中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Nginx如何配置跨域

發布時間:2021-09-09 11:10:32 來源:億速云 閱讀:498 作者:chen 欄目:服務器

本篇內容主要講解“Nginx如何配置跨域”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Nginx如何配置跨域”吧!

當出現403跨域錯誤的時候 No 'Access-Control-Allow-Origin' header is present on the  requested resource,需要給Nginx服務器配置響應的header參數,下面一起來看看吧!

Nginx如何配置跨域

一、 配置跨域

Nginx如何配置跨域

只需要在Nginx的配置文件中配置以下參數:

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

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

2. Access-Control-Allow-Headers 是為了防止出現以下錯誤:

Request header field Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.

這個錯誤表示當前請求Content-Type的值不被支持。其實是我們發起了"application/json"的類型請求導致的。這里涉及到一個概念:預檢請求(preflight  request),請看下面"預檢請求"的介紹。

3. Access-Control-Allow-Methods 是為了防止出現以下錯誤:

Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.

4. 給OPTIONS 添加 204的返回,是為了處理在發送POST請求時Nginx依然拒絕訪問的錯誤

發送"預檢請求"時,需要用到方法 OPTIONS ,所以服務器需要允許該方法。

三、 預檢請求(preflight request)

其實上面的配置涉及到了一個W3C標準:CROS,全稱是跨域資源共享 (Cross-origin resource  sharing),它的提出就是為了解決跨域請求的。

Nginx如何配置跨域

跨域資源共享(CORS)標準新增了一組 HTTP  首部字段,允許服務器聲明哪些源站有權限訪問哪些資源。另外,規范要求,對那些可能對服務器數據產生副作用的HTTP 請求方法(特別是 GET 以外的 HTTP  請求,或者搭配某些 MIME 類型的 POST 請求),瀏覽器必須首先使用 OPTIONS 方法發起一個預檢請求(preflight  request),從而獲知服務端是否允許該跨域請求。服務器確認允許之后,才發起實際的 HTTP  請求。在預檢請求的返回中,服務器端也可以通知客戶端,是否需要攜帶身份憑證(包括 Cookies 和 HTTP 認證相關數據)。

其實Content-Type字段的類型為application/json的請求就是上面所說的搭配某些 MIME 類型的 POST  請求,CORS規定,Content-Type不屬于以下MIME類型的,都屬于預檢請求:

application/x-www-form-urlencodedmultipart/form-datatext/plain

所以 application/json的請求 會在正式通信之前,增加一次"預檢"請求,這次"預檢"請求會帶上頭部信息  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 ...

服務器回應時,返回的頭部信息如果不包含Access-Control-Allow-Headers:  Content-Type則表示不接受非默認的的Content-Type。即出現以下錯誤:

Request header field Content-Type is not allowed by Access-Control-Allow-Headers in preflight response.

到此,相信大家對“Nginx如何配置跨域”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴宁市| 漾濞| 孙吴县| 康马县| 沧州市| 望都县| 东乌| 加查县| 山阳县| 武城县| 寿光市| 嵊泗县| 壶关县| 长宁县| 视频| 涡阳县| 临桂县| 新营市| 绩溪县| 金乡县| 商南县| 宝坻区| 连云港市| 霍邱县| 徐闻县| 清丰县| 秭归县| 水富县| 弥勒县| 常德市| 桂东县| 柘荣县| 大田县| 麻阳| 商城县| 京山县| 锡林郭勒盟| 包头市| 龙州县| 娄烦县| 濮阳县|