共计 938 个字符,预计需要花费 3 分钟才能阅读完成。
在项目中采用 token 来验证用户登录,运作机制大致如下
用户首次登录成功时,server-end 发送 token 到 client,client 存入 cookie。
用户做任何请求操作时,在 ajax 的 headers 里带上 token,用以 server-end 做登录状态验证。
请求
$.ajax({
type: type,
timeout: 10000, // 超时时间 10 秒
headers: {'Access-Token':$.cookie('access_token')
},
url: url,
data: data,
success: function(data) { },
error: function(err) { },
complete: function(XMLHttpRequest, status) {// 请求完成后最终执行参数}
})
报错:
Request header field Access-Token is not allowed by Access-Control-Allow-Headers in preflight response.
1
其中 Access-Control-Allow-Headers 首部字段用于预检请求的响应。其指明了实际请求中允许携带的首部字段。参考 MDN
查阅了很多参考资料以及各位前辈踩坑记录,得到如下总结:
报错意思是请求头中的 Access-Token 字段在 Access-Control-Allow-Headers 中没有被设置为允许.
谁来设置?
一种是 font-end 自己设置,在 ajax 在中设置 beforeSend
$.ajax({
type: type,
timeout: 10000,
beforeSend: function(xhr) {xhr.setRequestHeader("Access-Toke");
},
headers: {'Access-Token':$.cookie('access_token')
},
url: url,
data: data,
success: function(data) { },
error: function(err) { },
complete: function(XMLHttpRequest, status) {// 请求完成后最终执行参数}
});
希望对大家有所帮助
原文地址: jQuery Ajax 设置请求头
正文完