nginx location 規(guī)則

location匹配順序

  1. "="前綴指令匹配,如果匹配成功,則停止其他匹配
  2. 普通字符串指令匹配,順序是從長到短,匹配成功的location如果使用^~,則停止其他匹配(正則匹配)
  3. 正則表達式指令匹配,按照配置文件里的順序,成功就停止其他匹配
  4. 如果第三步中有匹配成功,則使用該結(jié)果,否則使用第二步結(jié)果

注意點

  1. 匹配的順序是先匹配普通字符串,然后再匹配正則表達式。另外普通字符串匹配順序是根據(jù)配置中字符長度從長到短,也就是說使用普通字符串配置的location順序是無關緊要的,反正最后nginx會根據(jù)配置的長短來進行匹配,但是需要注意的是正則表達式按照配置文件里的順序測試。找到第一個比配的正則表達式將停止搜索。

  2. 一般情況下,匹配成功了普通字符串location后還會進行正則表達式location匹配。有兩種方法改變這種行為,其一就是使用“=”前綴,這時執(zhí)行的是嚴格匹配,并且匹配成功后立即停止其他匹配,同時處理這個請求;另外一種就是使用“^~”前綴,如果把這個前綴用于一個常規(guī)字符串那么告訴nginx 如果路徑匹配那么不測試正則表達式。

匹配模式及順序

location = /uri    =開頭表示精確匹配,只有完全匹配上才能生效。

location ^~ /uri   ^~ 開頭對URL路徑進行前綴匹配,并且在正則之前。

location ~ pattern  ~開頭表示區(qū)分大小寫的正則匹配。

location ~* pattern  ~*開頭表示不區(qū)分大小寫的正則匹配。

location /uri     不帶任何修飾符,也表示前綴匹配,但是在正則匹配之后。

location /      通用匹配,任何未匹配到其它location的請求都會匹配到,相當于switch中的default。

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容