成人AV在线无码|婷婷五月激情色,|伊人加勒比二三四区|国产一区激情都市|亚洲AV无码电影|日av韩av无码|天堂在线亚洲Av|无码一区二区影院|成人无码毛片AV|超碰在线看中文字幕

nginx 偽靜態(tài) 重定向 包括域名、目錄、文件等方法

nginx 偽靜態(tài) 重定向 包括域名、目錄、文件等方法在網(wǎng)站建設(shè)中需要網(wǎng)頁重定向的情況很多:如網(wǎng)頁目錄結(jié)構(gòu)變動,網(wǎng)頁重命名、網(wǎng)頁的擴展名改變、網(wǎng)站域名改變等。如果不做重定向,用戶的收藏和搜索引擎數(shù)據(jù)庫

nginx 偽靜態(tài) 重定向 包括域名、目錄、文件等方法

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

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

1、將多個域名指向同一web 目錄:

server_name www.php100.com php100.com;

rewrite ^/$ / redirect;

2、將不帶www 的域名301轉(zhuǎn)向到帶www 的域名:

server_name www.php100.com php100.com;

if ( $host != "www.php100.com" ) {

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

}

nginx 重定向規(guī)則詳細介紹

rewrite 命令

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

rewrite 正則表達式 替換目標(biāo) flag 標(biāo)記

flag 標(biāo)記可以用以下幾種格式:

,

last – 基本上都用這個Flag 。

break – 中止Rewirte ,不在繼續(xù)匹配

redirect – 返回臨時重定向的HTTP 狀態(tài)302

permanent – 返回永久重定向的HTTP 狀態(tài)301

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

location /download/ {

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

}

nginx 重定向的IF 條件判斷

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

如:

匹配判斷

~ 為區(qū)分大小寫匹配; !~為區(qū)分大小寫不匹配

~* 為不區(qū)分大小寫匹配;!~為不區(qū)分大小寫不匹配

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

if ($http_user_agent ~ MSIE) {

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

}

,

文件和目錄判斷

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

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

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

-x 和!-x 判斷文件是否可執(zhí)行

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

if (!-e $request_filename) {

proxy_pass http://127.0.0.1/;

}

return

返回http 代碼,例如設(shè)置nginx 防盜鏈:

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

valid_referers none blocked http://www.php100.com/ http://www.php100.cc/; if ($invalid_referer) {

return 404;

}

}

set

設(shè)置nginx 變量

301重定向方法

,

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

server_name www.php100.com php100.com ;

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

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

}

...

}

第二種方法:

server {

server_name php100.com;

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

}

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

last – 基本上都用這個Flag 。

break – 中止Rewirte ,不在繼續(xù)匹配

redirect – 返回臨時重定向的HTTP 狀態(tài)302

permanent – 返回永久重定向的HTTP 狀態(tài)301

好了, 現(xiàn)在可以檢查結(jié)果

,

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

nginx rewrite 偽靜態(tài)配置參數(shù)詳細說明(轉(zhuǎn))

* ~ 為區(qū)分大小寫匹配

* ~* 為不區(qū)分大小寫匹配

* !~和!~*分別為區(qū)分大小寫不匹配及不區(qū)分大小寫不匹配 文件及目錄匹配,其中:

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

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

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

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

flag 標(biāo)記有:

* last 相當(dāng)于Apache 里的[L]標(biāo)記,表示完成rewrite

* break 終止匹配, 不再匹配后面的規(guī)則

* redirect 返回302臨時重定向 地址欄會顯示跳轉(zhuǎn)后的地址 * permanent 返回301永久重定向 地址欄會顯示跳轉(zhuǎn)后的地址 一些可用的全局變量有,可以用做條件判斷(待補全)

$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

結(jié)合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;

多目錄轉(zhuǎn)成參數(shù)

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;

例如下面設(shè)定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 設(shè)置過期時間;

這里為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;

}

,

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

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

access_log off;

root /opt/lampp/htdocs/web;

expires 600;

break;

}

文件反盜鏈并設(shè)置過期時間

這里的return 412 為自定義的http 狀態(tài)碼,默認(rèn)為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;

}

標(biāo)簽: