詳解 nginx location ~ .*\.(js|css)?$ 什麼意思?

語法規則: location [=|~|~*|^~] /uri/ { … }

= 開頭表示精確匹配php

^~ 開頭表示uri以某個常規字符串開頭,理解爲匹配 url路徑便可。nginx不對url作編碼,所以請求爲/static/20%/aa,能夠被規則^~ /static/ /aa匹配到(注意是空格)。css

~ 開頭表示區分大小寫的正則匹配html

~*  開頭表示不區分大小寫的正則匹配linux

!~和!~*分別爲區分大小寫不匹配及不區分大小寫不匹配 的正則nginx

/ 通用匹配,任何請求都會匹配到。web

多個location配置的狀況下匹配順序爲(參考資料而來,還未實際驗證,試試就知道了,沒必要拘泥,僅供參考):後端

首先匹配 =,其次匹配^~, 其次是按文件中順序的正則匹配,最後是交給 / 通用匹配。當有匹配成功時候,中止匹配,按當前匹配規則處理請求。tomcat

例子,有以下匹配規則:服務器

1cookie

location = / {精確匹配,必須是127.0.0.1/

#規則A

}

location = /login {精確匹配,必須是127.0.0.1/login

#規則B

}

location ^~ /static/ {非精確匹配,而且不區分大小寫,好比127.0.0.1/static/js.

#規則C

}

location ~ \.(gif|jpg|png|js|css)$ {區分大小寫,以gif,jpg,js結尾

#規則D

}

location ~* \.png$ {不區分大小寫,匹配.png結尾的

#規則E

}

location !~ \.xhtml$ {區分大小寫,匹配不已.xhtml結尾的

#規則F

}

location !~* \.xhtml$ {

#規則G

}

location / {什麼均可以

#規則H

}

那麼產生的效果以下:

訪問根目錄/, 好比http://localhost/ 將匹配規則A

訪問 http://localhost/login 將匹配規則B,http://localhost/register 則匹配規則H

訪問 http://localhost/static/a.html 將匹配規則C

訪問 http://localhost/a.gif, http://localhost/b.jpg 將匹配規則D和規則E,可是規則D順序優先,規則E不起做用, 而 http://localhost/static/c.png 則優先匹配到 規則C

訪問 http://localhost/a.PNG 則匹配規則E, 而不會匹配規則D,由於規則E不區分大小寫。

訪問 http://localhost/a.xhtml 不會匹配規則F和規則G,http://localhost/a.XHTML不會匹配規則G,由於不區分大小寫。規則F,規則G屬於排除法,符合匹配規則可是不會匹配到,因此想一想看實際應用中哪裏會用到。

訪問 http://localhost/category/id/1111 則最終匹配到規則H,由於以上規則都不匹配,這個時候應該是nginx轉發請求給後端應用服務器,好比FastCGI(php),tomcat(jsp),nginx做爲方向代理服務器存在。

因此實際使用中,我的以爲至少有三個匹配規則定義,以下:

#這裏是直接轉發給後端應用服務器了,也能夠是一個靜態首頁

# 第一個必選規則

location = / {

proxy_pass http://tomcat:8080/index

}

# 第二個必選規則是處理靜態文件請求,這是nginx做爲http服務器的強項

# 有兩種配置模式,目錄匹配或後綴匹配,任選其一或搭配使用

location ^~ /static/ {

root /webroot/static/;

}

location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {

root /webroot/res/;

}

#第三個規則就是通用規則,用來轉發動態請求到後端應用服務器

#非靜態文件請求就默認是動態請求,本身根據實際把握

#畢竟目前的一些框架的流行,帶.php,.jsp後綴的狀況不多了

location / {

proxy_pass http://tomcat:8080/

}

#直接匹配網站根,經過域名訪問網站首頁比較頻繁,使用這個會加速處理,官網如是說。

#這裏是直接轉發給後端應用服務器了,也能夠是一個靜態首頁

# 第一個必選規則

location = / {

proxy_pass http://tomcat:8080/index

}

# 第二個必選規則是處理靜態文件請求,這是nginx做爲http服務器的強項

# 有兩種配置模式,目錄匹配或後綴匹配,任選其一或搭配使用

location ^~ /static/ {

root /webroot/static/;

}

location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {

root /webroot/res/;

}

#第三個規則就是通用規則,用來轉發動態請求到後端應用服務器

#非靜態文件請求就默認是動態請求,本身根據實際把握

#畢竟目前的一些框架的流行,帶.php,.jsp後綴的狀況不多了

location / {

proxy_pass http://tomcat:8080/

}

未試驗過的其餘信息:

3、ReWrite語法 
last – 基本上都用這個Flag。 
break – 停止Rewirte,不在繼續匹配 
redirect – 返回臨時重定向的HTTP狀態302 
permanent – 返回永久重定向的HTTP狀態301 
一、下面是能夠用來判斷的表達式: 
-f和!-f用來判斷是否存在文件 
-d和!-d用來判斷是否存在目錄 
-e和!-e用來判斷是否存在文件或目錄 
-x和!-x用來判斷文件是否可執行 
二、下面是能夠用做判斷的全局變量 
例:http://localhost:88/test1/test2/test.php 
$host:localhost 
$server_port:88 
$request_uri:http://localhost:88/test1/test2/test.php 
$document_uri:/test1/test2/test.php 
$document_root:D:\nginx/html 
$request_filename:D:\nginx/html/test1/test2/test.php 
4、Redirect語法 
server { 
listen 80; 
server_name start.igrow.cn; 
index index.html index.php; 
root html; 
if ($http_host !~ 「^star\.igrow\.cn$&quot { 
rewrite ^(.*) http://star.igrow.cn$1 redirect; 


5、防盜鏈location ~* \.(gif|jpg|swf)$ { 
valid_referers none blocked start.igrow.cn sta.igrow.cn; 
if ($invalid_referer) { 
rewrite ^/ http://$host/logo.png; 


6、根據文件類型設置過時時間 
location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ { 
if (-f $request_filename) { 
expires 1h; 
break; 


7、禁止訪問某個目錄 
location ~* \.(txt|doc)${ 
root /data/www/wwwroot/linuxtone/test; 
deny all; 
}

++ 一些可用的全局變量 $args $content_length $content_type $document_root $document_uri $host $http_user_agent $http_cookie $limit_rate $request_body_file $request_method $remote_addr $remote_port $remote_user $request_filename $request_uri $query_string $scheme $server_protocol $server_addr $server_name $server_port $uri

相關文章
相關標籤/搜索