rewite
在server塊下,會優先執行rewrite部分,然后才會去匹配location塊
server中的rewrite break和last沒什么區別,都會去匹配location,所以沒必要用last再發起新的請求,可以留空
location中的rewirte:
不寫last和break - 那么流程就是依次執行這些rewrite
1. rewrite break
url重寫后,直接使用當前資源,不再執行location里余下的語句,完成本次請求,地址欄url不變
2. rewrite last
url重寫后,馬上發起一個新的請求,再次進入server塊,重試location匹配,超過10次匹配不到報500錯誤,地址欄url不變
3. rewrite redirect
返回302臨時重定向,地址欄顯示重定向后的url,爬蟲不會更新url(因為是臨時)
4. rewrite permanent
返回301永久重定向, 地址欄顯示重定向后的url,爬蟲更新url
使用last會對server標簽重新發起請求
如果location中rewrite后是對靜態資源的請求,不需要再進行其他匹配,一般要使用break或不寫,直接使用當前location中的數據源,完成本次請求
如果location中rewrite后,還需要進行其他處理,如動態fastcgi請求(.PHP,.jsp)等,要用last繼續發起新的請求
(根的location使用last比較好, 因為如果有.php等fastcgi請求還要繼續處理)
使用alias指定源:必須使用last
if語句主要用來判斷一些在rewrite語句中無法直接匹配的條件,比如檢測文件存在與否,http header,cookie等
location匹配規則及優先級
- = 嚴格匹配這個查詢。如果找到,停止搜索。
- ^~ 匹配路徑的前綴,如果找到,停止搜索。
- ~ 為區分大小寫的正則匹配
- ~* 為不區分大小寫匹配
優先級: =, ^~, ~/~*, 無
break語句
放在server塊rewrite語句前面
如果是直接請求某個真實存在的文件,則用break語句停止rewrite檢查
if (-f $request_filename) { break; }
轉自:http://blog.csdn.net/zhanlanmg/article/details/49684803