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 }

【转】 nginx rewrite 伪静态配置参数详细说明的更多相关文章

  1. vsftpd配置参数详细整理

    vsftpd配置参数详细整理  -|白王斧三又干一 vsftpd配置参数详细整理     -|白王斧三又干一 发表于 2005-10-23 20:30:00   1.vsftpd配置参数详细整理#接受 ...

  2. Nginx 服务器伪静态配置不当造成 Access denied

    Nginx 服务器伪静态配置不当造成 Access denied 有群有反馈将 FastAdmin 布署到阿里云后无法打开后台. 出现如下提示,首页是可以打开,点登录链接后出现的.(下是群友的截图) ...

  3. mosquitto配置文件/etc/mosquitto/mosquitto.conf配置参数详细说明

    mosquitto配置文件/etc/mosquitto/mosquitto.conf配置参数详细说明 摘自:https://blog.csdn.net/weixin_43025071/article/ ...

  4. nginx rewrite标签配置以及用户认证配置

    一.nginx  rewrite标签 rewrite 实现URL的改写主要是实现伪静态 1.  rewrite指令语法 指令语法:rewrite regex replacement[flag] 默认值 ...

  5. nginx 高并发配置参数(转载)

    声明:原文章来自http://blog.csdn.net/oonets334/article/details/7528558.如需知道更详细内容请访问. 一.一般来说nginx 配置文件中对优化比较有 ...

  6. nginx之fastcgi配置参数及其缓存

    CGI的由来 最早的Web服务器只能简单地响应浏览器发来的HTTP请求,并将存储在服务器上的HTML文件返回给浏览器,也就是静态html文件,但是后期随着网站功能增多网站开发也越来越复杂,以至于出现动 ...

  7. nginx 高并发配置参数

    一.一般来说nginx 配置文件中对优化比较有作用的为以下几项: 1.  worker_processes 8; nginx 进程数,建议按照cpu 数目来指定,一般为它的倍数 (如,2个四核的cpu ...

  8. nginx 配置参数详细说明

    #定义Nginx运行的用户和用户组 user www www; # #nginx进程数,建议设置为等于CPU总核心数. worker_processes 8; # #全局错误日志定义类型,[ debu ...

  9. codeigniter nginx rewrite规则配置【转】

    转自:http://www.nginx.cn/1134.html nginx如何配置才能支持codeigniter ? 1. codeigniter的url美化去掉index.php   1 2 3 ...

随机推荐

  1. 【实用工具】Teleport Pro爬取整个网站镜像到本地

    1. 使用Teleport Pro可以完全或部分下载一个网站上的内容,在硬盘上创建一个与原网站完全相同的镜象,使用户能够离线浏览 Teleport Pro的安装以及基本使用 在菜单栏Project下得 ...

  2. JS获取单选框checked的value方法

    ; var obj = document.getElementsByTagName("input"); document.getElementById('gender').oncl ...

  3. css兼容处理-hack

    浏览器兼容之旅的第二站:各浏览器的Hack写法 Browser CSS Hacks Moving IE specific CSS into @media blocks Detecting browse ...

  4. Python解释器镜像源修改

    目录 Windows Mac 这篇文章将解除你使用python的pip install xxx受到的网速限制,如果只是下载较小的第三方库,可以尝试pip --default-timeout=100 i ...

  5. 记我的小网站发现的Bug之一 —— 某用户签到了两次

    1.故事背景 今天上午我忙完手中的事情之后突然想起来我还没签到,于是赶紧打开签到页面,刚点击了签到按钮,提示"签到成功,获得25阅读额度!",正准备退出浏览器,忽然发现签到列表有异 ...

  6. 解决php7.3 configure: error: off_t undefined

    //解决该问题:php7.3 configure: error: off_t undefined; check your library configuration # 添加搜索路径到配置文件echo ...

  7. python基础学习笔记——shelve、shutil模块

    shelve 我们之前学了json和pickle模块 这些都是序列化的模块,咱们进行在讲一个序列化的东西 叫做shelve 你们肯定有个疑问,这个东西和那个类似为什么要讲.是因为这个模块比较简单的,并 ...

  8. PC上测试移动端网站和模拟手机浏览器

    一.Chrome*浏览器 chrome模拟手机总共有四种方法,原理都一样,通过伪装User-Agent,将浏览器模拟成Android设备.以下标星的为推荐方法. 1.新建Chrome快捷方式 右击桌面 ...

  9. 【LeetCode】Available Captures for Rook(车的可用捕获量)

    这道题是LeetCode里的第999道题. 题目叙述: 在一个 8 x 8 的棋盘上,有一个白色车(rook).也可能有空方块,白色的象(bishop)和黑色的卒(pawn).它们分别以字符 &quo ...

  10. Leetcode 378.有序矩阵中第k小的元素

    有序矩阵中第k小的元素 给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩阵中第k小的元素.请注意,它是排序后的第k小元素,而不是第k个元素. 示例: matrix = [ [ 1, ...