nginx rewrite重写

Rewrite主要的功能就是实现URL的重写. 通过Rewrite规则,可以实现规范的URL、根据变量来做URL转向及选择配置。

相关指令

if指令

语法:if(condition){…}

使用环境:server,location

该指令用于检查一个条件是否符合,如果条件符合,则执行大括号内的语句。if指令不支持嵌套,不支持多个条件&&和||处理。

其中,condition中可以包含的判断标识如下

  1. ~为区分大小写匹配
  2. ~*为不区分大小写匹配
  3. !~区分大小写不匹配
  4. !~*不区分大小写不匹配
  5. -f和!-f用来判断是否存在文件
  6. -d和!-d用来判断是否存在目录
  7. -e和!-e用来判断是否存在文件或目录
  8. -x和!-x用来判断文件是否可执行
示例,如果是IE浏览器就进行跳转
if ($http_user_agent ~MSIE){  
  rewrite ^(.*)$/msie/$1 break;  
}

return指令

语法:return code

使用环境:server,location,if

该指令用于结束规则的执行并返回状态吗给客户端。状态码包括:204(No Content)、400(Bad Request)、402(Payment Required)、403(Forbidden)、404(Not Found)、405(Method Not Allowed)、406(Not Acceptable)、408(Request Timeout)、410(Gone)、411(Length Required)、413(Request Entity Too Large)、416(Requested Range Not Satisfiable)、500(Internal Server Error)、501(Not Implemented)、502(Bad Gateway)、503(Service Unavailable)和504(Gateway Timeout)。

例如,示例,如果访问的URL以.sh .bash 结尾,返回状态码403

location ~ .*\.(sh|bash)?$  
{  
  return 403;  
}

set指令

语法:set variable value

使用环境:server,location,if

该指令用于定义一个变量,并给变量赋值。

rewrite指令

语法:rewrite regex replacement flag

使用环境:server,location,if

该指令根据表达式来重定向URI,或者修改字符串。

flag标记有:

  • last相当于Apache里的[L]标记,表示完成rewrite
  • break终止匹配, 不再匹配后面的规则
  • redirect返回302临时重定向 地址栏会显示跳转后的地址
  • permanent返回301永久重定向 地址栏会显示跳转后的地址

例如,示例,将www重定向到http://

if ($host ~* www\.(.*)){
  set $host_without_www $1;
  rewrite ^(.*)$ http://$host_without_www$1 permanent;
}

使用案例

域名永久重定向

rewrite ^(.*)$  http://blog.720ui.com permanent;

当访问的文件和目录不存在时,重定向到某个html文件

if ( !-e $request_filename ){
  rewrite ^/(.*)$ error.html last;
}

访问目录跳转

将访问/b跳转到/bbs目录上去

rewrite ^/b/?$ /bbs permanent;

目录对换

/123456/xxxx  ====>   /xxxx?id=123456
rewrite ^/(d+)/(.+)/  /$2?id=$1 last;

根据不同的浏览器将得到不同的结果。

if ($http_user_agent ~ Firefox) {  
   rewrite ^(.*)$ /firefox/$1 break;  
}  

if ($http_user_agent ~ MSIE) {  
   rewrite ^(.*)$ /msie/$1 break;  
}  

if ($http_user_agent ~ Chrome) {  
  rewrite ^(.*)$ /chrome/$1 break;  
}

防止盗链

根据Referer信息防止盗链

location ~*\.(gif|jpg|png|swf|flv)${  
  valid_referers none blocked www.cheng.com*.test.com;  
  if ($invalid_referer)  
    rewrite ^/(.*) http://www.lianggzone.com/error.html           
}

禁止访问以/data开头的文件

location ~ ^/data
{
  deny all;
}

禁止访问以.sh,.exe为文件后缀名的文件

location ~ .*\.(sh|exe)?$  
{  
  return 403;  
}

设置某些类型文件的浏览器缓存时间

location ~ .*.(gif|jpg|jpeg|png|bmp)$
{
  expires 30d;
}

location ~ .*.(js|css)$
{
  expires 1h;
}

设置过期时间并不记录404错误日志

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;
}

附录

常用正则

  • . : 匹配除换行符以外的任意字符
  • ? : 重复0次或1次
  • + : 重复1次或更多次
  • *: 重复0次或更多次
  • \d :匹配数字
  • ^ : 匹配字符串的开始
  • $ : 匹配字符串的介绍
  • {n} : 重复n次
  • {n,} : 重复n次或更多次
  • [c] : 匹配单个字符c
  • [a-z]: 匹配a-z小写字母的任意一个

全局变量

  • $args : #这个变量等于请求行中的参数,同$query_string
  • $content_length : 请求头中的Content-length字段。
  • $content_type : 请求头中的Content-Type字段。
  • $document_root : 当前请求在root指令中指定的值。
  • $host : 请求主机头字段,否则为服务器名称。
  • $http_user_agent : 客户端agent信息
  • $http_cookie : 客户端cookie信息
  • $limit_rate : 这个变量可以限制连接速率。
  • $request_method : 客户端请求的动作,通常为GET或POST。
  • $remote_addr : 客户端的IP地址。
  • $remote_port : 客户端的端口。
  • $remote_user : 已经经过Auth Basic Module验证的用户名。
  • $request_filename : 当前请求的文件路径,由root或alias指令与URI请求生成。
  • $scheme : HTTP方法(如http,https)。
  • $server_protocol : 请求使用的协议,通常是HTTP/1.0或HTTP/1.1。
  • $server_addr : 服务器地址,在完成一次系统调用后可以确定这个值。
  • $server_name : 服务器名称。
  • $server_port : 请求到达服务器的端口号。
  • $request_uri : 包含请求参数的原始URI,不包含主机名,如:/foo/bar.php?arg=baz
  • $uri : 不带请求参数的当前URI,$uri不包含主机名,如/foo/bar.html
  • $document_uri : 与$uri相同。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值