好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 通過Nginx代理轉發配置實現跨域的方法(API代理轉發)

通過Nginx代理轉發配置實現跨域的方法(API代理轉發)

熱門標簽:蘭州ai電銷機器人招商 江西外呼系統 新邵電銷機器人企業 新科美甲店地圖標注 湖北ai智能電銷機器人 AI電銷機器人 源碼 北海市地圖標注app 外呼系統打哪顯哪 高德地圖標注論壇

前言

在WEB開發中,我們經常涉及到跨域的請求,解決跨域問題的方式有很多,比如有window.name、iframe、JSONP、CORS等等,就不詳細展開了,涉及到 協議、端口 不一樣的跨域請求方式是采用代理,這里我們重點聊聊Nginx代理的方式。

場景
本地啟動了一個前后端分離的WEB應用,端口為:3000,可以通過http://127.0.0.1:3000訪問前端頁面,頁面中有些Ajax請求的地址為http://127.0.0.1:3000/api/getList,一般情況下肯定是404或者請求失敗,如下圖:

這種后端服務的接口存放在于其他的服務器中,比如在公司內網可以通過http://172.30.1.123:8081/api/getList訪問到測試環境中的服務接口。

這種情況的請求就涉及到端口不一樣的跨域了,那么我們可以利用Nginx代理請求。

Nginx代理配置參考

首先找到Nginx配置文件:

  • Windows下路徑就是你安裝Nginx目錄下找,比如我的放在C盤根目錄,那就是:c:\nginx\conf\nginx.conf
  • Mac系統配置文件路徑在: /usr/local/etc/nginx/nginx.conf, Finder下通過Shift+Command+G,輸入/usr/local/etc/nginx/進入該目錄。

在Nginx配置文件中添加如下配置:

server {
 listen 80;
 server_name 127.0.0.1;

 location / {
 proxy_pass http://127.0.0.1:3000;
 }

 location ~ /api/ {
 proxy_pass http://172.30.1.123:8081;
 }
}

上面的配置的可以理解為:

監聽80端口(Nginx默認啟動了80端口),將http://127.0.0.1的所有請求服務轉發到127.0.0.1端口為3000;
將http://127.0.0.1/api/或者http://127.0.0.1/api/getList請求轉發到http://172.30.1.123:8081

完成

經過上面的配置我們可以直接通過http://127.0.0.1訪問我們的WEB應用(如果采用IP訪問),而相關的API請求也會根據我們的Nginx配置進行相應的請求,瀏覽器端看到的/api/getList請求的是127.0.0.1端口為80的端口,但是實際上這個請求已經被我們的Nginx轉發指向http://172.30.1.123:8081/api/getList

優化:

基本的代理功能就像上面如此簡單的配置即可。

但是,當我們需要獲取真實IP的業務時,還需要添加關于真實IP的配置,如下:

server {
 listen 80;
 server_name 127.0.0.1;

 location / {
 proxy_pass http://127.0.0.1:3000;
 proxy_set_header Host $host:80;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }

 location ~ /api/ {
 proxy_pass http://172.30.1.123:8081;
 proxy_set_header Host $host:80;
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }
}

proxy_set_header這個配置是改變HTTP的請求頭,而Host是請求的主機名,X-Real-IP是請求的真實IP,X-Forwarded-For表示請求是由誰發起的。

因為我們的Nginx在這里屬于代理服務器,通過proxy_set_header配置這些信息目的是讓服務端獲取到真實的請求頭。

友情提示:

Nginx每一條配置語句后面都必須要加分好; 否則會報配置錯誤,自己還一臉懵逼。

拓展

綁定host

如果你覺得輸入IP訪問不爽那你可以自己修改host,推薦host修改神器:SwitchHosts。

host修改參考:

127.0.0.1 www.domain.com  #改成你需要的任何域名

如果綁定了host,在Nginx配置中當然也可以直接配置你指定的域名,譬如:

server {
 listen 80;
 server_name www.domain.com; #這里將IP改成你的域名
 #...
}

修改host后你可以直接通過你的域名訪問,如:http://www.domain.com

關于location

上面的配置你可能會對localtion后面的配置感到疑惑,關于localtion后面的常用的需求有:

localtion / {
 # 所有請求都匹配以下規則
 # 因為所有的地址都以 / 開頭,所以這條規則將匹配到所有請求
 # xxx 你的配置寫在這里
}

location = / {
 # 精確匹配 / ,后面帶任何字符串的地址都不符合
}

localtion /api {
 # 匹配任何 /api 開頭的URL,包括 /api 后面任意的, 比如 /api/getList
 # 匹配符合以后,還要繼續往下搜索
 # 只有后面的正則表達式沒有匹配到時,這一條才會采用這一條
}

localtion ~ /api/abc {
 # 匹配任何 /api/abc 開頭的URL,包括 /api/abc 后面任意的, 比如 /api/abc/getList
 # 匹配符合以后,還要繼續往下搜索
 # 只有后面的正則表達式沒有匹配到時,這一條才會采用這一條
}
以/ 通用匹配, 如果沒有其它匹配,任何請求都會匹配到
=開頭表示精確匹配
如 A 中只匹配根目錄結尾的請求,后面不能帶任何字符串。
^~ 開頭表示uri以某個常規字符串開頭,不是正則匹配
~ 開頭表示區分大小寫的正則匹配;
~* 開頭表示不區分大小寫的正則匹配

更多詳細localtion的正則匹配規則可參考:nginx配置location總結及rewrite規則寫法

后記

筆者也是Nginx的初級使用者,希望通過通俗易懂的方式記錄這些知識,分享給有需要的人,一起鉆研學習,如有紕漏,歡迎指正,謝謝!

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

標簽:阿克蘇 黔東 黃石 大理 自貢 池州 海南 南陽

巨人網絡通訊聲明:本文標題《通過Nginx代理轉發配置實現跨域的方法(API代理轉發)》,本文關鍵詞  通過,Nginx,代理,轉發,配置,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《通過Nginx代理轉發配置實現跨域的方法(API代理轉發)》相關的同類信息!
  • 本頁收集關于通過Nginx代理轉發配置實現跨域的方法(API代理轉發)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 学生自慰喷潮A片免费观看 | 国产免费91视频| 男人j桶进女人p无遮挡| 高跟91????白丝| 啊灬啊灬啊灬啊灬快灬高潮| 欧美人与性囗牲恔配视频| 1688影院免费观看电视剧软件| 日本一区免费在线| 免费精品视频| 午夜精品无码亚洲AV| 村长又粗又长弄死我了| 办公室揉弄小雪好爽日本电视剧| 腿抬高点吃扇贝| 久久人人爽人人爽大片aw| 国产午睡精品沙发系列| 女KTVWC沟厕偷窥| 孕妇性孕交XXXXXWWW| 狠狠色噜噜色狠狠狠综合久久按摩| 久久精品国产对白国产AV老师| 99热九九这里只有精品10 | 免费看91| 阳茎伸入女人的阳道免费视频| 麻豆aV国产一区二区三区| 国产成人亚洲精品影院| 91原创国产| yy6080一级毛片普通话| 亚洲V欧美V国产V在线观看| 很污很黄很肉尺寸大动态图| 男男多肉文| 小泽玛利亚一区二区三区免费| 天仙TV国产丝袜嫩模福利| 女人被男人躁到呻吟的| 美女扒开胸罩给男生摸| 男人舔女人的阴部黄色骚虎视频| 国产天堂在线一区二区三区| 51国精产品自偷自偷综合| 风流小子征服群妇记| 耽美肉文小说| 亚亚洲乱码一二三四区| 香港精点一极毛片免费看| 宝贝含着做到哭h男男|