cors数据类型_jQuery CORS内容类型选项

使用自定义Content-type的jQuery CORS发送AJAX正文请求时遇到问题。这是我的代码:

$.ajax({

url: "http://some-other-domain/my-path",

type: "POST",

contentType: "application/json",

dataType: "json",

data: JSON.stringify({

key: 1,

key2: 2

}),

statusCode: {

200: function(data) {

}

},

xhrFields: {

withCredentials: true

},

crossDomain: true

});

我需要将Content-type设置为“ application / json”,因为它需要服务器端。但是jQuery并非以POST形式发送请求,而是以OPTIONS形式发送请求。

这是标题:

响应标题:

HTTP/1.1 200 OK

Server: Apache-Coyote/1.1

Pragma: No-cache

Cache-Control: no-cache

Expires: Thu, 01 Jan 1970 03:00:00 EET

Set-Cookie: JSESSIONID=BB9D6783E58FB0F2ADE1924A2F0CBA52; Path=/

Content-Type: text/html;charset=UTF-8

Content-Length: 6233

Date: Fri, 07 Sep 2012 14:41:13 GMT

请求标头:

OPTIONS /my-path HTTP/1.1

Host: MY-HOME-NAME

User-Agent: MY_USER_AGEMT

Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

Accept-Language: en-us,en;q=0.5

Accept-Encoding: gzip, deflate

Connection: keep-alive

Origin: HERE-GOES-DOMAIN

Access-Control-Request-Method: POST

Access-Control-Request-Headers: content-type

Pragma: no-cache

Cache-Control: no-cache

CORS运作良好,所有必需的标头均由服务器发送,但如果按OPTIONS类型发送,则不能。是jQuery问题吗?

jQuery-1.8.1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CORS(跨域资源共享)错误是指在使用XMLHttpRequest(XHR)进行跨域请求时出现的错误。在浏览器中,为了保护用户的安全,限制了跨域请求,即无法通过XHR直接从一个域名向另一个域名发起请求。然而,在某些情况下,我们可能需要进行跨域请求,这时就会出现CORS错误。 CORS错误主要有以下几种类型: 1. 简单请求(Simple Request)错误:简单请求是指满足一些特定条件的跨域请求。例如,使用GET、POST、HEAD方法之一,并且只使用了允许的头部字段等。如果在简单请求中出现CORS错误,通常是因为后端服务器未正确设置CORS响应头部,如Access-Control-Allow-Origin。 2. 预检请求(Preflight Request)错误:预检请求是指满足一些复杂条件的跨域请求。例如,使用了PUT、DELETE等非简单方法,或者使用了自定义的请求头部字段。在发送预检请求时,浏览器会先发送一个OPTIONS请求,后端服务器需要正确处理该请求,并返回带有正确CORS响应头部的响应。如果在预检请求中出现CORS错误,可能是因为服务器未正确处理OPTIONS请求。 3. 带身份凭证请求(Request with Credentials)错误:当XHR请求设置了withCredentials为true时,代表允许跨域请求携带身份凭证(如cookie)。在这种情况下,跨域请求的服务器需要设置允许携带身份凭证的响应头部,如Access-Control-Allow-Credentials。如果未正确设置,会导致CORS错误。 为了解决CORS错误,可以采取以下措施: 1. 在后端服务器中正确设置CORS响应头部,包括Access-Control-Allow-Origin、Access-Control-Allow-Methods、Access-Control-Allow-Headers等。 2. 如果出现预检请求错误,需要在后端服务器中正确处理OPTIONS请求,并返回带有正确CORS响应头部的响应。 3. 如果需要跨域请求携带身份凭证,需要在后端服务器中设置Access-Control-Allow-Credentials为true,并在前端请求中设置withCredentials为true。 总的来说,解决CORS错误需要在前端和后端共同进行配置和处理。前端通过设置XHR请求的头部字段和withCredentials属性,后端通过设置CORS响应头部来实现跨域请求的安全和成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值