<ul id="g60s4"><pre id="g60s4"></pre></ul>
<strong id="g60s4"><nav id="g60s4"></nav></strong>
<ul id="g60s4"></ul>
  • <tr id="g60s4"></tr>
  • 
    
  • 或者

    nginx重定向規則詳細介紹

    作者:淺色記憶 瀏覽:220 發布時間:2018-02-06
    分享 評論 0

     為何要使用301重定向

      在網站建設中需要網頁重定向的情況很多:如網頁目錄結構變動,網頁重命名、網頁的擴展名改變、網站域名改變等。如果不做重定向,用戶的收藏和搜索引擎數據庫中的舊地址只能讓訪客得到一個404錯誤信息頁面,訪問流量白白喪失。不僅如此,之前該頁面的一切積累(比如PR值)就都白費了。

      301重定向不僅能使頁面實現自動跳轉,對于搜索引擎來說,也可能可以傳遞PR值。

      nginx重定向規則詳細介紹

      http://www.jefflei.com/post/1015.html

      rewrite命令

      nginx的rewrite相當于apache的rewriterule(大多數情況下可以把原有apache的rewrite規則加上引號就可以直接使用),它可以用在server,location 和IF條件判斷塊中,命令格式如下:

      rewrite 正則表達式 替換目標 flag標記

      flag標記可以用以下幾種格式:

      last – 基本上都用這個Flag。

      break – 中止Rewirte,不在繼續匹配

      redirect – 返回臨時重定向的HTTP狀態302

      permanent – 返回永久重定向的HTTP狀態301

      例如下面這段設定nginx將某個目錄下面的文件重定向到另一個目錄,$2對應第二個括號(.*)中對應的字符串:

      location /download/ {

      rewrite ^(/download/.*)/m/(.*)\..*$ $1/nginx-rewrite/$2.gz break;

      }

      nginx重定向的IF條件判斷

      在server和location兩種情況下可以使用nginx的IF條件判斷,條件可以為以下幾種:

      正則表達式

      如:

      匹配判斷

      ~ 為區分大小寫匹配; !~為區分大小寫不匹配

      ~* 為不區分大小寫匹配;!~為不區分大小寫不匹配

      例如下面設定nginx在用戶使用ie的使用重定向到/nginx-ie目錄下:

      if ($http_user_agent ~ MSIE) {

      rewrite ^(.*)$ /nginx-ie/$1 break;

      }

      文件和目錄判斷

      -f和!-f判斷是否存在文件

      -d和!-d判斷是否存在目錄

      -e和!-e判斷是否存在文件或目錄

      -x和!-x判斷文件是否可執行

      例如下面設定nginx在文件和目錄不存在的時候重定向:

      if (!-e $request_filename) {

      proxy_pass http://127.0.0.1/;

      }

      return

      返回http代碼,例如設置nginx防盜鏈:

      location ~* \.(gif|jpg|png|swf|flv)$ {

      valid_referers none blocked http://www.jefflei.com/ http://www.leizhenfang.com/;

      if ($invalid_referer) {

      return 404;

      }

      }

      set

      設置nginx變量

      301重定向方法

      進行了301重定向,把www .jefflei.com和jefflei.com合并,并把之前的域名也一并合并. 有兩種實現方法,第一種方法是判斷nginx核心變量host(老版本是http_host):

      server {

      server_name www.jefflei.com jefflei.com ;

      if ($host != 'www.jefflei.com' ) {

      rewrite ^/(.*)$ http://www.jefflei.com/$1 permanent;

      }

      ...

      }

      第二種方法:

      server {

      server_name jefflei.com;

      rewrite ^/(.*) http://www.jefflei.com/$1 permanent;

      }

      測試了第一種方法ok,這兩種方法中, permanent是關鍵,詳細說明見nginx重定向規則說明。

      last – 基本上都用這個Flag。

      break – 中止Rewirte,不在繼續匹配

      redirect – 返回臨時重定向的HTTP狀態302

      permanent – 返回永久重定向的HTTP狀態301

      好了,現在可以檢查結果,這里可以看返回的HTTP頭信息:

      http://www.seoconsultants.com/tools/headers.asp

      第二種方法沒有測試成功...

      測試是否定向成功

      http://qinfy.net/301-redirect-for-nginx/

      輸入指令~

      /usr/local/nginx/sbin/nginx -t

      提示:

      the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

      configuration file /usr/local/nginx/conf/nginx.conf test is successful

      測試成功~ 重啟nginx~ 輸入指令~

      /usr/local/nginx/sbin/nginx -s reload

      重啟之后測試一下~是否成功設定完成! 輸入指令~

      curl -I imcat.tk

      會輸出:

      HTTP/1.1 301 Moved Permanently

      Server: nginx/0.7.65

      Date: Tue, 03 Aug 2010 01:12:37 GMT

      Content-Type: text/html

      Content-Length: 185

      Connection: keep-alive

      Location: http://qinfy.net/

      nginx rewrite 偽靜態配置參數詳細說明(轉)

      http://hi.baidu.com/hx10/blog/item/942a0ad784f3ffd0a144df94.html

      nginx rewrite 偽靜態配置參數和使用例子 附正則使用說明

      正則表達式匹配,其中

      * ~ 為區分大小寫匹配

      * ~* 為不區分大小寫匹配

      * !~和!~*分別為區分大小寫不匹配及不區分大小寫不匹配

      文件及目錄匹配,其中

      * -f和!-f用來判斷是否存在文件

      * -d和!-d用來判斷是否存在目錄

      * -e和!-e用來判斷是否存在文件或目錄

      * -x和!-x用來判斷文件是否可執行

      flag標記有:

      * last 相當于Apache里的[L]標記,表示完成rewrite

      * break 終止匹配, 不再匹配后面的規則

      * redirect 返回302臨時重定向 地址欄會顯示跳轉后的地址

      * permanent 返回301永久重定向 地址欄會顯示跳轉后的地址

      一些可用的全局變量有,可以用做條件判斷(待補全)

      $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

      結合QeePHP的例子

      if (!-d $request_filename) {

      rewrite ^/([a-z-A-Z]+)/([a-z-A-Z]+)/?(.*)$ /index.php?namespace=user&controller=$1&action=$2&$3 last;

      rewrite ^/([a-z-A-Z]+)/?$ /index.php?namespace=user&controller=$1 last;

      break;

      多目錄轉成參數

      abc.domian.com/sort/2 => abc.domian.com/index.php?act=sort&name=abc&id=2

      if ($host ~* (.*)\.domain\.com) {

      set $sub_name $1;

      rewrite ^/sort\/(\d+)\/?$ /index.php?act=sort&cid=$sub_name&id=$1 last;

      }

      目錄對換

      /123456/xxxx -> /xxxx?id=123456

      rewrite ^/(\d+)/(.+)/ /$2?id=$1 last;

      例如下面設定nginx在用戶使用ie的使用重定向到/nginx-ie目錄下:

      if ($http_user_agent ~ MSIE) {

      rewrite ^(.*)$ /nginx-ie/$1 break;

      }

      目錄自動加“/”

      if (-d $request_filename){

      rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;

      }

      禁止htaccess

      location ~/\.ht {

      deny all;

      }

      禁止多個目錄

      location ~ ^/(cron|templates)/ {

      deny all;

      break;

      }

      禁止以/data開頭的文件

      可以禁止/data/下多級目錄下.log.txt等請求;

      location ~ ^/data {

      deny all;

      }

      禁止單個目錄

      不能禁止.log.txt能請求

      location /searchword/cron/ {

      deny all;

      }

      禁止單個文件

      location ~ /data/sql/data.sql {

      deny all;

      }

      給favicon.ico和robots.txt設置過期時間;

      這里為favicon.ico為99 天,robots.txt為7天并不記錄404錯誤日志

      location ~(favicon.ico) {

      log_not_found off;

      expires 99d;

      break;

      }

      location ~(robots.txt) {

      log_not_found off;

      expires 7d;

      break;

      }

      設定某個文件的過期時間;這里為600秒,并不記錄訪問日志

      location ^~ /html/scripts/loadhead_1.js {

      access_log off;

      root /opt/lampp/htdocs/web;

      expires 600;

      break;

      }

      文件反盜鏈并設置過期時間

      這里的return 412 為自定義的http狀態碼,默認為403,方便找出正確的盜鏈的請求

      “rewrite ^/ http://leech.c1gstudio.com/leech.gif;”顯示一張防盜鏈圖片

      “access_log off;”不記錄訪問日志,減輕壓力

      “expires 3d”所有文件3天的瀏覽器緩存

      location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ {

      valid_referers none blocked *.c1gstudio.com *.c1gstudio.net localhost 208.97.167.194;

      if ($invalid_referer) {

      rewrite ^/ http://leech.c1gstudio.com/leech.gif;

      return 412;

      break;

      }

      access_log off;

      root /opt/lampp/htdocs/web;

      expires 3d;

      break;

      }

      只充許固定ip訪問網站,并加上密碼

      root /opt/htdocs/www;

      allow 208.97.167.194;

      allow 222.33.1.2;

      allow 231.152.49.4;

      deny all;

      auth_basic "C1G_ADMIN";

      auth_basic_user_file htpasswd;

      將多級目錄下的文件轉成一個文件,增強seo效果

      /job-123-456-789.html 指向/job/123/456/789.html

      rewrite ^/job-([0-9]+)-([0-9]+)-([0-9]+)\.html$ /job/$1/$2/jobshow_$3.html last;

      將根目錄下某個文件夾指向2級目錄

      如/shanghaijob/ 指向 /area/shanghai/

      如果你將last改成permanent,那么瀏覽器地址欄顯是 /location/shanghai/

      rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;

      上面例子有個問題是訪問/shanghai 時將不會匹配

      rewrite ^/([0-9a-z]+)job$ /area/$1/ last;

      rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;

      這樣/shanghai 也可以訪問了,但頁面中的相對鏈接無法使用,

      如./list_1.html真實地址是/area /shanghia/list_1.html會變成/list_1.html,導至無法訪問。

      那我加上自動跳轉也是不行咯

      (-d $request_filename)它有個條件是必需為真實目錄,而我的rewrite不是的,所以沒有效果

      if (-d $request_filename){

      rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;

      }

      知道原因后就好辦了,讓我手動跳轉吧

      rewrite ^/([0-9a-z]+)job$ /$1job/ permanent;

      rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;

      文件和目錄不存在的時候重定向:

      if (!-e $request_filename) {

      proxy_pass http://127.0.0.1/;

      }

      域名跳轉

      server

      {

      listen 80;

      server_name jump.c1gstudio.com;

      index index.html index.htm index.php;

      root /opt/lampp/htdocs/www;

      rewrite ^/ http://www.c1gstudio.com/;

      access_log off;

      }

      多域名轉向

      server_name http://www.c1gstudio.com/ http://www.c1gstudio.net/;

      index index.html index.htm index.php;

      root /opt/lampp/htdocs;

      if ($host ~ "c1gstudio\.net") {

      rewrite ^(.*) http://www.c1gstudio.com$1/ permanent;

      }

      三級域名跳轉

      if ($http_host ~* "^(.*)\.i\.c1gstudio\.com$") {

      rewrite ^(.*) http://top.yingjiesheng.com$1/;

      break;

      }

      域名鏡向

      server

      {

      listen 80;

      server_name mirror.c1gstudio.com;

      index index.html index.htm index.php;

      root /opt/lampp/htdocs/www;

      rewrite ^/(.*) http://www.c1gstudio.com/$1 last;

      access_log off;

      }

      某個子目錄作鏡向

      location ^~ /zhaopinhui {

      rewrite ^.+ http://zph.c1gstudio.com/ last;

      break;

      }

      discuz ucenter home (uchome) rewrite

      rewrite ^/(space|network)-(.+)\.html$ /$1.php?rewrite=$2 last;

      rewrite ^/(space|network)\.html$ /$1.php last;

      rewrite ^/([0-9]+)$ /space.php?uid=$1 last;

      discuz 7 rewrite

      rewrite ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)$ $1/archiver/index.php?$2 last;

      rewrite ^(.*)/forum-([0-9]+)-([0-9]+)\.html$ $1/forumdisplay.php?fid=$2&page=$3 last;

      rewrite ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ $1/viewthread.php?tid=$2&extra=page\%3D$4&page=$3 last;

      rewrite ^(.*)/profile-(username|uid)-(.+)\.html$ $1/viewpro.php?$2=$3 last;

      rewrite ^(.*)/space-(username|uid)-(.+)\.html$ $1/space.php?$2=$3 last;

      rewrite ^(.*)/tag-(.+)\.html$ $1/tag.php?name=$2 last;

      給discuz某版塊單獨配置域名

      server_name bbs.c1gstudio.com news.c1gstudio.com;

      location = / {

      if ($http_host ~ news\.c1gstudio.com$) {

      rewrite ^.+ http://news.c1gstudio.com/forum-831-1.html last;

      break;

      }

      }

      discuz ucenter 頭像 rewrite 優化

      location ^~ /ucenter {

      location ~ .*\.php?$

      {

      #fastcgi_pass unix:/tmp/php-cgi.sock;

      fastcgi_pass 127.0.0.1:9000;

      fastcgi_index index.php;

      include fcgi.conf;

      }

      location /ucenter/data/avatar {

      log_not_found off;

      access_log off;

      location ~ /(.*)_big\.jpg$ {

      error_page 404 /ucenter/images/noavatar_big.gif;

      }

      location ~ /(.*)_middle\.jpg$ {

      error_page 404 /ucenter/images/noavatar_middle.gif;

      }

      location ~ /(.*)_small\.jpg$ {

      error_page 404 /ucenter/images/noavatar_small.gif;

      }

      expires 300;

      break;

      }

      }

      jspace rewrite

      location ~ .*\.php?$

      {

      #fastcgi_pass unix:/tmp/php-cgi.sock;

      fastcgi_pass 127.0.0.1:9000;

      fastcgi_index index.php;

      include fcgi.conf;

      }

      location ~* ^/index.php/

      {

      rewrite ^/index.php/(.*) /index.php?$1 break;

      fastcgi_pass 127.0.0.1:9000;

      fastcgi_index index.php;

      include fcgi.conf;

      }


    日韩一区二区三区电影在线观看| 中文字幕久久久久久精品| 香蕉精品视频在线观看| 日韩av无码一区二区三区| 牛牛本精品99久久精品| 国产精品一国产AV麻豆| 国产成人精品天堂| 亚洲麻豆精品果冻传媒| 日韩精品一区二区三区色欲AV| 国产原创精品视频| 四虎国产精品免费永久在线| 久久狠狠一本精品综合网| 亚洲精品国产日韩无码AV永久免费网 | 午夜天堂精品久久久久| 久久91精品国产91久久小草| 国产在线观看高清精品| 久久久久人妻一区精品| 精品久久久久久久中文字幕 | 精品久久久久久成人AV| 亚洲国产日产无码精品| 182tv午夜精品视频在线播放| 久久99精品久久久久久久久久| 奇米影视7777久久精品| 人妻少妇精品视频二区| 骚片AV蜜桃精品一区| 久久夜色精品国产网站| 久久亚洲中文字幕精品有坂深雪 | 精品国产av一二三四区| 精品久久久久久中文字幕无碍| 香蕉久久国产精品免| 国产精品美女自在线观看免费| 国产精品高清在线观看93| 国产精品扒开做爽爽爽的视频| 国产剧情精品在线| 一区二区三区日韩精品| 亚洲国产日韩视频观看| 精品人妻一区二区三区四区在线| 亚洲国产午夜中文字幕精品黄网站 | 国产精品不卡视频| 日韩va中文字幕无码电影| 亚洲 日韩 色 图网站|