Rewrite跳轉場景

Rewrite跳轉場景

URL看起來更規範,合理
企業會將動態URL地址僞裝成靜態地址提供服務
網址換新域名後,讓舊的訪問跳轉到新的域名上
服務端某些業務調整

Rewrite跳轉實現

Rewrite跳轉場景

Rewrite實用場景

  • Nginx跳轉需求的實現方式
    使用rewrite進行匹配跳轉
    使用if匹配全局變量後跳轉
    使用location匹配再跳轉
  • rewrite放在server{},if{},location{}段中
  • 對域名或參數字符串
    使用if全局變量匹配
    使用proxy_pass反向代理

常用的正則表達式元字符

字符 說明
^ 匹配輸入字符串的起始位置
$ 匹配輸入字符串的結束位置
* 匹配前面的字符零次或多次
+ 匹配前面的字符一次或多次
匹配前面的字符零次或一次
. 匹配除\n之外的任何單個字符,使用諸如"[.\n]"之類的模式,可匹配包括"\n"在內的任意字符
\d 匹配純數字 [0-9]
{n} 重複多次
{n,} 重複n次或更多次
[c] 匹配單個字符c
[a-z] 匹配a-z小寫字母的任意一個
[a-zA-Z] 匹配a-z小寫字母或A-Z大寫字母的任意一個

Rewrite命令

語法:
rewrite <regex>            <replacement>             [flag];
            正則                  跳轉後的內容               rewrite支持的flag標記

flag標記說明:

標記 說明
last 相當於Apache的[L]標記,表示完成rewrite
break 本條規則匹配完成即終止,不再匹配後面的任何規則
redirect 返回302臨時重定向,瀏覽器地址會顯示跳轉後的URL地址,爬蟲不會更新url
permanent 返回301永久重定向,瀏覽器地址欄會顯示跳轉後的URL地址,爬蟲更新url

last和break比較:

last break
使用場景 一般寫在server和if中 一般使用在location中
URL匹配 不終止重寫後的url匹配 終止重寫後的url匹配

location分類

分類:
    location = patt {} [精準匹配]
    location patt {} [一般匹配]
    location ~ patt {} [正則匹配]

正則匹配的常用表達式:

標記 說明
~ 執行一個正則匹配,區分大小寫
~* 執行一個正則匹配,不區分大小寫
!~ 執行一個正則匹配,區分大小寫不匹配
!~* 執行一個正則匹配,不區分大小寫不匹配
^~ 普通字符匹配;使用前綴匹配。如果匹配成功,則不再匹配其他location
= 普通字符精準匹配。也就是完全匹配
@ 定義一個命名的location,使用在內部定向時

location優先級

**相同類型的表達式,字符創長的會優先匹配**
**按優先級排列**
    = 類型
    ^~ 類型表達式
    正則表達式(~和~*)類型
    常規字符串匹配類型,按前綴匹配
    通常匹配(/),如果沒有其他匹配,任何請求都會匹配到

比較rewrite和location

**相同點**
        都能實現跳轉
**不同點**
        rewrite是在同一域名內更改獲取資源的路徑
        location是對一類路徑做控制訪問或方向代理,還可以proxy_pass到其他機器
**rewrite會寫在location裏執行順序**
        執行server塊裏面的rewrite指令
        執行location匹配
        執行選定的location中的rewrite指令

location優先級的示例

##精確匹配/,主機名後面不能帶任何字符串
location = / {
[ configuration A ]     
}

##所有的地址都以/開頭,這條規則將匹配到所有請求,但正則和最長字符串會優先匹配
location  / {
[ configuration B ]     
}

##匹配任何以/documents/開頭的地址,當後面正則表達式沒有匹配到時,才起作用
location /documents/ {
[ configuration C ]
}

##匹配任何以/documents/abc開頭的地址,當後面正則表達式沒有匹配到時,纔會起作用
location ~ /documents/abc {
[ configuration D ]
}

##以/images/開頭的地址,匹配符合後,停止往下匹配
location ^~ /images/ {
[ configuration E ]
}

##匹配所有以gif結尾的請求,/images/下的圖片會被[configuration E]處理,因爲^~的優先級更高
location ~* \.(gif|jpg|jpeg)$ {
[ configuration F ]
}

##最長字符匹配到/images/abc,優先級最低
location /images/abc {
[ configuration G ]
}

##以/images/abc開頭的,優先級次之
location ~ /images/abc {
[ configuration H ]
}

##如果和正則~/images/abc/1.html相比,正則優先級更高
location /images/abc/1.html {
[ configuration I ]
}

location優先級規則

匹配某個具體文件:
(location = 完整路徑)>(location ^~完整路徑)>(location ~完整路徑)>(location ~完整路徑)>(location 完整路徑)>(location /)
用目錄做匹配訪問某個文件:
(location = 目錄)>(location ^~目錄/)>(location ~ 目錄)>(location ~
目錄)>(location 目錄)>(location /)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章