java ajax 获取headers_js ajax设置和获取自定义header信息的方法总结

1、js ajax 设置自定义header

1.1 方法一:

$.ajax({

type: "POST",

url: "Handler1.ashx",

contentType: "application/x-www-form-urlencoded",

beforeSend: function (request) {

request.setRequestHeader("token1", "Chenxizhang");

},

success: function (data) {

//your code

}

});

1.2 方法二:

$.ajax({

headers: {

"testheader": "test"

},

type: "POST",

url: "Handler1.ashx",

contentType: "application/x-www-form-urlencoded",

success: function (data) {

//your code

}

});

2、js ajax 获取请求返回的response的header信息

ajax请求完成,会返回xhr(XMLHTTPRequest)对象,这里面会包含返回的头信息,可以通过getResponseHeader(key)和getAllResponseHeaders()获取header信息;

$.ajax({

type: "POST",

url: "Handler1.ashx",

contentType: "application/x-www-form-urlencoded",

success: function (data) {

//your code

},

complete: function (xhr, data) {

/*

获取相关Http Response header

getResponseHeader(key):获取指定头信息

getAllResponseHeaders():获取全部可默认可获取的头信息

*/

var date=xhr.getResponseHeader('Date');// 服务器端时间

//获取服务端自定义的header信息

var stoken = xhr.getResponseHeader('servertoken');

var list = xhr.getAllResponseHeaders();

console.log(list);

/*

date: Fri, 12 Jul 2019 12:41:00 GMT

content-encoding: gzip

server: Microsoft-IIS/10.0

x-aspnet-version: 4.0.30319

x-powered-by: ASP.NET

vary: Accept-Encoding

content-type: text/plain; charset=utf-8

servertoken: test1

cache-control: private

content-length: 129

*/

}

});

3、js ajax 跨域请求的情况下获取自定义的header信息

JS AJAX 跨域请求的时候是不能设置自定义的header信息的,但是是可以在response中获取到服务端自定义的header信息,前提是服务端设置了Access-Control-Expose-Headers;

下面是 ASP.NET 的服务端示例:

public void ProcessRequest(HttpContext context)

{

context.Response.AddHeader("Access-Control-Allow-Origin", "*");

context.Response.AddHeader("Access-Control-Allow-Headers", "*");

context.Response.AddHeader("Access-Control-Allow-Methods", "*");

//自定义header信息

context.Response.AddHeader("servertoken", "test");

context.Response.AddHeader("Access-Control-Expose-Headers", "servertoken");

context.Response.ContentType = "text/plain";

context.Response.Write("Hello World");

}

——————————————————————————————————————

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值