前言
add_header 是 headers 模塊中定義的一個指令,顧名思義就是用來添加 http 響應頭的。但請注意他只是「添加」而已,并不是重寫。所以如果已經存在某個頭,再使用 add_header 就會出問題。而且在低版本的 nginx 中 add_header 還不支持在錯誤頁面中使用。
這是一個坑比較多的指令。它的處理階段比 location 處理晚,雖然可以寫在 location 中,但如果 rewrite 別的 location,那么上一個 location 中尚未處理的 add_header 就會丟失。比如:
location = /a { add_header a 1; rewrite / /b;}location = /b { add_header b 2; return 204;}
并沒有 a 1 這個頭吧?這就是一個坑!
另一個坑就是一開始說的重復的問題,比如我希望給一個內容設置 Content-Type,但是由于全局有設置一個 default_type,所以就重復了。
default_type 'text/plain';location = /a { add_header Content-Type application/json; return 200 '"OK"';}
解決的辦法當然有很多比如對這個 location 將 default_type 置空,或者干脆不用 add_header,直接針對這個 location 修改 default_type。
最后一個大坑就是對錯誤頁面無法生效,這也是在文檔中有明確定義的。比如下面這個例子:
location = /a { add_header Content-Type application/json; return 404 '"Not Found"';}
我希望響應一個 JSON,然而由于狀態碼是 404,所以這里的 add_header 并不會生效。
雖然這個例子可以用 default_type 來解決問題,但如果是其它頭呢?比如 Access-Control-Allow-Origin 要怎么辦?那么除了使用 lua 或其它第三方模塊來解決之外就無解了。nginx 當然也意識到了這個問題,所以文檔中也說了在 1.7.5 版本之后支持一個叫 always 的參數。雖然 nginx 自己解決了這個問題,但基于 1.6.2 的 tengine 就要呵呵了。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答