一.nginx路徑匹配符號
= 表示精確匹配
^~ 表示uri以某個常規字符串開頭,大多情況下用來匹配url路徑,nginx不對url做編碼,因此請求為/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)。
~ 正則匹配(區分大小寫)
~* 正則匹配(不區分大小寫)
!~ 區分大小寫不匹配
!~* 不區分大小寫不匹配
/ 任何請求都會匹配
二.nginx符號優先級
首先匹配 =,其次匹配^~, 其次是按文件中順序的正則匹配,最后是交給 / 通用匹配。當有匹配成功時候,停止匹配,按當前匹配規則處理請求。(精准匹配>模糊匹配>通用匹配)
三.demo示例
location = / { # 精確匹配 / ,主機名后面不能帶任何字符串 [ 規則 A ] } location / { # 因為所有的地址都以 / 開頭,所以這條規則將匹配到所有請求 # 但是正則和最長字符串會優先匹配 [ 規則 B ] } location /documents/ { # 匹配任何以 /documents/ 開頭的地址,匹配符合以后,還要繼續往下搜索 # 只有后面的正則表達式沒有匹配到時,這一條才會采用這一條 [ 規則 C ] } location ~ /documents/Abc { # 匹配任何以 /documents/ 開頭的地址,匹配符合以后,還要繼續往下搜索 # 只有后面的正則表達式沒有匹配到時,這一條才會采用這一條 [ 規則 D ] } location ^~ /images/ { # 匹配任何以 /images/ 開頭的地址,匹配符合以后,停止往下搜索正則,采用這一條。 [ 規則 E ] } location ~* \.(gif|jpg|jpeg)$ { # 匹配所有以 gif,jpg或jpeg 結尾的請求 # 然而,所有請求 /images/ 下的圖片會被 [規則 E] 處理,因為 ^~ 優先級更高 [ 規則 F ] } location /images/ { # 字符匹配到 /images/,繼續往下,會發現 ^~ 存在 [ 規則 G ] } location /images/abc { # 最長字符匹配到 /images/abc,繼續往下,會發現 ^~ 存在 [ 規則 H ] } location ~ /images/abc/ { # 只有去掉 [規則 E] 才有效:先最長匹配 [規則 H] 開頭的地址,繼續往下搜索,匹配到這一條正則,采用 [ 規則 I ] }
四.其他實際應用示例
1.微信授權文件通用匹配規則(匹配MP_verify_****.txt文件,中間任意字符,並在/usr/share/nginx/file目錄中尋找對應文件)
# 微信授權文件通用匹配規則 location ~(MP_verify_)*\.(txt)$ { root /usr/share/nginx/file; }
2.匹配/static開頭路徑,並在/data/product/static尋找對應文件
# 靜態文件工程配置 location ^~ /static/ { root /data/product/static; index index.html index.htm; }
3.靜態文件匹配
# 靜態文件配置 location ~* \.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ { root /data/product/static/; }
4.mp4視頻播放匹配
location ~* \.mp4$ { #這里配置視頻
root D:\sp\djz; #這里是你的視頻的存放目錄
}
5.proxy_pass進行服務器的項目的代理
location /stwx { proxy_pass http://stwx; include proxy.conf; }