濮阳杆衣贸易有限公司

主頁 > 知識庫 > 如何利用map實現(xiàn)Nginx允許多個域名跨域

如何利用map實現(xiàn)Nginx允許多個域名跨域

熱門標簽:百度地圖底圖標注 撫州市城區(qū)地圖標注 電銷智能機器人試用 智能電銷機器人真的有用么 高德地圖標注足跡怎么打標 企業(yè)辦理400電話收費標準 新鄉(xiāng)牧野400電話申請 中國地圖標注上各個省 激光標記地圖標注

常見的 Nginx 配置允許跨域

server {
  listen    11111;
  server_name localhost;

  location ~ /xxx/xx {
    if ($request_method = 'OPTIONS') {
      return 204;
    }
    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';
    proxy_pass http://1.2.3.4:5678;
  }
}

指定 Access-Control-Allow-Origin 為 ‘*' ,即為最簡單暴力的允許所有訪問跨域

允許 Cookie

有些場景下需要使用 Cookie,這時 Nginx 需要加一句 add_header Access-Control-Allow-Credentials 'true';,但此時會發(fā)現(xiàn)瀏覽器報錯,說該參數(shù)為 true 時,allow origin 不能設(shè)置為 ‘*‘,如果手動指定了多個域名,那同樣會被瀏覽器提示錯誤,說 allow origin 不能設(shè)置多個,這些是協(xié)議層面的限制

使用 map

在 Nginx 中可以使用 map 得到一個自定義變量,簡單的使用可以參考官方文檔,在上面提到的場景中,可以對請求中的 origin 做一個過濾處理,把符合要求的請求域名放到一個變量中,在設(shè)置 allow origin 時使用該變量就能實現(xiàn)一個動態(tài)的、多個的允許跨域域名

一個示例配置如下:

map $http_origin $allow_origin {
  default "";
  "~^(https?://localhost(:[0-9]+)?)" $1;
  "~^(https?://127.0.0.1(:[0-9]+)?)" $1;
  "~^(https?://172.10(.[\d]+){2}(:[0-9]+)?)" $1;
  "~^(https?://192.168(.[\d]+){2}(:[0-9]+)?)" $1;
}

server {
  listen    11111;
  server_name localhost;

  location ~ /xxx/xx {
    if ($request_method = 'OPTIONS') {
      return 204;
    }
    add_header Access-Control-Allow-Origin $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';
    add_header Access-Control-Allow-Credentials 'true';
    proxy_pass http://1.2.3.4:5678;
  }
}

解釋說明:

$http_origin 是 Nginx 的內(nèi)部變量,用于獲取請求頭中的 origin

$allow_origin 是可以自定義的變量名

總結(jié)

到此這篇關(guān)于如何利用map實現(xiàn)Nginx允許多個域名跨域的文章就介紹到這了,更多相關(guān)map實現(xiàn)Nginx允許多個域名跨域內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

標簽:邯鄲 忻州 南通 西安 臨汾 辛集 延安 海西

巨人網(wǎng)絡(luò)通訊聲明:本文標題《如何利用map實現(xiàn)Nginx允許多個域名跨域》,本文關(guān)鍵詞  如何,利用,map,實現(xiàn),Nginx,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何利用map實現(xiàn)Nginx允許多個域名跨域》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何利用map實現(xiàn)Nginx允許多個域名跨域的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    靖宇县| 独山县| 新源县| 明水县| 仙居县| 玉环县| 扎赉特旗| 龙江县| 石渠县| 姜堰市| 射阳县| 信宜市| 镇江市| 西畴县| 莱芜市| 榆中县| 喀什市| 扬中市| 蚌埠市| 阳春市| 工布江达县| 安阳县| 凌云县| 汽车| 塔城市| 麻阳| 渝中区| 朝阳区| 山西省| 旌德县| 东平县| 磐石市| 元朗区| 宁明县| 宁晋县| 百色市| SHOW| 阜南县| 休宁县| 诏安县| 临湘市|