【转】 nginx rewrite 伪静态配置参数详细说明

时间:2023-11-09 17:58:20
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的例子
01 if (!-d $request_filename) {
02     rewrite ^/([a-z-A-Z]+)/([a-z-A-Z]+)/?(.*)$ /index.php?namespace=user&controller=$1&action=$2&$3 last;
03     rewrite ^/([a-z-A-Z]+)/?$ /index.php?namespace=user&controller=$1 last;
04     break;
05     #多目录转成参数
06     abc.domian.com/sort/2 => abc.domian.com/index.php?act=sort&name=abc&id=2
07     if ($host ~* (.*)\.domain\.com) {
08     set $sub_name $1;
09     rewrite ^/sort\/(\d+)\/?$ /index.php?act=sort&cid=$sub_name&id=$1 last;
10 }
11 #目录对换
12 /123456/xxxx -> /xxxx?id=123456
13 rewrite ^/(\d+)/(.+)/ /$2?id=$1 last;
14 #例如下面设定nginx在用户使用ie的使用重定向到/nginx-ie目录下:
15 if ($http_user_agent ~ MSIE) {
16     rewrite ^(.*)$ /nginx-ie/$1 break;
17 }
18 #目录自动加“/”
19 if (-d $request_filename){
20     rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
21 }
22 #禁止htaccess
23 location ~/\.ht {
24     deny all;
25 }
26 #禁止多个目录
27 location ~ ^/(cron|templates)/ {
28     deny all;
29     break;
30 }
31 #禁止以/data开头的文件
32 #可以禁止/data/下多级目录下.log.txt等请求;
33 location ~ ^/data {
34     deny all;
35 }
36 #禁止单个目录
37 #不能禁止.log.txt能请求
38 location /searchword/cron/ {
39     deny all;
40 }
41 #禁止单个文件
42 location ~ /data/sql/data.sql {
43     deny all;
44 }
45 #给favicon.ico和robots.txt设置过期时间;
46 #这里为favicon.ico为99 天,robots.txt为7天并不记录404错误日志
47 location ~(favicon.ico) {
48     log_not_found off;
49     expires 99d;
50     break;
51 }
52  
53 location ~(robots.txt) {
54     log_not_found off;
55     expires 7d;
56     break;
57 }
58 #设定某个文件的过期时间;这里为600秒,并不记录访问日志
59 location ^~ /html/scripts/loadhead_1.js {
60     access_log off;
61     root /opt/lampp/htdocs/web;
62     expires 600;
63     break;
64 }
65 #文件反盗链并设置过期时间
66 #这里的return 412 为自定义的http状态码,默认为403,方便找出正确的盗链的请求
67 #“rewrite ^/ http://leech.c1gstudio.com/leech.gif;”显示一张防盗链图片
68 #“access_log off;”不记录访问日志,减轻压力
69 #“expires 3d”所有文件3天的浏览器缓存
70 location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ {
71     valid_referers none blocked *.c1gstudio.com *.c1gstudio.net localhost 208.97.167.194;
72     if ($invalid_referer) {
74     return 412;
75     break;
76 }
77 access_log off;
78 root /opt/lampp/htdocs/web;
79 expires 3d;
80 break;
81 }
只充许固定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;
001 #文件和目录不存在的时候重定向:
002 if (!-e $request_filename) {
003     proxy_pass http://127.0.0.1/;
004 }
005 #域名跳转
006 server
007 {
008     listen 80;
009     server_name jump.31diy.com;
010     index index.html index.htm index.php;
011     root /opt/lampp/htdocs/www;
012     rewrite ^/ http://www.31diy.com/;
013     access_log off;
014 }
015 #多域名转向
017 index index.html index.htm index.php;
018 root /opt/lampp/htdocs;
019 if ($host ~ "31diy\.net") {
020     rewrite ^(.*) http://www.31diy.com$1/ permanent;
021 }
022 #三级域名跳转
023 if ($http_host ~* "^(.*)\.i\.31diy\.com$") {
024     rewrite ^(.*) http://top.yingjiesheng.com$1/;
025     break;
026 }
027 #域名镜向
028 server
029 {
030     listen 80;
031     server_name mirror.31diy.com;
032     index index.html index.htm index.php;
033     root /opt/lampp/htdocs/www;
034     rewrite ^/(.*) http://www.31diy.com/$1 last;
035     access_log off;
036 }
037 #某个子目录作镜向
038 location ^~ /zhaopinhui {
039     rewrite ^.+ http://zph.31diy.com/ last;
040     break;
041 }
042  
043 #discuz ucenter home (uchome) rewrite
044 rewrite ^/(space|network)-(.+)\.html$ /$1.php?rewrite=$2 last;
045 rewrite ^/(space|network)\.html$ /$1.php last;
046 rewrite ^/([0-9]+)$ /space.php?uid=$1 last;
047 discuz 7 rewrite
048 rewrite ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)$ $1/archiver/index.php?$2 last;
049 rewrite ^(.*)/forum-([0-9]+)-([0-9]+)\.html$ $1/forumdisplay.php?fid=$2&page=$3 last;
050 rewrite ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ $1/viewthread.php?tid=$2&extra=page\%3D$4&page=$3 last;
051 rewrite ^(.*)/profile-(username|uid)-(.+)\.html$ $1/viewpro.php?$2=$3 last;
052 rewrite ^(.*)/space-(username|uid)-(.+)\.html$ $1/space.php?$2=$3 last;
053 rewrite ^(.*)/tag-(.+)\.html$ $1/tag.php?name=$2 last;
054  
055 #给discuz某版块单独配置域名
056 server_name bbs.31diy.com news.31diy.com;
057  
058 location = / {
059     if ($http_host ~ news\.31diy.com$) {
060         rewrite ^.+ http://news.31diy.com/forum-831-1.html last;
061         break;
062     }
063 }
064 #discuz ucenter 头像 rewrite 优化
065 location ^~ /ucenter {
066     location ~ .*\.php?$
067     {
068         #fastcgi_pass unix:/tmp/php-cgi.sock;
069         fastcgi_pass 127.0.0.1:9000;
070         fastcgi_index index.php;
071         include fcgi.conf;
072     }
073  
074     location /ucenter/data/avatar {
075         log_not_found off;
076         access_log off;
077         location ~ /(.*)_big\.jpg$ {
078         error_page 404 /ucenter/images/noavatar_big.gif;
079     }
080     location ~ /(.*)_middle\.jpg$ {
081         error_page 404 /ucenter/images/noavatar_middle.gif;
082     }
083     location ~ /(.*)_small\.jpg$ {
084         error_page 404 /ucenter/images/noavatar_small.gif;
085     }
086     expires 300;
087     break;
088     }
089 }
090 #jspace rewrite
091 location ~ .*\.php?$
092 {
093     #fastcgi_pass unix:/tmp/php-cgi.sock;
094     fastcgi_pass 127.0.0.1:9000;
095     fastcgi_index index.php;
096     include fcgi.conf;
097 }
098  
099 location ~* ^/index.php/
100 {
101     rewrite ^/index.php/(.*) /index.php?$1 break;
102     fastcgi_pass 127.0.0.1:9000;
103     fastcgi_index index.php;
104     include fcgi.conf;
105 }