Nginx中的正则表达式、location匹配简介以及rewrite重写跳转

本文详细介绍了Nginx中的正则表达式和location匹配规则,包括匹配优先级及实际应用案例。同时,深入讲解了rewrite功能,如何实现URL重写和重定向,以及不同flag标记的使用。文中还通过多个实例展示了基于域名、客户端IP、旧域名跳转、参数匹配和文件类型等多种场景下的rewrite跳转配置及其验证过程。
摘要由CSDN通过智能技术生成

目录

一、Nginx 正则表达式

二、location匹配

2.1 概述

2.2 匹配规则格式

2.3 常用的匹配规则

2.4 匹配的优先级

2.5 示例

2.6 实际网站使用中,至少有三个匹配规则定义

2.6.1 第一个必选规则

2.6.2 第二个必选规则

2.6.3 第三个规则

三、rewrite重写

3.1 概述

3.2 rewrite跳转实现

3.3 rewrite执行顺序

3.4 rewrite语法格式

四、rewrite跳转

4.1 基于域名的跳转

4.1.1 需求

4.1.2 配置

4.1.3 浏览器验证

4.2 基于客户端IP访问跳转

4.2.1 需求

4.2.2 配置

4.2.3 浏览器验证

4.3 基于旧域名跳转到新域名后面加目录

4.3.1 需求

4.3.2 配置

4.3.3 浏览器测试

4.4 基于参数匹配的跳转

4.4.1 需求

4.4.2 配置

4.4.3 浏览器测试

4.5 基于目录下所有php结尾的文件跳转

4.5.1 需求

4.5.2 配置

4.5.3 浏览器测试

4.6 基于最普通一条url请求的跳转

4.6.1 需求

4.6.2 配置

4.6.3 浏览器测试


一、Nginx 正则表达式

^ :匹配输入字符串的起始位置
$ :匹配输入字符串的结束位置
* :匹配前面的字符零次或多次。如“ol*”能匹配“o”及“ol”、“oll”
+ :匹配前面的字符一次或多次。如“ol+”能匹配“ol”及“oll”、“olll”,但不能匹配“o”
? :匹配前面的字符零次或一次,例如“do(es)?”能匹配“do”或者“does”,”?”等效于”{0,1}”
. :匹配除“\n”之外的任何单个字符,若要匹配包括“\n”在内的任意字符,请使用诸如“[.\n]”之类的模式
\ :将后面接着的字符标记为一个特殊字符或一个原义字符或一个向后引用。如“\n”匹配一个换行符,而“\$”则匹配“$”
\d :匹配纯数字
\w :匹配字母或数字或下划线或汉字
\s :匹配任意的空白符
\b :匹配单词的开始或结束
{n} :重复 n 次
{n,} :重复 n 次或更多次
{n,m} :重复 n 到 m 次
[] :定义匹配的字符范围
[c] :匹配单个字符 c
[a-z] :匹配 a-z 小写字母的任意一个
[a-zA-Z0-9] :匹配所有大小写字母或数字
() :表达式的开始和结束位置
| :或运算符

二、location匹配

2.1 概述

从功能看,rewrite和location似乎很像,都能实现跳转,主要区别在于 rewrite是在同一域名内更改获取资源的路径,而location是对一类路径做控制访问或反向代理,还可以proxy_pass到其他机器

2.2 匹配规则格式

格式 规则
精准匹配 location = / {...}
一般匹配 location / {...}
正则匹配 location ~ / {...}

2.3 常用的匹配规则

= :进行普通字符精确匹配,也就是完全匹配。
^~ :表示普通字符匹配。使用前缀匹配。如果匹配成功,则不再匹配其它 location。
~ :区分大小写的匹配。
~* :不区分大小写的匹配。
!~ :区分大小写的匹配取非。
!~* :不区分大小写的匹配取非。

2.4 匹配的优先级

首先精确匹配 =
其次前缀匹配 ^~
再其次是按文件中顺序的正则匹配 ~或~*
然后匹配不带任何修饰的前缀匹配(一般匹配)
最后是交给/通用匹配
优先级总结:
1.(location = 完整路径)>(location ^~路径)>(location ~,~* 正则顺序)>(location 部分起始部分)>(location /)
2.优先级相同,正则看上下顺序,上面的优先;一般匹配看长度,最长匹配优先

2.5 示例

(1)location = / {}
=为精确匹配 / ,主机名后面不能带任何字符串,比如访问 / 和 /data,则 / 匹配,/data 不匹配
再比如 location = /abc,则只匹配/abc ,/abc/或 /abcd不匹配。若 location  /abc,则即匹配/abc 、/abcd/ 同时也匹配 /abc/。

(2)location / {}
因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求 比如访问 / 和 /data, 则 / 匹配, /data 也匹配,
但若后面是正则表达式会和最长字符串优先匹配(最长匹配)

(3)location /documents/ {}
匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索其它 location
只有其它 location后面的正则表达式没有匹配到时,才会采用这一条

(4)location /documents/abc {}
匹配任何以 /documents/abc 开头的地址,匹配符合以后,还要继续往下搜索其它 location
只有其它 location后面的正则表达式没有匹配到时,才会采用这一条

(5)location ^~ /images/ {}
匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条

(6)location ~* \.(gif|jpg|jpeg)$ {}
匹配所有以 gif、jpg或jpeg 结尾的请求
然而,所有请求 /images/ 下的图片会被 location ^~ /images/ 处理,因为 ^~ 的优先级更高,所以到达不了这一条正则

(7)location /images/abc {}
最长字符匹配到 /images/abc,优先级最低,继续往下搜索其它 location,会发现 ^~ 和 ~ 存在

(8)location ~ /images/abc {}
匹配以/images/abc 开头的,优先级次之,只有去掉 location ^~ /images/ 才会采用这一条

(9)location /images/abc/1.html {}
匹配/images/abc/1.html 文件,如果和正则 ~ /images/abc/1.html 相比,正则优先级更高
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值