久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Nginx中rewrite(地址重定向)的深入剖析

瀏覽:241日期:2023-03-13 15:37:30
目錄
  • 一、rewrite語法
  • 二、應用場景
  • 三、rewrite指定工作原理
  • 四、flag 參數(shù)簡介
    • 1、last
    • 2、break
    • 3、redirect
    • 4、parmanent
  • 五、示例
    • 總結

      一、rewrite語法

      指令語法:rewrite regex replacement[flag]

      默認值:none

      應用位置:server、location、if

      regex是PCRE 風格的,如果regex匹配URI,那么URI就會被替換成replacement,replacement 就是新的URI。如果rewrite同一個上下文中有多個這樣的正則,匹配會依照rewrite指令出現(xiàn)的順序先后依次進行下去,匹配到一個之后并不會終止,而是繼續(xù)往下匹配,直到返回最后一個匹配上的為止。如果想要中止繼續(xù)往下匹配,可以使用第三個參數(shù)flag。

      如果新URI字符中有關于協(xié)議的任何東西,比如http://或者https://等,進一步的處理就終止了,直接返回客戶端302。

      如果返回的是30x,那么瀏覽器根據(jù)這個狀態(tài)碼和Location響應頭再發(fā)起一次請求,然后才能得到想要的響應結果。但是,如果不是返回30x狀態(tài)碼,那么跳轉就是內部的,瀏覽器不做跳轉就能得到相應。

      rewrite是實現(xiàn)URL重定向的重要指令,他根據(jù)regex(正則表達式)來匹配內容跳轉到replacement,結尾是flag標記

      示例:

      rewrite ^/(.*) http://www.baidu.com/ permanent;     # 匹配成功后跳轉到百度,執(zhí)行永久301跳轉
      

      常用正則表達式:

      字符描述\將后面接著的字符標記為一個特殊字符或者一個原義字符或一個向后引用^匹配輸入字符串的起始位置$匹配輸入字符串的結束位置*匹配前面的字符零次或多次+匹配前面的字符一次或多次?匹配前面的字符零次或一次.匹配除“\n”之外的所有單個字符(pattern)匹配括號內的pattern

      rewrite的最后一項參數(shù)

      標記符號說明last本條規(guī)則匹配完成后繼續(xù)向下匹配新的location URL 規(guī)則break本條規(guī)則匹配完成后終止,不在匹配任何規(guī)則redirect返回302臨時重定向parmanent返回301永久重定向

      二、應用場景

      • 調整用戶瀏覽的URL,看起來規(guī)范
      • 為了讓搜索引擎收錄網(wǎng)站內容,讓用戶體驗更好
      • 網(wǎng)站更換新域名后
      • 根據(jù)特殊的變量、目錄、客戶端進行跳轉

      三、rewrite指定工作原理

      rewrite模塊的指令有break, if, return, rewrite, set等。rewrite指令所執(zhí)行的順序如下:

      首先在server上下文中依照順序執(zhí)行rewrite模塊指令;如果server中進行了rewrite重新,那么以新的URL發(fā)起內部跳轉,直接匹配location,不會再執(zhí)行server中的rewrite指令,然后

      - 新URL直接匹配location

      - 如果匹配上某個location,那么其中的rewrite模塊指令同樣依照順序執(zhí)行。

      - 如果再次導致URL的rewrite,那么再一次進行內部跳轉去匹配location,但跳轉的總次數(shù)不能超過10次。

      四、flag 參數(shù)簡介

      1、last

      如果有l(wèi)ast參數(shù),那么停止處理任何rewrite相關的指令,立即用替換后的新URI開始下一輪的location匹配。

      如果在location的rewrite也使用last,便會再次以新的URI重新發(fā)起內部重定向,再次進行l(wèi)ocation匹配,而新的URI中極有可能和舊的URI一樣再次匹配到相同location中,這樣死循環(huán)發(fā)生了。當循環(huán)到第10次時,Nginx會終止這樣無意義的循環(huán),并返回500錯誤。這點需要特別的注意。

      2、break

      停止處理任何rewrite的相關指令,就如同break 指令本身一樣。

      last的break的相同點在于,立即停止執(zhí)行所有當前上下文的rewrite模塊指令;不同點在于last參數(shù)接著用新的URI馬上搜尋新的location,而break不會搜尋新的location,直接用這個新的URI來處理請求,這樣能避免重復rewite。因此,在server上下文中使用last,而在location上下文中使用break。

      3、redirect

      replacement 如果不包含協(xié)議,仍然是一個新的的URI,那么就用新的URI匹配的location去處理請求,不會返回30x跳轉。但是redirect參數(shù)可以讓這種情況也返回30x(默認302)狀態(tài)碼,就像新的URI包含http://和https://等一樣。這樣的話,瀏覽器看到302,就會再發(fā)起一次請求,真正返回響應結果的就是這第二個請求。

      4、parmanent

      和redirect參數(shù)一樣,只不過直接返回301永久重定向

      雖說URI有了新的,但是要拼接成完整的URL還需要當前請求的scheme,以及由server_name_in_redirect和port_in_redirect指令決定的HOST和PORT.

      還有一個比較有意思的應用,就是如果replacement中包含請求參數(shù),那么默認情況下舊URI中的請求參數(shù)也會拼接在replacement后面作為新的URI,如果不想這么做,可以在replacement的最后面加上?。

      舉例說明:

      rewrite ^/users/(.*)$ /show?user=$1? last;

      這樣的新URI還是 /show?user=xxx

      但如果不加問號:

      rewrite ^/users/(.*)$ /show?user=$1 last;

      得到的新URI就是/show?user=$1&xxx=xxx。其中xxx=xxx是舊URI所帶的請求參數(shù)。

      五、示例

      server {
        # 訪問 /last.html 的時候,頁面內容重寫到 /index.html 中,并繼續(xù)后面的location匹配,瀏覽器地址欄URL地址不變
        rewrite /last.html /index.html last;
      
        # 訪問 /break.html 的時候,頁面內容重寫到 /index.html 中,并停止后續(xù)的匹配,瀏覽器地址欄URL地址不變;
        rewrite /break.html /index.html break;
      
        # 訪問 /redirect.html 的時候,頁面直接302定向到 /index.html中,瀏覽器地址URL跳為index.html
        rewrite /redirect.html /index.html redirect;
      
        # 訪問 /permanent.html 的時候,頁面直接301定向到 /index.html中,瀏覽器地址URL跳為index.html
        rewrite /permanent.html /index.html permanent;
      
        # 把 /html/*.html => /post/*.html ,301定向
        rewrite ^/html/(.+?).html$ /post/$1.html permanent;
      
        # 把 /search/key => /search.html?keyword=key
        rewrite ^/search\/([^\/]+?)(\/|$) /search.html?keyword=$1 permanent;
        
        # 把當前域名的請求,跳轉到新域名上,域名變化但路徑不變
        rewrite ^/(.*) http://www.jd.com/$1 permanent;
        }
      

      總結

      到此這篇關于Nginx中rewrite(地址重定向)的文章就介紹到這了,更多相關Nginx rewrite地址重定向內容請搜索以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持!

      標簽: Nginx
      主站蜘蛛池模板: 国产成人精品一区二区三区四区 | 播放一区 | 精品在线播放 | 日韩免费视频一区二区 | 亚洲精品免费在线观看 | 精品国产精品三级精品av网址 | 国产精品一二 | 欧美日韩一区二区三区在线观看 | 日韩一区二区成人 | 岛国av在线| 羞羞视频在线播放 | 国产91在线观看 | 黄色片免费在线观看视频 | 国产在线中文字幕 | 国产自产才c区 | 成人免费看电影 | 男女视频在线免费观看 | 久久精品国产免费 | 国产精品国产成人国产三级 | 91精品国产高清自在线观看 | 成人av教育 | 亚洲成人av一区二区三区 | 九九热精 | 伊人久久精品久久亚洲一区 | 免费一区二区三区视频在线 | 精品久久久久久国产 | 成人精品视频99在线观看免费 | 亚洲一区电影 | 一级色视频 | 欧美日韩一区二区三区不卡视频 | 国产三级毛片 | 婷婷中文字幕 | 国变精品美女久久久久av爽 | 欧美激情一区二区 | 国产视频久久 | 国产一区二区成人 | 国产精品一区二区三区四区 | 免费在线一区二区 | 免费av在线网站 | 亚洲国产中文字幕 | 久久精品亚洲精品 |