Rewrite跳转原理和实现方法

本文将为大家详细介绍Rewrite的跳转原理和实现方法,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,我们先来看看Rewrite的跳转原理:

创新互联公司始终坚持【策划先行,效果至上】的经营理念,通过多达10多年累计超上千家客户的网站建设总结了一套系统有效的营销解决方案,现已广泛运用于各行各业的客户,其中包括:汽车玻璃修复等企业,备受客户赞许。

Rewrite跳转场景

URL看起来更规范,合理
企业会将动态URL地址伪装成静态地址提供服务
网址换新域名后,让旧的访问跳转到新的域名上
服务端某些业务调整

Rewrite跳转实现

Rewrite跳转原理和实现方法

Rewrite实用场景

  • Nginx跳转需求的实现方式
    使用rewrite进行匹配跳转
    使用if匹配全局变量后跳转
    使用location匹配再跳转
  • rewrite放在server{},if{},location{}段中
  • 对域名或参数字符串
    使用if全局变量匹配
    使用proxy_pass反向代理

常用的正则表达式元字符

字符说明
^匹配输入字符串的起始位置
$匹配输入字符串的结束位置
*匹配前面的字符零次或多次
+匹配前面的字符一次或多次
匹配前面的字符零次或一次
.匹配除\n之外的任何单个字符,使用诸如"[.\n]"之类的模式,可匹配包括"\n"在内的任意字符
\d匹配纯数字  [0-9]
{n}重复多次
{n,}重复n次或更多次
[c]匹配单个字符c
[a-z]匹配a-z小写字母的任意一个
[a-zA-Z]匹配a-z小写字母或A-Z大写字母的任意一个

Rewrite命令

语法:
rewrite                          [flag];
            正则                  跳转后的内容               rewrite支持的flag标记

flag标记说明:

标记说明
last相当于Apache的[L]标记,表示完成rewrite
break本条规则匹配完成即终止,不再匹配后面的任何规则
redirect返回302临时重定向,浏览器地址会显示跳转后的URL地址,爬虫不会更新url
permanent返回301永久重定向,浏览器地址栏会显示跳转后的URL地址,爬虫更新url

last和break比较:

lastbreak
使用场景一般写在server和if中一般使用在location中
URL匹配不终止重写后的url匹配终止重写后的url匹配

location分类

分类:
    location = patt {} [精准匹配]
    location patt {} [一般匹配]
    location ~ patt {} [正则匹配]

正则匹配的常用表达式:

标记说明
~执行一个正则匹配,区分大小写
~*执行一个正则匹配,不区分大小写
!~执行一个正则匹配,区分大小写不匹配
!~*执行一个正则匹配,不区分大小写不匹配
^~普通字符匹配;使用前缀匹配。如果匹配成功,则不再匹配其他location
=普通字符精准匹配。也就是完全匹配
@定义一个命名的location,使用在内部定向时

location优先级

**相同类型的表达式,字符创长的会优先匹配**
**按优先级排列**
    = 类型
    ^~ 类型表达式
    正则表达式(~和~*)类型
    常规字符串匹配类型,按前缀匹配
    通常匹配(/),如果没有其他匹配,任何请求都会匹配到

比较rewrite和location

**相同点**
        都能实现跳转
**不同点**
        rewrite是在同一域名内更改获取资源的路径
        location是对一类路径做控制访问或方向代理,还可以proxy_pass到其他机器
**rewrite会写在location里执行顺序**
        执行server块里面的rewrite指令
        执行location匹配
        执行选定的location中的rewrite指令

location优先级的示例

##精确匹配/,主机名后面不能带任何字符串
location = / {
[ configuration A ]     
}

##所有的地址都以/开头,这条规则将匹配到所有请求,但正则和最长字符串会优先匹配
location  / {
[ configuration B ]     
}

##匹配任何以/documents/开头的地址,当后面正则表达式没有匹配到时,才起作用
location /documents/ {
[ configuration C ]
}

##匹配任何以/documents/abc开头的地址,当后面正则表达式没有匹配到时,才会起作用
location ~ /documents/abc {
[ configuration D ]
}

##以/images/开头的地址,匹配符合后,停止往下匹配
location ^~ /images/ {
[ configuration E ]
}

##匹配所有以gif结尾的请求,/images/下的图片会被[configuration E]处理,因为^~的优先级更高
location ~* \.(gif|jpg|jpeg)$ {
[ configuration F ]
}

##最长字符匹配到/images/abc,优先级最低
location /images/abc {
[ configuration G ]
}

##以/images/abc开头的,优先级次之
location ~ /images/abc {
[ configuration H ]
}

##如果和正则~/images/abc/1.html相比,正则优先级更高
location /images/abc/1.html {
[ configuration I ]
}

location优先级规则

匹配某个具体文件:
(location = 完整路径)>(location ^~完整路径)>(location ~完整路径)>(location ~完整路径)>(location 完整路径)>(location /)
用目录做匹配访问某个文件:
(location = 目录)>(location ^~目录/)>(location ~ 目录)>(location ~
 目录)>(location 目录)>(location /)

看完上述内容,你们对Rewrite的跳转原理和实现方法大概了解了吗?如果想了解更多相关文章内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!




网站标题:Rewrite跳转原理和实现方法
文章路径:http://myzitong.com/article/igcjge.html