濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 為何要小心Nginx的add_header指令詳解

為何要小心Nginx的add_header指令詳解

熱門(mén)標(biāo)簽:百應(yīng)電銷(xiāo)機(jī)器人靠譜嗎 coreldraw地圖標(biāo)注 遼寧電銷(xiāo)平臺(tái)外呼系統(tǒng)軟件 營(yíng)銷(xiāo)電銷(xiāo)機(jī)器人招商 申請(qǐng)400電話號(hào)碼多少錢(qián) 物超所值的400電話申請(qǐng) 如何在各種地圖標(biāo)注自己的地址 信陽(yáng)銷(xiāo)售外呼系統(tǒng)招商 菏澤crm外呼系統(tǒng)價(jià)格

前言

大家都知道,nginx配置文件通過(guò)使用add_header指令來(lái)設(shè)置response header。

昨天無(wú)聊用curl查看一個(gè)站點(diǎn)的信息,發(fā)現(xiàn)返回的頭部與想象中的不一樣:

HTTP/2 200
date: Thu, 07 Feb 2019 04:26:38 GMT
content-type: text/html; charset=UTF-8
vary: Accept-Encoding, Cookie
cache-control: max-age=3, must-revalidate
last-modified: Thu, 07 Feb 2019 03:54:54 GMT
X-Cache: Miss
server: cloudflare
...

主站點(diǎn)在nginx.conf中配置了HSTS等header:

add_header Strict-Transport-Security "max-age=63072000; preload";
add_header X-Frame-Options SAMEORIGIN;
add_header X-Content-Type-Options nosniff;
add_header X-XSS-Protection "1; mode=block";

但響應(yīng)頭部沒(méi)有這些header。除了常規(guī)的header,僅出現(xiàn)了一個(gè)配置配置在location中的header X-Cache。

第一印象是CDN過(guò)濾了這些header?于是找Cloudflare的文檔,沒(méi)發(fā)現(xiàn)會(huì)對(duì)這些進(jìn)行處理。轉(zhuǎn)念一想,CDN過(guò)濾這些干啥?。砍燥柫藫蔚陌??他們又不搞zheng審那一套!

問(wèn)題轉(zhuǎn)移到Nginx的配置上。打開(kāi)Google搜索”nginx location add_header”,果然發(fā)現(xiàn)不少槽點(diǎn)。點(diǎn)開(kāi)官網(wǎng)add_header的文檔,有這樣的描述(其他信息已省略):

There could be several add_header directives. These directives are inherited from the previous level if and only if there are no add_header directives defined on the current level.

注意重點(diǎn)在“These directives are inherited from the previous level if and only if there are no add_header directives defined on the current level. ”。即:僅當(dāng)當(dāng)前層級(jí)中沒(méi)有add_header指令才會(huì)繼承父級(jí)設(shè)置。所以我的疑問(wèn)就清晰了:location中有add_header,nginx.conf中的配置被丟棄了。

這是Nginx的故意行為,說(shuō)不上是bug或坑。但深入體會(huì)這句話,會(huì)發(fā)現(xiàn)更有意思的現(xiàn)象:僅最近一處的add_header起作用。http、server和location三處均可配置add_header,但起作用的是最接近的配置,往上的配置都會(huì)失效。

但問(wèn)題還不僅于此。如果location中rewrite到另一個(gè)location,最后結(jié)果僅出現(xiàn)第二個(gè)的header。例如:

location /foo1 {
 add_header foo1 1;
 rewrite / /foo2;
}

location /foo2 {
 add_header foo2 1;
 return 200 "OK";
}

不管請(qǐng)求/foo1還是/foo2,最終header只有foo2:

盡管說(shuō)得通這是正常行為,但總讓人感覺(jué)有點(diǎn)勉強(qiáng)和不舒坦:server丟掉http配置,location丟掉server配置也就算了,但兩個(gè)location在同一層級(jí)啊!

不能繼承父級(jí)配置,又不想在當(dāng)前塊重復(fù)指令,解決辦法可以用include指令。

參考

  • Nginx Module ngx_http_headers_module
  • Nginx add_header configuration pitfall
  • Be very careful with your add_header in Nginx! You might make your site insecure
  • add_header directives in location overwriting add_header directives in server
  • nginx 配置之 add_header 的坑

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

標(biāo)簽:玉樹(shù) 內(nèi)江 湖北 泰安 江門(mén) 江西 廈門(mén) 瀘州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《為何要小心Nginx的add_header指令詳解》,本文關(guān)鍵詞  為何,要,小心,Nginx,的,add,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《為何要小心Nginx的add_header指令詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于為何要小心Nginx的add_header指令詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    二连浩特市| 茶陵县| 花垣县| 吐鲁番市| 泗阳县| 鹤壁市| 广东省| 神农架林区| 城固县| 宜宾县| 德令哈市| 探索| 夹江县| 和平县| 扬中市| 梅河口市| 历史| 东莞市| 清原| 高密市| 南投市| 辰溪县| 盐池县| 普兰店市| 河津市| 平舆县| 兴安县| 阿勒泰市| 长兴县| 六安市| 大悟县| 江源县| 罗源县| 苏州市| 闵行区| 二连浩特市| 如皋市| 和硕县| 贵州省| 三台县| 本溪|