jQuery.ajax跨域请求webapi设置headers的解决⽅案
解决跨域调⽤服务并设置headers 主要的解决⽅法需要通过服务器端设置响应头、正确响应options请求,正确设置 JavaScript端
需要设置的headers信息⽅能实现。
1.第⼀步服务端设置响应头,在webapi的fig做如下设置
<system.webServer>
<httpProtocol>
jquery实现ajax
<!--跨域配置开始-->
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*" /><!--⽀持全域名访问,不安全,部署后需要固定限制为客户端⽹址-->
<add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" /><!--⽀持
的http 动作-->
<add name="Access-Control-Allow-Headers" value="Content-Type,X-Requested-With,token" /><!--响应头请按照⾃⼰需求添加这⾥新加了token这个headers--> <add name="Access-Control-Request-Methods" value="GET, POST, PUT, DELETE, OPTIONS" /><!--允许请求的http 动作-->
</customHeaders>
<!--跨域配置结束-->
</httpProtocol>
2.第⼆部了解IE chrome 等浏览器对于跨域请求并要求设置Headers⾃定义参数的时候的 "预请求" 就是如果遇到跨域并设置headers的请求,所有请求需要两步完成!
A 第⼀步:发送预请求 OPTIONS 请求。此时服务器端需要对于OPTIONS请求作出响应⼀般使⽤202响应即可不⽤返回任何内容信息。(能看到这份⼿稿的⼈,本⼈不相信你后台处理不了⼀个options请求)options请求可在权限中处理
/// <summary>
/// 权限
/// </summary>
public class ApiAuthorizeAttribute : AuthorizeAttribute
{
public override void OnAuthorization(HttpActionContext actionContext)
{
if (actionContext.Request.Method == HttpMethod.Options)
{
actionContext.Response = actionContext.Request.CreateResponse(HttpStatusCode.Accepted);
return;
}
}
}
B 第⼆步:服务器accepted 第⼀步请求后浏览器⾃动执⾏第⼆步发送真正的请求。
客户端代码:
$("#btnSumit").click(function () {
var Ticket = $.cookie("token");
var model = {
id: 1
};
$.ajax({
type: "POST",
url: "localhost:65312/api/products/FindProductById",
data: JSON.stringify(model),
contentType: "application/json; charset=utf-8",
dataType: "json",
beforeSend: function (xhr) {
// //发送ajax请求之前向http的head⾥⾯加⼊验证信息
xhr.setRequestHeader("token", Ticket); // 请求发起前在头部附加token
},
success: function (data, status) {
if (data.statuscode == "401") {
alert(data.msg);
}
else
{
alert(JSON.stringify(data))
}
},
//error: function (XMLHttpRequest, textStatus, errorThrown) {
// alert(XMLHttpRequest.status);
// adyState);
// alert(textStatus);
//},
complete: function () {
}
});
});
以上所述是⼩编给⼤家介绍的jQuery.ajax 跨域请求webapi设置headers解决⽅案,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。