jQuery在header中设置请求信息的方法
jquery是js的类库,js本身不能操作header,因为js是在浏览器加载页面过程中才开始执行的header需要服务器端执行操作
如果是ajax,是可以设置header
$.ajax({
url:"",
data:{},
type:"GET",
beforeSend:function(xhr){xhr.setRequestHeader('X-Test-Header','test-value');},//这里设置header
success:function(){}
});
也就是setRequestHeader函数
如何在ajax请求中设置特殊的RequestHeader
现在ajax应用已经相当广泛了,有很多不错的ajax框架可供使用。ajax是一个异步请求,也主要是一种客户端的脚本行为。那么,如何在请求之前为请求添加特殊的一些头部信息呢?
下面是一个简单的例子,我用jQuery编写,它的ajax函数中,有一个beforeSend方法,这个方法接受一个参数,就代表了发起异步请求的XMLHttpRequest对象,我们可以用该对象的setRequestHeader方法实现我们的目的
为什么要setRequestHeader?
比如,在及时通信系统中,每次获取消息或者发送消息,都需要去判断这个用户是否还在连线中,通过设置"accessToken",就可以实现正常通信;
beforeSend:function(request){
request.setRequestHeader("accessToken",accessToken);
},
<%@PageLanguage="C#"AutoEventWireup="true"CodeFile="Default2.aspx.cs"Inherits="Default2"%>
$(function(){
$("#test").click(function(){
$.ajax({
type:"GET",
url:"default.aspx",
beforeSend:function(request){
request.setRequestHeader("Test","Chenxizhang");
},
success:function(result){
alert(result);
}
});
});
});