您好,登錄后才能下訂單哦!
前言
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 就要呵呵了。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。