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
。
例如:跨域訪問(詳細參見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緩存服務(wù)器上靜態(tài)文件的設(shè)置方法
這篇文章主要介紹了使用nginx緩存服務(wù)器上的靜態(tài)文件,文中給大家提到了nginx緩存的優(yōu)點及設(shè)置方法,通過實例相結(jié)合的形式給大家介紹的非常詳細,需要的朋友可以參考下2018-05-05Nginx訪問FTP服務(wù)器文件的時效性/安全校驗的方法
nginx的實現(xiàn)方式在校驗失敗的時候頁面返回error image,跳轉(zhuǎn)的是420 error_page,成功的時候會訪問FTP文件服務(wù)器的路徑,反正圖片到頁面展示,這篇文章主要介紹了Nginx訪問FTP服務(wù)器文件的時效性/安全校驗,需要的朋友可以參考下2023-12-12