文章都可以转载、引用,标明转载出处即可。

Nginx配置文件Rewrite语法

nginx 服务 Mr.c 5530℃ 0评论

  Nginx的Rewrite规则和Apache的Rewite规则差别不是很大,几乎可以直接使用(当然并不是说不改动任何东西就拿来使用)。
  比如在Apache中这样写规则 rewrite ^/([0-9]{5}).html$ /viewthread.php?tid=$1 last; 而在Nginx中写成这样写是无法启动的,解决的办法是加上两个双引号: rewrite “^/([0-9]{5}).html$” /viewthread.php?tid=$1 last;一般来说,nginx的rewrite规则可以写在nginx配置文件中的location {}中,也可以针对特定的目录进行location \demo {},这个实例就是针对服务器根目录下的demo目录的rewrite规则配置等等;
   nginx的rewrite重写是基于pcre库匹配的,所以会牵涉到一些基本的nginx匹配规则:
nginx rewrite 正则表达式匹配

大小写匹配

~ 为区分大小写匹配 

~* 为不区分大小写匹配 

!~和!~*分别为区分大小写不匹配及不区分大小写不匹配 

文件及目录匹配

-f和!-f用来判断是否存在文件 

-d和!-d用来判断是否存在目录 

-e和!-e用来判断是否存在文件或目录 

-x和!-x用来判断文件是否可执行 

flag标记

last 相当于Apache里的[L]标记,表示完成rewrite

break 终止匹配, 不再匹配后面的规则。

redirect 返回302临时重定向 地址栏会显示跳转后的地址。

permanent 返回301永久重定向 地址栏会显示跳转后的地址。

一些可用的全局变量

可以用在rewrite时的条件判断

$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 

一下做几个实例以便于加深记忆

多目录转成参数

要求: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; 

再来一个针对浏览器优化的自动rewrite,这里rewrite后的目录可以是存在的;

例如设定nginx在用户使用ie的使用重定向到/nginx-ie目录

规则如下:

 if ($http_user_agent ~ MSIE) {

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

} 

目录自动加“/” ,这个功能一般浏览器自动完成

if (-d $request_filename){ 

rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent; 

} 

以下这些可能就跟广义的rewrite重写无关了

禁止htaccess

location ~/\.ht { 

    deny all; 

} 

禁止多个目录

location ~ ^/(cron|templates)/ { 

    deny all; break; 

} 

禁止以/data开头的文件,可以禁止/data/下多级目录下.log.txt等请求

location ~ ^/data { 

    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; 

    expires 600; 

    break; 

} 

  文件反盗链并设置过期时间–<盗链多次请求也会打开你的站点的图片啊,所以设置下缓存时间,不会每次盗链都请求并下载这张图片>

location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ { 

    valid_referers none blocked *.cnyunwei.cc *.cnyunwei.com.cn *.lanwei.org *.cnyunwei.org localhost  42.121.107.189; 

    if ($invalid_referer) { 

        rewrite ^/ http://img.cnyunwei.cc/forbid.gif; 

        return 417; 

        break; 

    } 

    access_log off; 

    break; 

} 

说明:

这里的return 417 为自定义的http状态码,默认为403,方便通过nginx的log文件找出正确的盗链的请求地址

“rewrite ^/ http://img.cnyunwei.cc/forbid.gif;”显示一张防盗链图片

 “access_log off;”不记录访问日志,减轻压力 

“expires 3d”所有文件3天的浏览器缓存 

只充许固定ip访问网站,并加上密码;这个对有权限认证的应用比较在行

location \ { 

    allow 22.27.164.25; #允许的ipd

    deny all; 

    auth_basic “KEY”; #认证的一些设置

    auth_basic_user_file htpasswd; 

}

说明:location的应用也有各种变化,这里的写法就针对了根目录了。

文件和目录不存在的时重定向

if (!-e $request_filename) { 

    #proxy_pass http://127.0.0.1; #这里是跳转到代理ip,这个代理ip上有一个监听的web服务器

    rewrite ^/ http://www.cnyunwei.cc/none.html;  #跳转到这个网页去

    #return 404; #直接返回404码,然后会寻找root指定的404.html文件

} 

域名跳转

server { 

    listen 80; 

    server_name jump.cnyunwei.cc ;#需要跳转的多级域名

    index index.html index.htm index.php; #入口索引文件的名字

    root /var/www/public_html/; #这个站点的根目录

    rewrite ^/ http://www.cnyunwei.cc/; 

    #rewrite到这个地址,功能表现:在浏览器上输入jump.cnyunwei.cc并回车,不会有任何提示直接变成www.cnyunwei.cc

    access_log off; 

} 

多域名转向

server { 

    listen 80; 

    server_name www.cnyunwei.cc www.cnyunwei.org;

    index index.html index.htm index.php; 

    root /var/www/public_html/; 

    if ($host ~ “cnyunwei\.org”) { 

        rewrite ^(.*) http://www.cnyunwei.cc$1 permanent; 

    } 

}

三级域名跳转

if ($http_host ~* “^(.*)\.i\.cnyunwei\.cn$”) { 

    rewrite ^(.*) http://demo.cnyunwei.cc$1; 

    break; 

} 

域名镜向

server { 

    listen 80; 

    server_name mirror.cnyunwei.cc; 

    index index.html index.htm index.php; 

    root /var/www/public_html; 

    rewrite ^/(.*) http://www.cnyunwei.cc/$1 last; 

    access_log off; 

} 

某个子目录作镜向,这里的示例是demo子目录

location ^~ /demo { 

    rewrite ^.+ http://demo.cnyunwei.cc/ last; 

    break; 

}

本文转载自 《Nginx的Rewrite配置笔记》 写的很通俗易懂,转载记录方便日后使用查阅。

转载请注明:菜鸟运维网 » Nginx配置文件Rewrite语法

喜欢 (3)
发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
(6)个小伙伴在吐槽
  1. 转载与:http://blog.cnyunwei.cc/linux/nginx_rewrite.html ,这个地址是你的二级域名?打不开
    小z博客2017-03-20 13:56 回复
    • 已处理,当时编辑出错导致。
      Mr.c2017-03-20 14:04 回复
  2. 博主,你的网站做的很精致,是自己写的主题么?
    ifio2017-03-30 11:04 回复
    • 不是自己写的,这个是找的模板,一些css文件让朋友帮忙改动过而已。
      Mr.c2017-03-30 11:17 回复
      • 能发下原模版的链接么,不胜感激
        ifio2017-03-30 13:58 回复
        • 具体哪里找的忘了,应该是 “翠竹林”这个主题,你可以找找看
          Mr.c2017-03-30 14:54 回复