设为首页 收藏本站
查看: 642|回复: 0

[经验分享] Nginx笔记之Rewrite规则

[复制链接]

尚未签到

发表于 2018-11-12 07:04:07 | 显示全部楼层 |阅读模式
  Nginx中Rewrite规则主要用于实现URL的重写。通过Rewrite规则,可以实现规范的URL、根据变量来做URL转向及选择配置。

Rewrite规则相关命令


  • break
  • if
  • return
  • rewrite
  • set
break命令
  break的作用即完成当前规则集,后续不再处理rewrite命令。
  

if ($slow)  
{
  limit_rate 10k;
  break;
  
}
  

if命令
  if条件判断,判断一个条件是否符合,符合就执行代码段内的命令。Nginx内的if命令不支持嵌套,也不支持多一个条件处理(&&或||)
  if命令是Rewrite规则内使用较多的一个命令,很多信息都可以作为if的条件进行判断。大致分为以下几种:


  • 变量名是否为空
  • 变量比较:=、!=
  • 正则匹配

    • 模糊匹配 ~*
    • 完全匹配 ~
    • 不匹配

      • 不完全匹配 !~
      • 不模糊匹配 !~*


  • 文件是否存在 -f | !-f
  • 目录是否存在 -d | !-d
  • 文件或目录是否存在 -e | !-e
  • 文件是否可执行 -x | !-x
  例如:
  

if ($http_user_agent ~ MSIE)  
{
  rewrite ^(.*)$ /msie/$1 break;
  
}
  
if ($http_cookie ~* "id=([^;] +)(?:;|$)")
  
{
  set $id $1;
  
}
  
if ($request_method = POST)
  
{
  return 405;
  
}
  
if (!-f $request_filename)
  
{
  break;
  proxy_pass http://127.0.0.1;
  
}
  
if ($slow)
  
{
  limit_rate 10k;
  
}
  
if ($invalid_referer)
  
{
  return 403;
  
}
  
if ($args ^~ post=140)
  
{
  rewrite ^ http://example.com/ permanent;
  
}
  

return命令
  return命令用于结束规则的执行并返回状态码信息给客户端。常用的可用状态码包括:


  • 403   Forbidden,服务器拒绝执行
  • 404   Not Found,请求的资源为找到
  • 500   Internet Server Error,服务器遇到错误,导致无法完成对请求的处理(常出现在服务器的程序代码出现错误时)
  • 502   Bad Gateway,网关或代理无效
  • 503   Service Unabailable,服务器由于临时进行维护或过载导致无法处理请求
  • 504   Gateway Timeout,作为网关或代理的服务器处理请求时未能及时从上游服务器得到响应。
rewrite(核心)
  作为rewrite规则内的核心命令,rewrite命令根据表达式来重定向URI,或者修改字符串。执行命令按其在配置文件内的顺序。

  重写表达式子对相对路径有效;如果想匹配主机名,需要配置if命令

  rewrite语法:rewrite regex replacement flag
  rewrite命令支持的flag:


  • last 完成rewrite,类似于apache内的[L]标记
  • break 本条规则匹配后终止匹配,后续规则不在匹配
  • redirect 返回状态码302,表示临时性的重定向
  • permanent 返回状态码301,永久重定向
  last和break用来实现URI重写,浏览器显示的URI地址不变,但服务器端访问的路径发生了变化;redirect和permanent用来实现URI跳转,浏览器会显示跳转后的URI地址。
  last会在本条rewrite规则执行后重新在所在块内发起请求,而break则在本条规则匹配后终止匹配,因此last在某些情况下误使用将导致死循环。一般在根location中或直接在server标签中编写rewrite规则,推荐使用last;在非根location中使用break。例如:
  

# 对于location / {...}块而言,可以直接写内部的代码,不写location  
rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$1.mp3 last;
  
return 403;
  

  
location 、download/ {
  rewrite ^(/download/.*)/media/(.*)\..*$ $1/mp3/$1.mp3 break;
  return 403;
  
}
  

  如果被替换的URI中含有参数(例如/app/test.php?id=5),默认参数会被自动附加到替换串上,我们可以通过在替换串的末尾加上?来解决这一问题。
  

rewrite ^/user/(.*)$ /show?user=$1? last;  

  
# 末尾不加?
  
# rewrite ^/test(.*)$ http://www.aaa.com/home permanent;
  
# 对于访问http://www.aaa.com/test?id=5,跳转后将访问http://www.aaa.com/home?id=5
  

  
# 末尾加?
  
# rewrite ^/test(.*)$ http://www.aaa.com/home? permanent;
  
# 对于访问http://www.aaa.com/test?id=5,跳转后将访问http://www.aaa.com/home
  

set命令
  set命令用于定义一个变量,还可以给变量进行赋值。配合if可以实现多条件。例如
  

if ($host ~* ^(.*?)\.aaa\.com$)  
{
  set $var_test '1';
  
}
  
if ($host ~* ^localhost)
  
{
  set $var_test '1';
  
}
  
if ($var_test !~ '1')
  
{
  rewrite ^/(.*)$ http://www.aaa.com/ redirect;
  
}
  

Nginx与Apache的Rewrite规则实例对比
  一般来说,,简单的nginx和apache的rewrite规则相差不大,只有小小修复即可实现兼容。
  Apache Rewrite规则:
  

RewriteRule ^/(.*)$ http://www.aaa.com/$1 [L]  

  Nginx Rewrite规则:
  

rewrite ^/(.*)$ http://www.aaa.com/$1 last;  

两者的细微区别


  • URL跳转方面
  

# nginx  
# nginx要求给转换后的URL添加域名:http://$host
  
rewrite ^/(.*)$ http://www.aaa.com/$1/ permanent;
  

  
# apache
  
RewriteRule ^/(.*)$ /$1/ [R=301,L]
  


  • 变量名称
  

# apache引用变量  
${HTTP_HOST}
  

  
# nginx引用变量
  
$host
  

两者的相似命令

apache
nginx
RewriteCond
if
RewriteRule
rewrite
[R]
redirect
[P]
last
[R,L]
redirect
[P,L]
last
[PT,L]
last
  本文是一篇读书笔记,是对书内某个章节的知识整理,以防遗忘。




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-633839-1-1.html 上篇帖子: nginx利用logrotate日志切割 下篇帖子: 升级Nginx到1.12.2的脚本
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表