使用ajax发起请求时候,响应的数据类型由ajax设置的接受数据方式决定:

responseText决定响应的数据类型是文本;

responseXML决定响应的数据类型xml文档。

以Servlet为例,当返回xml文档时候,Servlet一定要设置response.setContentType("text/xml;charset=utf-8")。根据是否需要缓存,可以设置response.setHeader("Cache-control","no-cache");


响应数据的格式由HTTP响应报文的Content-Type决定:

text/xml xml

text/html html

text/plain 文本

application/json json

下面是Servlet返回文本、xml文档、json、html的代码:

index.jsp

[html] view plain copy
  1. <%@pagelanguage="java"contentType="text/html;charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
  4. <htmlheadMetahttp-equiv="Content-Type"content="text/html;charset=UTF-8"title>Inserttitlehere</scripttype="text/javascript"
  5. functiongetXMLHttpRequest(){
  6. varxmlReq;
  7. if(window.XMLHttpRequest){//codeforIE7+,Firefox,Chrome,Opera,Safari
  8. xmlReq=newXMLHttpRequest();
  9. }else{//codeforIE6,IE5
  10. newActiveXObject("Microsoft.XMLHTTP");
  11. }
  12. returnxmlReq;
  13. //返回文本数据测试
  14. functionajaxText(){
  15. varoReq=getXMLHttpRequest();
  16. oReq.open("POST","TextServlet",true);
  17. oReq.setRequestHeader("Content-type",
  18. "application/x-www-form-urlencoded");//提交表单必须
  19. oReq.send("name=我是文本&pwd=123");
  20. oReq.onreadystatechange=function(){
  21. if(oReq.readyState==4&&oReq.status==200){
  22. document.getElementById("myDiv").innerHTML=oReq.responseText;//responseText响应类型是文本
  23. }
  24. //返回XML文档测试
  25. functionajaxXML(){
  26. oReq.send("name=我是xml&pwd=111");
  27. varxmlObj=oReq.responseXML;//responseXML响应类型是XML文档
  28. varnames=xmlObj.documentElement.getElementsByTagName("name");
  29. varname=names[0].firstChild.nodeValue;
  30. varpwds=xmlObj.documentElement.getElementsByTagName("pwd");
  31. varpwd=pwds[0].firstChild.nodeValue;
  32. name+","+pwd;
  33. //返回json文档测试
  34. functionajaxJSON(){
  35. oReq.send("name=我是json&pwd=varresObj=oReq.responseText;//json字符串用文本形式接收
  36. varjsonObj1=eval('('+resObj+')');
  37. varname1=jsonObj1.name;
  38. varpwd1=jsonObj1.pwd;
  39. name1+","+pwd1;
  40. //返回html
  41. functionajaxHTML(){
  42. oReq.send("name=我是html&pwd=oReq.responseText;//html用文本形式接收
  43. resObj;
  44. scriptbodybuttononclick="ajaxText()">ajax请求文本button"ajaxXML()">ajax请求XML文档"ajaxJSON()">ajax请求json字符串"ajaxHTML()">ajax请求htmldivid="myDiv">div>


返回文本的Servlet:

[java] copy
    packagecom.ajax.test;
  1. importjava.io.IOException;
  2. importjavax.servlet.servletexception;
  3. importjavax.servlet.ServletoutputStream;
  4. importjavax.servlet.http.HttpServlet;
  5. importjavax.servlet.http.HttpServletRequest;
  6. importjavax.servlet.http.HttpServletResponse;
  7. publicclassTextServletextendsHttpServlet{
  8. protectedvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsservletexception,IOException{
  9. doPost(request,response);
  10. voiddoPost(HttpServletRequestrequest,IOException{
  11. System.out.println("intext");
  12. request.setCharacterEncoding("utf-8");
  13. Stringname=request.getParameter("name");
  14. Stringpwd=request.getParameter("pwd");
  15. "name:"+name+",pwd:"+pwd);
  16. //返回文本数据
  17. response.setContentType("text/plain;charset=utf-8");
  18. ServletoutputStreamoutputStream=response.getoutputStream();
  19. outputStream.write(name.getBytes("utf-8"));
  20. outputStream.write(pwd.getBytes("utf-8"));
  21. outputStream.flush();
  22. outputStream.close();
  23. }

AJAX responseText和responseXML的更多相关文章

  1. 关于h5中的fetch方法解读(小结)

    这篇文章主要介绍了关于h5中的fetch方法解读(小结),fetch身为H5中的一个新对象,他的诞生,是为了取代ajax的存在而出现,有兴趣的可以了解一下

  2. ios – 使用NSURLSession获取JSON数据

    我试图从谷歌距离api使用NSURLSession获取数据,但如下所示,当我打印响应和数据时,我得到的结果为NULL.可能是什么问题?

  3. xcode – Cordova plugin.xml添加“Header Search Paths”条目

    我希望将Cordova插件添加到Xcode项目后,在“HeaderSearchPaths”下添加一个新条目.如何在Cordovaplugin.xml文件中进行配置?

  4. ios – 有关多个连接/提要/视图的XML解析的设计/实现建议

    >我应该在每个视图中都有解析器类/对象或解析XML提要吗?

  5. ios – 错误域= com.alamofire.error.serialization.response代码= -1011“请求失败:禁止

    任何人都可以帮我解决以下错误–>在AFNetworking2.5中使用“删除”方法时出错解决方法我发现,如果我的手机时钟不同步……它不允许我更新…也许检查你的手机设置到正确的时间“自动区”,看看是否有效…

  6. iOS网页/原生应用Facebook登录弹出 – 失败?

    如果我重新启动app/web-app,用户将自动登录,并重定向到成功页面.我认为是导致问题的原因当您在Firefox/Chrome/Safari浏览器中运行网页时,Facebook登录对话框会弹出一个弹出窗口或另一个选项卡.我相信这是这个弹出页面的一个问题,以及当成功登录时Javascript如何与自身通信.window.close的东西没有返回的根页面…失败的解决方法由于应用程序挂在前面提到的URL上,我决定在shouldStartLoadWithRequest(…)中添加if语句以强制UIWebvie

  7. ios – Watchkit新会话不起作用

    我的手表扩展中有两个视图控制器.每当我打电话时我只得到第一个视图控制器的响应,并在第二个viewcontroller中得到错误WCSession在app和watch扩展中启动.任何建议?

  8. 使用Firebase iOS Swift将特定设备的通知推送到特定设备

    我非常感谢PushNotifications的帮助.我的应用聊天,用户可以直接向对方发送短信.但是如果没有PushNotifications,它就没有多大意义.它全部设置在Firebase上.如何将推送通知从特定设备发送到特定设备?

  9. ios – 保存从查询中获取的用户的属性(即不在currentUser上)

    我有兴趣根据currentUser执行的操作将属性保存到数据库中的用户.基于以下代码,我收到错误消息“除非已通过logIn或signUp验证用户,否则无法保存用户”我想知道是否有一个解决方法,我可以将属性保存到foundUser,而无需登录该用户.谢谢你的帮助!解决方法如果要更新当前不是登录用户的用户,则需要使用主密钥调用Parse.您可以从CloudCode执行此操作;并从您的iOS项目中调用它;

  10. 在iOS中使用NSJSONSerialization进行JSON解析

    解决方法首先在您的JSON响应字典中,在“RESPONSE”键下,您有一个数组而不是字典,该数组包含字典对象.所以要提取用户名和电子邮件ID,如下所示

随机推荐

  1. xe-ajax-mock 前端虚拟服务

    最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

  2. vue 使用 xe-ajax

    安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

  3. AJAX POST数据中文乱码解决

    前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

  4. Koa2框架利用CORS完成跨域ajax请求

    实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

  5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

  6. ajax的cache作用

    filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

  7. 浅谈ajax上传文件属性contentType = false

    默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

  8. 909422229_ajaxFileUpload上传文件

    ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

  9. AJAX-Cache:一款好用的Ajax缓存插件

    原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

  10. jsf – Ajax update/render在已渲染属性的组件上不起作用

    我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

返回
顶部