nginx路徑匹配規則及配置nginx靜態文件或者視頻文件的本地播放等


一.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;
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM