好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 為何要小心Nginx的add_header指令詳解

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

熱門標簽:百應電銷機器人靠譜嗎 coreldraw地圖標注 遼寧電銷平臺外呼系統軟件 營銷電銷機器人招商 申請400電話號碼多少錢 物超所值的400電話申請 如何在各種地圖標注自己的地址 信陽銷售外呼系統招商 菏澤crm外呼系統價格

前言

大家都知道,nginx配置文件通過使用add_header指令來設置response header。

昨天無聊用curl查看一個站點的信息,發現返回的頭部與想象中的不一樣:

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
...

主站點在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";

但響應頭部沒有這些header。除了常規的header,僅出現了一個配置配置在location中的header X-Cache。

第一印象是CDN過濾了這些header?于是找Cloudflare的文檔,沒發現會對這些進行處理。轉念一想,CDN過濾這些干啥啊?吃飽了撐的啊?他們又不搞zheng審那一套!

問題轉移到Nginx的配置上。打開Google搜索”nginx location add_header”,果然發現不少槽點。點開官網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.

注意重點在“These directives are inherited from the previous level if and only if there are no add_header directives defined on the current level. ”。即:僅當當前層級中沒有add_header指令才會繼承父級設置。所以我的疑問就清晰了:location中有add_header,nginx.conf中的配置被丟棄了。

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

但問題還不僅于此。如果location中rewrite到另一個location,最后結果僅出現第二個的header。例如:

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

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

不管請求/foo1還是/foo2,最終header只有foo2:

盡管說得通這是正常行為,但總讓人感覺有點勉強和不舒坦:server丟掉http配置,location丟掉server配置也就算了,但兩個location在同一層級啊!

不能繼承父級配置,又不想在當前塊重復指令,解決辦法可以用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 的坑

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

標簽:玉樹 內江 湖北 泰安 江門 江西 廈門 瀘州

巨人網絡通訊聲明:本文標題《為何要小心Nginx的add_header指令詳解》,本文關鍵詞  為何,要,小心,Nginx,的,add,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《為何要小心Nginx的add_header指令詳解》相關的同類信息!
  • 本頁收集關于為何要小心Nginx的add_header指令詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 《熟妇的荡欲》未删减版在线观看| 78成人网| 天天做天天爱天天一爽一毛片| 精品国产三级a| 爽?躁多水?快?深小| jizz国产在线播放| 女子被按到床强行糟蹋视频| 亚洲91网站| 亚洲国产品综合人成综合网站| 一级毛片在线看在线播放| 中文字幕99在线精品视频免费看| 国产黄三级三级三级三级一区二区| 国产欧美日韩综合| 色婷婷综合和线在线| chinese情侣自拍啪hd| 黄色免费网站下载| 日本公妇乱偷中文字幕| 污视频在线看| 王爷低喘闷哼顶弄H| 青青青青久久精品国产一百度| 成 人 黄 色 片 在线播放| 国模一区二区三区视频一| 久久婷婷色区一区二区三古装| 熟女???码免费播放www| 爱爱动图好硬好湿好爽| 美女的秘?让男人桶到爽| 亚洲国产在人线播放午夜| 大尺度做爰呻吟小说疯狂进出| 亚洲欧美国产人成在线app| 五月丁香欧美综合亚洲AV| 日韩天天干| 免费观看又污又黄的网站高| 男女边吃奶边做爽动态爽| 欧美色-情-伦-理一区二色戒| 日本一级特黄大片大全色就色| 亚洲性夜夜综合久久麻豆| 日韩精品电影一区亚洲| 91亚洲视频在线| 91精品久久久久久久久久小网站 | 扒开女同学的腿嗯啊的叫| 老井电影高清完整版在线播放|