nginx rewrite 重寫

rewrite 重寫

Nginx內置常用變量

http://blog.csdn.net/kwinH/article/details/75513132

重寫中用到的指令

if (條件) {} 設定條件,再進行重寫
set #設置變量
return #返回狀態碼
break #跳出rewrite
rewrite #重寫

if位置 放在location下

If 語法格式

If 空格 (條件) {
重寫模式
}

條件判斷重寫

1: “=”來判斷相等, 用於字符串比較
2: “~” 用正則來匹配(此處的正則區分大小寫)
~* 不區分大小寫的正則
3: -f -d -e來判斷是否爲文件,爲目錄,是否存在.

例子:

if  ($remote_addr = 192.168.1.100) {
return 403;
}

 if ($http_user_agent ~ MSIE) {
 rewrite ^.*$ /ie.htm;
 break; #(不break會循環重定向)
 }

if (!-e $document_root$fastcgi_script_name) {
rewrite ^.*$ /404.html break;
#注, 此處還要加break,
}

以 xx.com/dsafsd.html這個不存在頁面爲例,
我們觀察訪問日誌, 日誌中顯示的訪問路徑,依然是GET /dsafsd.html HTTP/1.1
提示: 服務器內部的rewrite和302跳轉不一樣.
跳轉的話URL都變了,變成重新http請求404.html, 而內部rewrite, 上下文沒變,
就是說 fastcgi_script_name 仍然是 dsafsd.html,因此 會循環重定向.
set 是設置變量用的, 可以用來達到多條件判斷時作標誌用.
達到apache下的 rewrite_condition的效果

如下: 判斷IE並重寫,且不用break; 我們用set變量來達到目的

if ($http_user_agent ~* msie) {
                set $isie 1;
            }

            if ($fastcgi_script_name = ie.html) {
                set $isie 0;
            }

            if ($isie 1) {
                rewrite ^.*$ ie.html;
            }

Rewrite語法
Rewrite 正則表達式 定向後的位置 模式

Goods-3.html —->Goods.php?goods_id=3
goods-([\d]+).html —> goods.php?goods_id =$1

location /ecshop {
index index.php;
rewrite goods-([\d]+)\.html$ /ecshop/goods.php?id=$1;
rewrite article-([\d]+)\.html$ /ecshop/article.php?id=$1;
rewrite category-(\d+)-b(\d+)\.html /ecshop/category.php?id=$1&brand=$2;

rewrite category-(\d+)-b(\d+)-min(\d+)-max(\d+)-attr([\d\.]+)\.html /ecshop/category.php?id=$1&brand=$2&price_min=$3&price_max=$4&filter_attr=$5;

rewrite category-(\d+)-b(\d+)-min(\d+)-max(\d+)-attr([\d+\.])-(\d+)-([^-]+)-([^-]+)\.html /ecshop/category.php?id=$1&brand=$2&price_min=$3&price_max=$4&filter_attr=$5&page=$6&sort=$7&order=$8;
}

注意:用url重寫時, 正則裏如果有”{}”,正則要用雙引號包起來

nginx隱藏index.php

location / {
  try_files $uri $uri/ /index.php?$query_string;
}

nginx防盜鏈

location  ~*  \.(gif|jpg|png|bmp|swf|flv)$  {
     valid_referers none blocked *.ttlsa.com server_names  ~\.google\.  ~\.baidu\.;
     if  ($invalid_referer)  {
          return  403;
          #rewrite ^/ http://www.ttlsa.com/403.jpg;
     }
}

第一行:gif|jpg|png|bmp|swf|flv
表示對gif|jpg|png|bmp|swf|flv後綴的文件實行防盜鏈
第二行: 表示對來源地址進行判斷,以上所有來至ttlsa.com和域名中包含google和baidu的站點都可以訪問到當前站點的圖片,如果來源域名不在這個列表中,那麼$invalid_referer等於1
if{}裏面內容的意思是,如果來路不是指定來源地址就跳轉到直接返回403或則rewrite跳轉其他頁面

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