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

proxy_set_header和add_header的區(qū)別
區(qū)別:proxy_set_header是Nginx設置請求頭信息給上游服務器,add_header是Nginx設置響應頭信息給瀏覽器。
proxy_set_header
假如Nginx請求上游服務器時,添加額外的請求頭,就需要使用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服務器獲取客戶端請求地址
requestUrl = request.getRequestURL().toString();
}add_header
Nginx響應數(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的預檢請求,我們可以緩存第一次的預檢請求的失效時間
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;
}總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

