語法規(guī)則
location [=|~|~*|^~] /uri/ { … }
模式 | 含義 |
---|---|
location = /uri | = 表示精確匹配,只有完全匹配上才能生效 |
location ^~ /uri | ^~ 開頭對URL路徑進行前綴匹配,并且在正則之前。 |
location ~ pattern | 開頭表示區(qū)分大小寫的正則匹配 |
location ~* pattern | 開頭表示不區(qū)分大小寫的正則匹配 |
location /uri | 不帶任何修飾符,也表示前綴匹配,但是在正則匹配之后 |
location / | 通用匹配,任何未匹配到其它location的請求都會匹配到,相當于switch中的default |
前綴匹配時,Nginx 不對 url 做編碼,因此請求為 /static/20%/aa ,可以被規(guī)則 ^~ /static/ /aa 匹配到(注意是空格)
多個 location 配置的情況下匹配順序為(參考資料而來,還未實際驗證,試試就知道了,不必拘泥,僅供參考):
注意:前綴匹配,如果有包含關(guān)系時,按最大匹配原則進行匹配。比如在前綴匹配: location /dir01
與 location /dir01/dir02
,如有請求 http://localhost/dir01/dir02/file
將最終匹配到 location /dir01/dir02
例子,有如下匹配規(guī)則:
location = / { echo "規(guī)則A";}location = /login { echo "規(guī)則B";}location^~ /static/ { echo "規(guī)則C";}location^~ /static/files { echo "規(guī)則X";}location ~ /.(gif|jpg|png|js|css)$ { echo "規(guī)則D";}location ~* /.png$ { echo "規(guī)則E";}location /img { echo "規(guī)則Y";}location / { echo "規(guī)則F";}
那么產(chǎn)生的效果如下:
/
,比如 http://localhost/
將匹配 規(guī)則Ahttp://localhost/login
將匹配 規(guī)則B , http://localhost/register
則匹配 規(guī)則F http://localhost/static/a.html
將匹配 規(guī)則Chttp://localhost/static/files/a.exe
將匹配 規(guī)則X ,雖然 規(guī)則C 也能匹配到,但因為最大匹配原則,最終選中了 規(guī)則X 。你可以測試下,去掉規(guī)則 X ,則當前 URL 會匹配上 規(guī)則C 。http://localhost/a.gif
, http://localhost/b.jpg
將匹配 規(guī)則D 和 規(guī)則 E ,但是 規(guī)則 D 順序優(yōu)先, 規(guī)則 E 不起作用,而 http://localhost/static/c.png
則優(yōu)先匹配到 規(guī)則 C http://localhost/a.PNG
則匹配 規(guī)則 E ,而不會匹配 規(guī)則 D ,因為 規(guī)則 E 不區(qū)分大小寫。 http://localhost/img/a.gif
會匹配上 規(guī)則D ,雖然 規(guī)則Y 也可以匹配上,但是因為正則匹配優(yōu)先,而忽略了 規(guī)則Y 。http://localhost/img/a.tiff
會匹配上 規(guī)則Y 。 訪問 http://localhost/category/id/1111
則最終匹配到規(guī)則 F ,因為以上規(guī)則都不匹配,這個時候應該是 Nginx 轉(zhuǎn)發(fā)請求給后端應用服務器,比如 FastCGI(php),tomcat(jsp),Nginx 作為反向代理服務器存在。
所以實際使用中,筆者覺得至少有三個匹配規(guī)則定義,如下:
# 直接匹配網(wǎng)站根,通過域名訪問網(wǎng)站首頁比較頻繁,使用這個會加速處理,官網(wǎng)如是說。# 這里是直接轉(zhuǎn)發(fā)給后端應用服務器了,也可以是一個靜態(tài)首頁# 第一個必選規(guī)則location = / { proxy_pass http://tomcat:8080/index}# 第二個必選規(guī)則是處理靜態(tài)文件請求,這是 nginx 作為 http 服務器的強項# 有兩種配置模式,目錄匹配或后綴匹配,任選其一或搭配使用location ^~ /static/ { root /webroot/static/;}location ~* /.(gif|jpg|jpeg|png|css|js|ico)$ { root /webroot/res/;}# 第三個規(guī)則就是通用規(guī)則,用來轉(zhuǎn)發(fā)動態(tài)請求到后端應用服務器# 非靜態(tài)文件請求就默認是動態(tài)請求,自己根據(jù)實際把握# 畢竟目前的一些框架的流行,帶.php、.jsp后綴的情況很少了location / { proxy_pass http://tomcat:8080/}
rewrite 語法
1、下面是可以用來判斷的表達式:
2、下面是可以用作判斷的全局變量
例:
http://localhost:88/test1/test2/test.php?k=v$host:localhost$server_port:88$request_uri:/test1/test2/test.php?k=v$document_uri:/test1/test2/test.php$document_root:D:/nginx/html$request_filename:D:/nginx/html/test1/test2/test.php
redirect 語法
server { listen 80; server_name start.igrow.cn; index index.html index.php; root html; if ($http_host !~ "^star/.igrow/.cn$") { rewrite^(.*) http://star.igrow.cn$1 redirect; }}
防盜鏈
location ~* /.(gif|jpg|swf)$ { valid_referers none blocked start.igrow.cn sta.igrow.cn; if ($invalid_referer) { rewrite^/ http://$host/logo.png; }}
根據(jù)文件類型設(shè)置過期時間
location ~* /.(js|css|jpg|jpeg|gif|png|swf)$ { if (-f $request_filename) { expires 1h; break; }}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點
疑難解答