java setrequestheader_XMLHttpRequest里的setRequestHeader到底怎么用

在Ajax应用程序中,XmlHttpRequest对象负责将用户信息以异步通信地发送到服务器端,并接收服务器返回的响应信息和数据。

XMLHttpRequest简介

XMLHttpRequest可以提供不重新加载页面的情况下更新网页,在页面加载后在客户端向服务器请求数据,在页面加载后在服务器端接受数据,在后台向客户端发送数据。XMLHttpRequest 对象提供了对 HTTP 协议的完全的访问,包括做出 POST 和 HEAD 请求以及普通的 GET 请求的能力。XMLHttpRequest 可以同步或异步返回 Web 服务器的响应,并且能以文本或者一个 DOM 文档形式返回内容。尽管名为 XMLHttpRequest,它并不限于和 XML 文档一起使用:它可以接收任何形式的文本文档。XMLHttpRequest 对象是名为 AJAX 的 Web 应用程序架构的一项关键功能。

XMLHttpRequest和Javascript

Javascript本身并未具备向服务器发送请求的能力,要么使用window.open()方法重新打开一个页面向服务器提交请求,要么使用XMLHttpRequest对象发送请求。不同的是,前者是普通的即同步交互模式,而后者是异步交互方式。

XMLHttpRequest提供了一系列的属性和方法,来向服务器发送异步的http请求;在服务器处理用户请求的过程中,XMLHttpRequest通过属性的状态值来实时反映http请求所处的状态,并根据这些状态指示Javascript做相应的处理;当服务器顺利完成响应用户行为的动作、并将响应数据返回时,XMLHttpRequest提供的response系列方法,可以将这些响应数据以文本、XML Document对象、Ado Stream对象或者unsigned byte数组的方式组装起来,提供给Javascript处理。

XMLHttpRequest的五步使用法:

1、 建立XMLHttpRequest对象

2、 注册回调函数

3、 使用open方法社会自和服务器端交互的基本信息

4、 设置发送的数据,开始和服务器端交互

5、 在回调函数中判断交互是否结束,响应是否正确,并根据需要过去服务器端返回的数据,更新页面内容

下面我们以用户名确认来实现XMLHttpRequest的五步使用法:

var xmlhttp;

function submit(){

//1.创建XHLHttpRequest对象

if(window.XMLHttpRequest){

//alert("IE7,IE8 ,FireFox。Mozillar、Safari,Opera");

//IE7,IE8 ,FireFox。Mozillar、Safari,Opera

xmlhttp=new XMLHttpRequest();

if(xmlhttp.overrideMimeType){

xmlhttp.overrideMimeType("text/xml");

}

}else if(window.ActiveXObject){

//IE6,IE6.5 IE5

alert("IE6,IE6.5 IE5");

var activexName= ['MSXML2.XMLHTTP.6.0','MSXML2.XMLHTTP.5.0',

'MSXML2.XMLHTTP.4.0','msxml2.xmlhttp.3.0','MSXML2.XMLHTTP.2.0',

'MSXML2.XMLHTTP.1.0'];

for(var i=0; i

try{

xmlhttp=new ActiveXObject(activexName[i]);

break;

}catch(e){

}

}

}

if(xmlhttp==undefined||xmlhttp==null){

alert("当前浏览器不支持穿件XMLHttpRequest对象,请更换浏览器");

return;

}

//alert(xmlhttp);

//2.注册回调方法

xmlhttp.onreadystatechange=callback;

//错误的写法callback();

//记忆一个固定用法,获取文本框中用户输入的内容

var userName=document.getElementById("UserName").value;

/*

//GET方式交互

//设置和服务器端交互的相应参数

xmlhttp.open("GET","AjaxServer?name="+userName,true);

//4.设置向服务器端发送的数据,启动和服务器端的交互

xmlhttp.send(null);

*/

//POST方式交互

//3.设置和服务器端交互的相应参数

xmlhttp.open("POST","AjaxServer",true);

//POST方式交互所需要增加的代码

xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");

//4.设置向服务器端发送的数据,启动和服务器端的交互

xmlhttp.send("name="+userName);

}

function callback(){

//5.判断和服务器端的交互是否完成,还有判断服务器端是否正确返回了数据

if(xmlhttp.readyState==4){

//表示和服务器端的交互已经完成

//服务器返回的http状态码

//200表示“成功”,404表示“未找到”。500表示“服务器内容部错误”

//alert(xmlhttp.status);

if(xmlhttp.status==200){

//表示服务器端的响应代码是200,正确的返回了数据

//纯文本数据的接受方法

var message=xmlhttp.responseText;

//XML数据对应的DOM对象的接受方法

//使用前提是,服务器端需要设置content-type为text/xml

//var domXml=xmlhttp.responseXML;

alert("bb");

//记忆想div标签填充文本内容的方法

var div=document.getElementById("message");

div.innerHTML=message;

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值