java的ajax的响应方法_Ajax中与服务器的通信【发送请求与处理响应】

一、发送请求

Ajax中通过XMLHttpRequest对象发送异步方式的后台请求时。通常有两种方式的请求,一种是GET请求,另一种是POST请求。发送请求一般要经过4个步骤分别是:

(1)初始化XMLHttpRequest对象

(2)为XMLHt指定一个返回结果的回调函数,用于返回结果的处理

(3)创建一个与服务器的连接。指定发送的请求是GET还是POST且是否采用异步方式发送请求

(4)向服务器发送请求。

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1

2

3 functioncheckBrowerType(){4 //第一步:初始化XMLHttpRequest对象

5 var http_request = false;6 if(window.XMLHttpRequest){ //非IE浏览器; 在调用window.ActiveXObject将返回一个对象,或是null(如果返回一个对象则为true,返回null则为false)

7 http_request = new XMLHttpRequest(); //创建XMLHttpRequest对象

8

9 }else if(window.ActiveXObject){10 try{11 http_request = new ActiveXObject("Msxml2.XMLHTTP"); //创建XMLHttpRequest对象

12 }catch(e){13 try{14 http_request = new ActiveXObject("Microsoft.XMLHTTP"); //创建XMLHttpRequest对象

15 }catch(e){16

17 }18 }19 }20 if(!http_request){21 alert("不能创建XMLHttpRequest对象实例");22 return false;23 }24 //第二步:设置回调函数

25 http_request.onreadystatechange = getResult; //调用返回处理函数

26 /*

27 注意:如果XMLHttpRequest对象的onreadystatechange属性指定回调函数时,28 不能指定要传递的参数。如果要指定参数可以使用以下方法:29 http_request.onreadystatechange = function(){30 getResult(param)31 };32 */

33

34 //第三步:创建一个与服务器的连接,(请求采用GET或POST请求方式,以及是否采用异步方式)

35 http_request.open("GET",url,true);36 //第四步:向服务器发送请求

37 http_request.send(null);38 }39 /*编写回调函数getResult()*/

40 functiongetResult(){41

42 }43

查看代码

小技巧:在建立与服务器的连接时,指定open(“method”,“url” ,async)中的url参数时,最好将一个时间戳追加到该url参数后面,这样可以防止因浏览器缓存结果而不能实时得到最新的结果。例如:可以这样指定url参数:String url="deal.jsp?nocache="+new Date().getTime();

二、处理服务器的响应

在处理服务器响应时需要通过XMLHttpRequest对象的onreadystatechange属性指定一个回调函数,用来处理服务器响应。在这个回调函数中,首先需要判断服务器的请求状态,保证请求已经完成;然后根据服务器的HTTP状态码,判断服务器对请求响应是否成功,如果成功,则获取服务器的响应反馈给客户。

XMLHttpRequest中提供了两种访问服务器响应的属性:一个是responseText属性,返回字符串响应;另一个是responseXML属性,返回XML响应。

(1)处理字符串响应

例如:

1 functiongetResult(){2 if(http_request.readyState == 4){ //判断请求状态

3 if(http_request.status == 200){ //请求成功,开始处理返回结果

4 alert(http_request.responseText); //显示判断结果

5 }else{6 alert("请求的页面有错误!");7 }8 }9 }

(2)处理XML响应

如果在服务器端需要生成特别负责的响应,则就要应用XML响应。

例:保存图书信息到XML文档中,并且使用回调函数将XML中的信息读取出来。

①XML中的图书信息,代码如下:

1 <?xml version="1.0" encoding="UTF-8"?>

2

3

4

5

Java Web程序开发

6 人民邮电出版社

7

8

9

Java从入门到精通

10 人民邮电出版社

11

12

13

②在回调函数中遍历保存图书信息的XML文档,并将其显示到页面中,代码如下:

1

2 functiongetResult(){3 //判断请求状态

4 if(http_request.readyState == 4){5 //请求成功,开始处理响应

6 if(http_request.status == 200){7 var xmldoc =http_request.responseXML;8 var str = "";9 for(int i=0;i

12 +book.getElementByTagName("publisher")[0].firstChild.data + "” 出版
";13 }14 document.getElementById("book").innerHTML = str; //显示图书信息

15 }else{16 alert("请求的页面有错误!");17 }18

19 }20 }21

22

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值