亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

通過(guò)Nginx代理轉(zhuǎn)發(fā)配置實(shí)現(xiàn)跨域的方法(API代理轉(zhuǎn)發(fā))

 更新時(shí)間:2019年11月17日 10:09:28   作者:Thinktxt  
這篇文章主要給大家介紹了關(guān)于如何通過(guò)Nginx代理轉(zhuǎn)發(fā)配置實(shí)現(xiàn)跨域(API代理轉(zhuǎn)發(fā))的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Nginx具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

在WEB開(kāi)發(fā)中,我們經(jīng)常涉及到跨域的請(qǐng)求,解決跨域問(wèn)題的方式有很多,比如有window.name、iframe、JSONP、CORS等等,就不詳細(xì)展開(kāi)了,涉及到 協(xié)議、端口 不一樣的跨域請(qǐng)求方式是采用代理,這里我們重點(diǎn)聊聊Nginx代理的方式。

場(chǎng)景
本地啟動(dòng)了一個(gè)前后端分離的WEB應(yīng)用,端口為:3000,可以通過(guò)http://127.0.0.1:3000訪問(wèn)前端頁(yè)面,頁(yè)面中有些Ajax請(qǐng)求的地址為http://127.0.0.1:3000/api/getList,一般情況下肯定是404或者請(qǐng)求失敗,如下圖:

這種后端服務(wù)的接口存放在于其他的服務(wù)器中,比如在公司內(nèi)網(wǎng)可以通過(guò)http://172.30.1.123:8081/api/getList訪問(wèn)到測(cè)試環(huán)境中的服務(wù)接口。

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

Nginx代理配置參考

首先找到Nginx配置文件:

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

在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;
 }
}

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

監(jiān)聽(tīng)80端口(Nginx默認(rèn)啟動(dòng)了80端口),將http://127.0.0.1的所有請(qǐng)求服務(wù)轉(zhuǎn)發(fā)到127.0.0.1端口為3000;
將http://127.0.0.1/api/或者h(yuǎn)ttp://127.0.0.1/api/getList請(qǐng)求轉(zhuǎn)發(fā)到http://172.30.1.123:8081

完成

經(jīng)過(guò)上面的配置我們可以直接通過(guò)http://127.0.0.1訪問(wèn)我們的WEB應(yīng)用(如果采用IP訪問(wèn)),而相關(guān)的API請(qǐng)求也會(huì)根據(jù)我們的Nginx配置進(jìn)行相應(yīng)的請(qǐng)求,瀏覽器端看到的/api/getList請(qǐng)求的是127.0.0.1端口為80的端口,但是實(shí)際上這個(gè)請(qǐng)求已經(jīng)被我們的Nginx轉(zhuǎn)發(fā)指向http://172.30.1.123:8081/api/getList

優(yōu)化:

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

但是,當(dāng)我們需要獲取真實(shí)IP的業(yè)務(wù)時(shí),還需要添加關(guān)于真實(shí)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這個(gè)配置是改變HTTP的請(qǐng)求頭,而Host是請(qǐng)求的主機(jī)名,X-Real-IP是請(qǐng)求的真實(shí)IP,X-Forwarded-For表示請(qǐng)求是由誰(shuí)發(fā)起的。

因?yàn)槲覀兊腘ginx在這里屬于代理服務(wù)器,通過(guò)proxy_set_header配置這些信息目的是讓服務(wù)端獲取到真實(shí)的請(qǐng)求頭。

友情提示:

Nginx每一條配置語(yǔ)句后面都必須要加分好; 否則會(huì)報(bào)配置錯(cuò)誤,自己還一臉懵逼。

拓展

綁定host

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

host修改參考:

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

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

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

修改host后你可以直接通過(guò)你的域名訪問(wèn),如:http://www.domain.com

關(guān)于location

上面的配置你可能會(huì)對(duì)localtion后面的配置感到疑惑,關(guān)于localtion后面的常用的需求有:

localtion / {
 # 所有請(qǐng)求都匹配以下規(guī)則
 # 因?yàn)樗械牡刂范家?/ 開(kāi)頭,所以這條規(guī)則將匹配到所有請(qǐng)求
 # xxx 你的配置寫(xiě)在這里
}

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

localtion /api {
 # 匹配任何 /api 開(kāi)頭的URL,包括 /api 后面任意的, 比如 /api/getList
 # 匹配符合以后,還要繼續(xù)往下搜索
 # 只有后面的正則表達(dá)式?jīng)]有匹配到時(shí),這一條才會(huì)采用這一條
}

localtion ~ /api/abc {
 # 匹配任何 /api/abc 開(kāi)頭的URL,包括 /api/abc 后面任意的, 比如 /api/abc/getList
 # 匹配符合以后,還要繼續(xù)往下搜索
 # 只有后面的正則表達(dá)式?jīng)]有匹配到時(shí),這一條才會(huì)采用這一條
}
以/ 通用匹配, 如果沒(méi)有其它匹配,任何請(qǐng)求都會(huì)匹配到
=開(kāi)頭表示精確匹配
如 A 中只匹配根目錄結(jié)尾的請(qǐng)求,后面不能帶任何字符串。
^~ 開(kāi)頭表示uri以某個(gè)常規(guī)字符串開(kāi)頭,不是正則匹配
~ 開(kāi)頭表示區(qū)分大小寫(xiě)的正則匹配;
~* 開(kāi)頭表示不區(qū)分大小寫(xiě)的正則匹配

更多詳細(xì)localtion的正則匹配規(guī)則可參考:nginx配置location總結(jié)及rewrite規(guī)則寫(xiě)法

后記

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

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Linux下Nginx負(fù)載均衡多個(gè)tomcat配置的方法步驟

    Linux下Nginx負(fù)載均衡多個(gè)tomcat配置的方法步驟

    這篇文章主要介紹了Linux下Nginx負(fù)載均衡多個(gè)tomcat配置的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • 使用nginx配置基于域名的虛擬主機(jī)實(shí)現(xiàn)​

    使用nginx配置基于域名的虛擬主機(jī)實(shí)現(xiàn)​

    這篇文章主要介紹了nginx配置基于域名的虛擬主機(jī)實(shí)現(xiàn)​,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Nginx配置多臺(tái)機(jī)器實(shí)現(xiàn)負(fù)載均衡的教程詳解

    Nginx配置多臺(tái)機(jī)器實(shí)現(xiàn)負(fù)載均衡的教程詳解

    這篇文章主要為大家詳細(xì)介紹了Nginx配置多臺(tái)機(jī)器實(shí)現(xiàn)負(fù)載均衡的相關(guān)教程,文中的示例代碼簡(jiǎn)潔易懂,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • Nginx 操作響應(yīng)頭信息的實(shí)現(xiàn)

    Nginx 操作響應(yīng)頭信息的實(shí)現(xiàn)

    這篇文章主要介紹了Nginx 操作響應(yīng)頭信息的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • nginx配置keepalive長(zhǎng)連接的實(shí)現(xiàn)方法

    nginx配置keepalive長(zhǎng)連接的實(shí)現(xiàn)方法

    長(zhǎng)連接允許客戶端在同一個(gè)TCP連接上發(fā)送多個(gè)請(qǐng)求,以減少連接握手的開(kāi)銷(xiāo),提高網(wǎng)站性能,本文主要介紹了nginx配置keepalive長(zhǎng)連接的實(shí)現(xiàn)方法,感興趣的可以了解一下
    2023-08-08
  • Nginx中的文件下載服務(wù)器詳解

    Nginx中的文件下載服務(wù)器詳解

    利 用Nginx的諸多內(nèi)置指令可實(shí)現(xiàn)自動(dòng)生成下載文件列表 頁(yè)、限制下載帶寬等功能,這篇文章給大家介紹Nginx中的文件下載服務(wù)器功能,感興趣的朋友一起看看吧
    2024-06-06
  • nginx反向代理二級(jí)域名綁定方法及注意事項(xiàng)

    nginx反向代理二級(jí)域名綁定方法及注意事項(xiàng)

    本文介紹了利用nginx實(shí)現(xiàn)多域名和多站點(diǎn)的綁定的方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2018-04-04
  • nginx如何限制訪問(wèn)某些url

    nginx如何限制訪問(wèn)某些url

    這篇文章主要關(guān)于介紹了nginx如何限制訪問(wèn)某些url的相關(guān)資料,nginx是非常出色web服務(wù)器,對(duì)于靜態(tài)文件的處理非常高效,同時(shí)它的代理轉(zhuǎn)發(fā)功能和其它后臺(tái)服務(wù)器搭配起來(lái)也非常的簡(jiǎn)單高效,需要的朋友可以參考下
    2023-08-08
  • 制作nginx的RPM包教程

    制作nginx的RPM包教程

    這篇文章主要介紹了制作nginx的RPM包的方法,需要的朋友可以參考下
    2014-07-07
  • nginx部署前端項(xiàng)目后刷新瀏覽器報(bào)錯(cuò)404問(wèn)題解決

    nginx部署前端項(xiàng)目后刷新瀏覽器報(bào)錯(cuò)404問(wèn)題解決

    現(xiàn)在前端頁(yè)面部署正常訪問(wèn),但是刷新的時(shí)候出現(xiàn)了404,所以下面給整理下,這篇文章主要給大家介紹了關(guān)于nginx部署前端項(xiàng)目后刷新瀏覽器報(bào)錯(cuò)404問(wèn)題的解決辦法,需要的朋友可以參考下
    2023-11-11

最新評(píng)論