Nginx偽靜態教程

zchd發表於2013-07-12

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

  server_name www.php100.com php100.com;

  rewrite ^/$ / redirect;

  2、將不帶www的域名301轉向到帶www的域名:

  server_name www.php100.com php100.com;

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

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

  }

  nginx重定向規則詳細介紹

  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.php100.com/ http://www.php100.cc/;

  if ($invalid_referer) {

  return 404;

  }

  }

  set

  設定nginx變數

  301重定向方法

  進行了301重定向,把www.php100.com和php100.com合併,並把之前的域名也一併合併. 有兩種實現方法,第一種方法是判斷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是關鍵,詳細說明見nginx重定向規則說明。

  last – 基本上都用這個Flag。

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

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

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

  好了,現在可以檢查結果

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

  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;

  }


相關文章