location模塊的匹配介紹
1.”=”前綴指令匹配,如果匹配成功,則停止其他匹配。
2.普通字符串指令匹配,順序是從長到短,匹配成功的location如果使用^~,則停止其他匹配(正則匹配)。
3.正則表達式指令匹配,按照配置文件里的順序,成功就停止其他匹配。
4.如果第三步中有匹配成功,則使用該結果,否則使用第二步結果。
注意點
1.匹配的順序是先匹配普通字符串,然后再匹配正則表達式。另外普通字符串匹配順序是根據配置中字符長度從長到短,也就是說使用普通字符串配置的location順序是無關緊要的,反正最后nginx會根據配置的長短來進行匹配,但是需要注意的是正則表達式按照配置文件里的順序測試。找到第一個匹配的正則表達式將停止搜索。
2.一般情況下,匹配成功了普通字符串location后還會進行正則表達式location匹配。有兩種方法改變這種行為,其一就是使用“=”前綴,這時執行的是嚴格匹配,并且匹配成功后立即停止其他匹配,同時處理這個請求;另外一種就是使用“^~”前綴,如果把這個前綴用于一個常規字符串那么告訴nginx 如果路徑匹配那么不測試正則表達式。
location?=?/uri
=開頭表示精確匹配,只有完全匹配上才能生效。
location?^~?/uri
^~ 開頭對url路徑進行前綴匹配,并且在正則之前。
location?~?pattern
~開頭表示區分大小寫的正則匹配。
location?~*?pattern
~*開頭表示不區分大小寫的正則匹配。
location?/uri
不帶任何修飾符,也表示前綴匹配,但是在正則匹配之后。
location?/
通用匹配,任何未匹配到其它location的請求都會匹配到,相當于switch中的default。
配置實例
server?{ ?listen??80; ?server_name?test.com; ?index?index.html?index.htm?index.php; ?charset?koi8-r; ?access_log?/var/log/nginx/host.access.log?main; ?#?域名+項目1名稱 ?location?^~?/a1/?{ ???alias?/usr/share/nginx/html/a1/public/; ?} ?#?域名+項目2名稱 ?location?^~?/a2/?{ ???alias?/usr/share/nginx/html/a2/public/; ?} ?error_page?404????/404.html; ?#?redirect?server?error?pages?to?the?static?page?/50x.html ? ?error_page?500?502?503?504?/50x.html; ?location?=?/50x.html?{ ??root?/usr/share/nginx/html/500.html; ?} ?#pass?the?php?scripts?to?fastcgi?server?listening?on?127.0.0.1:9000 ? ?location?~?.php$?{ ??root???html; ??fastcgi_pass?127.0.0.1:9000; ??fastcgi_index?index.php; ??fastcgi_param?script_filename?/scripts$fastcgi_script_name; ??include??fastcgi_params; ?} ? ?location?~?/.ht?{ ??deny?all; ?} }
效果預覽
1.訪問a1項目
2.訪問a2項目
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END