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; } }
效果預覽
#
以上是Nginx一個網域名稱如何存取多個項目的詳細內容。更多資訊請關注PHP中文網其他相關文章!