當(dāng)出現(xiàn)403跨域錯(cuò)誤的時(shí)候 No 'Access-Control-Allow-Origin' header is present on the requested resource
擂仍,需要給Nginx服務(wù)器配置響應(yīng)的header參數(shù):
一其障、 解決方案
只需要在Nginx的配置文件中配置以下參數(shù):
location / {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
if ($request_method = 'OPTIONS') {
return 204;
}
}
上面配置代碼即可解決問(wèn)題了沛硅,不想深入研究的,看到這里就可以啦=-=
二、 解釋
1. Access-Control-Allow-Origin
服務(wù)器默認(rèn)是不被允許跨域的。給Nginx服務(wù)器配置Access-Control-Allow-Origin *
后,表示服務(wù)器可以接受所有的請(qǐng)求源(Origin),即接受所有跨域的請(qǐng)求嘉竟。</pre>
2. Access-Control-Allow-Headers 是為了防止出現(xiàn)以下錯(cuò)誤:
Request header field Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.
這個(gè)錯(cuò)誤表示當(dāng)前請(qǐng)求Content-Type的值不被支持。其實(shí)是我們發(fā)起了"application/json"的類(lèi)型請(qǐng)求導(dǎo)致的洋侨。這里涉及到一個(gè)概念:預(yù)檢請(qǐng)求(preflight request)
,請(qǐng)看下面"預(yù)檢請(qǐng)求"的介紹舍扰。
3. Access-Control-Allow-Methods 是為了防止出現(xiàn)以下錯(cuò)誤:
Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.
4.給OPTIONS
添加 204
的返回,是為了處理在發(fā)送POST請(qǐng)求時(shí)Nginx依然拒絕訪(fǎng)問(wèn)的錯(cuò)誤
發(fā)送"預(yù)檢請(qǐng)求"時(shí)希坚,需要用到方法 OPTIONS
,所以服務(wù)器需要允許該方法边苹。
三、 預(yù)檢請(qǐng)求(preflight request)
其實(shí)上面的配置涉及到了一個(gè)W3C標(biāo)準(zhǔn):CROS
,全稱(chēng)是跨域資源共享 (Cross-origin resource sharing)裁僧,它的提出就是為了解決跨域請(qǐng)求的个束。
跨域資源共享(CORS)標(biāo)準(zhǔn)新增了一組 HTTP 首部字段慕购,允許服務(wù)器聲明哪些源站有權(quán)限訪(fǎng)問(wèn)哪些資源。另外茬底,規(guī)范要求沪悲,
對(duì)那些可能對(duì)服務(wù)器數(shù)據(jù)產(chǎn)生副作用的HTTP 請(qǐng)求方法(特別是 GET 以外的 HTTP 請(qǐng)求,或者搭配某些 MIME 類(lèi)型的 POST 請(qǐng)求)
阱表,瀏覽器必須首先使用 OPTIONS 方法發(fā)起一個(gè)預(yù)檢請(qǐng)求(preflight request)殿如,從而獲知服務(wù)端是否允許該跨域請(qǐng)求。服務(wù)器確認(rèn)允許之后最爬,才發(fā)起實(shí)際的 HTTP 請(qǐng)求涉馁。在預(yù)檢請(qǐng)求的返回中,服務(wù)器端也可以通知客戶(hù)端爱致,是否需要攜帶身份憑證(包括 Cookies 和 HTTP 認(rèn)證相關(guān)數(shù)據(jù))烤送。
其實(shí)Content-Type字段的類(lèi)型為application/json
的請(qǐng)求就是上面所說(shuō)的搭配某些 MIME 類(lèi)型的 POST 請(qǐng)求
,CORS規(guī)定,Content-Type不屬于以下MIME類(lèi)型的糠悯,都屬于預(yù)檢請(qǐng)求:
application/x-www-form-urlencoded
multipart/form-data
text/plain</pre>
所以 application/json的請(qǐng)求 會(huì)在正式通信之前帮坚,增加一次"預(yù)檢"請(qǐng)求,這次"預(yù)檢"請(qǐng)求會(huì)帶上頭部信息 Access-Control-Request-Headers: Content-Type
:
OPTIONS /api/test HTTP/1.1
Origin: http://foo.example
Access-Control-Request-Method: POST
Access-Control-Request-Headers: Content-Type
... 省略了一些
理解:
Origin: http://foo.example
origin為發(fā)起跨域請(qǐng)求的地址逢防,即原網(wǎng)址
例如:A域名下請(qǐng)求B域名下的資源叶沛,即為跨站蒲讯,這里origin即為A忘朝。如果B的服務(wù)器允許跨站,必須在服務(wù)端進(jìn)行配置判帮,指定如下參數(shù)
Access-Control-Allow-Origin: A
或
Access-Control-Allow-Origin: *//允許所有
服務(wù)器回應(yīng)時(shí)局嘁,返回的頭部信息如果不包含Access-Control-Allow-Headers: Content-Type
則表示不接受非默認(rèn)的的Content-Type。即出現(xiàn)以下錯(cuò)誤:
Request header field Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.
參考文章: