nginx的配置轉(zhuǎn)發(fā)到其他網(wǎng)站詳解
需求
有這樣一個需求:項目中跳轉(zhuǎn)到某個地址,但這個地址不想暴露給用戶。
因此我們想到要做一層代理,通過項目某個路徑直接用ngnix代理到這個地址。
查詢相關(guān)文檔后,發(fā)現(xiàn)方案如下:
用return 302
location /myBaidu {
return 302 http://baidu.com;
}
- 這種方案會直接跳轉(zhuǎn)到baidu,并且會改變域名,相當(dāng)于直接location.href = 'baidu.com' ,顯然并不適合我們的需求。
- 我們想要的效果是代理到百度,但是瀏覽器的url框內(nèi)還是/sparkMonitor,那么就用proxy_pass
用proxy_pass
假設(shè)我們的網(wǎng)站域名為 http://myorigin.com/
location /myBaidu {
proxy_pass http://www.baidu.com/;
}
這樣配置后就可以由http://myorigin.com/myBaidu直接訪問到百度頁面,如下圖

關(guān)于proxy_pass使用的語法,與/有關(guān)
當(dāng)路徑加上/:相對路徑,此時相當(dāng)于代理到http://www.baidu.com/
location /myBaidu {
proxy_pass http://www.baidu.com/;
}
如果訪問http://myorigin.com/myBaidu/abc就相當(dāng)于訪問http://www.baidu.com/abc
當(dāng)路徑不加/:絕對路徑,,此時相當(dāng)于代理到http://www.baidu.com/myBaidu
location /myBaidu {
proxy_pass http://www.baidu.com;
}
如果訪問http://myorigin.com/myBaidu/abc就相當(dāng)于訪問http://www.baidu.com/myBaidu/abc
當(dāng)路徑加上/xxx/
location /myBaidu {
proxy_pass http://www.baidu.com/xxx/;
}
- 如果訪問http://myorigin.com/myBaidu/abc就相當(dāng)于訪問http://www.baidu.com/xxx/abc
當(dāng)路徑加上/xxx
location /myBaidu {
proxy_pass http://www.baidu.com/xxx;
}
- 如果訪問http://myorigin.com/myBaidu/abc就相當(dāng)于訪問http://www.baidu.com/xxxabc
其他問題
- 用proxy_pass的方案反向代理到百度頁面,沒有任何問題。
- 但是我們項目中是要求跳轉(zhuǎn)到某個內(nèi)網(wǎng)域名,而且此域名和http://myorigin.com/并沒有互通,因此配置代理時,需要配置成ip地址,然后代理成功跳轉(zhuǎn)
但此時打開代理的頁面顯示沒有樣式,查看控制臺發(fā)現(xiàn)了報錯如下:

點進(jìn)去查看錯誤如下圖

- 由此,問題就很明顯了,代理的網(wǎng)站用了根目錄絕對路徑去找到/static下的jquery文件,因此會直接在我們項目的域名下找http://myorigin.com/static文件,這樣是怎么也無法找到代理項目的/static文件,因此jquery找不到報錯,頁面樣式失效
- 而且不只是/static文件,可能還有其他文件也找不到,而且還有可能路徑與路由沖突,引發(fā)問題
- 因此,我們可以得出結(jié)論,前端項目的nginx的配置轉(zhuǎn)發(fā)到其他網(wǎng)站需要慎重,不是所有網(wǎng)站都可以走前端代理的,需要具體情況具體分析
以上就是nginx的配置轉(zhuǎn)發(fā)到其他網(wǎng)站詳解的詳細(xì)內(nèi)容,更多關(guān)于nginx配置轉(zhuǎn)發(fā)網(wǎng)站的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
使用nginx配置基于域名的虛擬主機(jī)實現(xiàn)
這篇文章主要介紹了nginx配置基于域名的虛擬主機(jī)實現(xiàn)​,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
利用Nginx反向代理功能解決WEB網(wǎng)站80端口被封的解決方法
大陸的網(wǎng)絡(luò)環(huán)境,都在天朝神獸的制度下讓我等小P民悲劇一片;動不動就拔網(wǎng)線、封機(jī)房;現(xiàn)在更厲害的一招,從網(wǎng)關(guān)封殺你的80端口,一旦被封,網(wǎng)站域名就無法訪問2012-08-08
ConfigMap掛載與Subpath在Nginx容器中的應(yīng)用小結(jié)
configmap可以通過ENV環(huán)境變量和文件兩種方式掛載到容器中,修改configmap后容器中對應(yīng)的ENV環(huán)境變量不會更新,將配置文件nginx.conf以configmap文件的方式掛載到容器中,本文介紹ConfigMap掛載與Subpath在Nginx容器中的應(yīng)用小結(jié),感興趣的朋友一起看看吧2024-03-03

