Nginx指令add_header和proxy_set_header的區(qū)別及說明
Nginx指令add_header和proxy_set_header區(qū)別
如何理解反向代理?
Nginx是反向代理服務(wù)器,我們可以從下面的圖來理解為什么是反向代理。
以Nginx為中心,數(shù)據(jù)的流向是從Server到Nginx再到Client,注意我說的是數(shù)據(jù)(響應(yīng)數(shù)據(jù)),而不是請求。
我們都知道水流一定是從上游流到下游,所以給Server一個別稱上游服務(wù)器,當(dāng)然這個別稱并不是我定義的。

proxy_set_header和add_header的區(qū)別
區(qū)別:proxy_set_header是Nginx設(shè)置請求頭信息給上游服務(wù)器,add_header是Nginx設(shè)置響應(yīng)頭信息給瀏覽器。
proxy_set_header
假如Nginx請求上游服務(wù)器時,添加額外的請求頭,就需要使用proxy_set_header。
在Java中使用HttpServletRequest#getHeader(String name)來獲取請求頭的值,name是請求頭的名稱。
例如:
proxy_set_header X-Request-URI $scheme://$host/$uri;
String requestUrl = request.getHeader("X-Request-URI");
if (requestUrl == null) {
// 從Servlet服務(wù)器獲取客戶端請求地址
requestUrl = request.getRequestURL().toString();
}add_header
Nginx響應(yīng)數(shù)據(jù)時,要告訴瀏覽器一些頭信息,就要使用add_header。
例如:跨域訪問(詳細(xì)參見Nginx跨域訪問配置)
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Headers' 'X-Requested-With';
add_header 'Access-Control-Allow-Methods' 'GET,POST,OPTIONS'
# 由于跨域請求,瀏覽器會先發(fā)送一個OPTIONS的預(yù)檢請求,我們可以緩存第一次的預(yù)檢請求的失效時間
if ($request_method = 'OPTIONS') {
add_header 'Access-Control-Max-Age' 2592000;
add_header 'Content-Type' 'text/plain; charset=utf-8';
add_header 'Content-Length' 0;
return 204;
}總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
nginx反向代理之將80端口請求轉(zhuǎn)發(fā)到8080
這篇文章主要介紹了nginx反向代理之將80端口請求轉(zhuǎn)發(fā)到8080,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
修改Nginx源碼實現(xiàn)worker進程隔離實現(xiàn)詳解
這篇文章主要為大家介紹了修改Nginx源碼實現(xiàn)worker進程隔離實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
Nginx 502 Bad Gateway錯誤的原因分析及解決方案
這篇文章主要介紹了Nginx 502 Bad Gateway錯誤的原因分析及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-05-05
Nginx上傳文件出現(xiàn)“ 413 (499 502 404) Requ
HTTP 413 Request Entity Too Large錯誤常常出現(xiàn)在客戶端發(fā)送的請求體超過服務(wù)器允許的大小限制時,本文主要介紹了Nginx上傳文件出現(xiàn)“ 413 (499 502 404) Request Entity Too Large錯誤解決,感興趣的可以了解一下2024-07-07

