国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 網(wǎng)站 > Nginx > 正文

Nginx配置跨域請(qǐng)求Access-Control-Allow-Origin * 詳解

2024-08-30 12:24:23
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

當(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; }} 

上面配置代碼即可解決問題了,不想深入研究的,看到這里就可以啦=-=

二、 解釋

1. Access-Control-Allow-Origin

服務(wù)器默認(rèn)是不被允許跨域的。給Nginx服務(wù)器配置`Access-Control-Allow-Origin *`后,表示服務(wù)器可以接受所有的請(qǐng)求源(Origin),即接受所有跨域的請(qǐng)求。

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"的類型請(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依然拒絕訪問的錯(cuò)誤

發(fā)送"預(yù)檢請(qǐng)求"時(shí),需要用到方法 OPTIONS ,所以服務(wù)器需要允許該方法。

三、 預(yù)檢請(qǐng)求(preflight request)

其實(shí)上面的配置涉及到了一個(gè)W3C標(biāo)準(zhǔn):CROS,全稱是跨域資源共享 (Cross-origin resource sharing),它的提出就是為了解決跨域請(qǐng)求的。

跨域資源共享(CORS)標(biāo)準(zhǔn)新增了一組 HTTP 首部字段,允許服務(wù)器聲明哪些源站有權(quán)限訪問哪些資源。另外,規(guī)范要求,對(duì)那些可能對(duì)服務(wù)器數(shù)據(jù)產(chǎn)生副作用的HTTP 請(qǐng)求方法(特別是 GET 以外的 HTTP 請(qǐng)求,或者搭配某些 MIME 類型的 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ù)器端也可以通知客戶端,是否需要攜帶身份憑證(包括 Cookies 和 HTTP 認(rèn)證相關(guān)數(shù)據(jù))。

其實(shí)Content-Type字段的類型為application/json的請(qǐng)求就是上面所說的搭配某些 MIME 類型的 POST 請(qǐng)求,CORS規(guī)定,Content-Type不屬于以下MIME類型的,都屬于預(yù)檢請(qǐng)求:

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 南汇区| 开远市| 罗山县| 万全县| 武邑县| 平安县| 临武县| 满洲里市| 昭平县| 长武县| 阿城市| 金寨县| 通山县| 柳州市| 江安县| 和田县| 两当县| 扶风县| 清涧县| 庆阳市| 安顺市| 肇庆市| 秭归县| 交口县| 韶关市| 宕昌县| 清苑县| 德清县| 衡阳市| 杨浦区| 垦利县| 横山县| 三穗县| 定边县| 佛学| 边坝县| 京山县| 二手房| 自贡市| 呼伦贝尔市| 华坪县|