location匹配順序
"="字首指令匹配,如果匹配成功,則停止其他匹配
普通字串指令匹配,順序是從長到短,匹配成功的location如果使用^~,則停止其他匹配(正則匹配)
正規表示式指令匹配,按照配置檔案裡的順序,成功就停止其他匹配
如果第三步中有匹配成功,則使用該結果,否則使用第二步結果
注意點匹配的順序是先匹配普通字串,然後再匹配正規表示式。另外普通字串匹配順序是根據配置中字元長度從長到短,也就是說使用普通字串配置的location順序是無關緊要的,反正最後nginx會根據配置的長短來進行匹配,但是需要注意的是正規表示式按照配置檔案裡的順序測試。找到第乙個比配的正規表示式將停止搜尋。
一般情況下,匹配成功了普通字串location後還會進行正規表示式location匹配。有兩種方法改變這種行為,其一就是使用「=」字首,這時執行的是嚴格匹配,並且匹配成功後立即停止其他匹配,同時處理這個請求;另外一種就是使用「^~」字首,如果把這個字首用於乙個常規字串那麼告訴nginx 如果路徑匹配那麼不測試正規表示式。
匹配模式及順序
location = /uri =開頭表示精確匹配,只有完全匹配上才能生效。
location ^~ /uri ^~ 開頭對url路徑進行字首匹配,並且在正則之前。
location ~ pattern ~開頭表示區分大小寫的正則匹配。
location ~* pattern ~*開頭表示不區分大小寫的正則匹配。
location /uri 不帶任何修飾符,也表示字首匹配,但是在正則匹配之後。
location / 通用匹配,任何未匹配到其它location的請求都會匹配到,相當於switch中的default。
實驗案例
測試"^「和」",nginx配置如下。瀏覽器輸入http://localhost/helloworld/test,返回601。如將#1注釋,#2開啟,瀏覽器輸入http://localhost/helloworld/test,返回603。注:#1和#2不能同時開啟,如同時開啟,啟動nginx會報nginx: [emerg] duplicate location 「/helloworld」…,因為這兩個都是普通字串。
location ^~ /helloworld
#location /helloworld
location ~ /helloworld
測試普通字串的長短(普通字串的匹配與順序無關,與長短有關)。瀏覽器輸入http://localhost/helloworld/test/a.html,返回601。瀏覽器輸入http://localhost/helloworld/a.html,返回602。
location /helloworld/test/
location /helloworld/
測試正規表示式的順序(正則匹配與順序相關)。瀏覽器輸入http://localhost/helloworld/test/a.html,返回602;將#2和#3調換順序,瀏覽器輸入http://localhost/helloworld/test/a.html,返回603
location /helloworld/test/
location ~ /helloworld
location ~ /helloworld/test
nginx之location匹配順序
開頭表示精確匹配 開頭表示uri以某個常規字串開頭,不是正則匹配 開頭表示區分大小寫的正則匹配 開頭表示不區分大小寫的正則匹配 通用匹配,如果沒有其它匹配,任何請求都會匹配到優先順序 location location 完整路徑 location 路徑 location 從上向下正則順序,匹配在最後...
nginx的location匹配順序
總原則 先字首字串,再正規表示式。不管配置檔案中的location順序怎麼寫,在匹配時,都會先 將所有字首字串拎出來,放在第一位 然後再去找所有正規表示式,作為第二位。1 首先匹配字首字串。字首字串有以下幾種形式 舉例 a location data b location data c locati...
location匹配規則
匹配符 匹配規則 優先順序 精確匹配 1 以某個字串開頭 2 區分大小寫的正則匹配 3 不區分大小寫的正則匹配 4 通用匹配,任何請求都會匹配到 5 測試結果如下 建議是curl測試 1.請求 會被 location 匹配 2.請求 index.html 會被 location 匹配 3.請求 do...