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)文章
前端加載訪問速度優(yōu)化詳細(xì)指南(Nginx)
在前端開發(fā)中,優(yōu)化頁面加載速度成為了開發(fā)者的一項重要任務(wù),下面這篇文章主要給大家介紹了關(guān)于前端加載訪問速度優(yōu)化(Nginx)的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06
使用nginx緩存服務(wù)器上靜態(tài)文件的設(shè)置方法
這篇文章主要介紹了使用nginx緩存服務(wù)器上的靜態(tài)文件,文中給大家提到了nginx緩存的優(yōu)點及設(shè)置方法,通過實例相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-05-05
Nginx訪問FTP服務(wù)器文件的時效性/安全校驗的方法
nginx的實現(xiàn)方式在校驗失敗的時候頁面返回error image,跳轉(zhuǎn)的是420 error_page,成功的時候會訪問FTP文件服務(wù)器的路徑,反正圖片到頁面展示,這篇文章主要介紹了Nginx訪問FTP服務(wù)器文件的時效性/安全校驗,需要的朋友可以參考下2023-12-12

