一、location 匹配顺序
- "=" 前缀指令匹配,如果匹配成功,则停止其他匹配
- 普通字符串指令匹配,顺序是从长到短,匹配成功的 location 如果使用 ^~ ,则停止其他匹配
- 正则表达式指令匹配,按照配置文件里的顺序,成功就停止其他匹配
- 如果第三步中有匹配成功,则使用该结果,否则使用第二步结果
二、注意
1)、匹配的顺序是先匹配普通字符串,然后再匹配正则表达式。另外普通字符串匹配顺序是根据配置中字符长度从长到短,也就是说使用普通字符串配置的 location 顺序是无关紧要的,反正最后 nginx 会根据配置的长短来进行匹配,但是需要注意的是正则表达式按照配置文件里的顺序测试。找到第一个比配的正则表达式将停止搜索。
2)、一般情况下,匹配成功了普通字符串 location 后还会进行正则表达式 location 匹配。有两种方法改变这种行为,其一就是使用 "=" 前缀,这时执行的是严格匹配,并且匹配成功后立即停止其他匹配,同时处理这个请求;另外一种就是使用 "^~" 前缀,如果把这个前缀用于一个常规字符串那么告诉 nginx 不进行正则匹配。
三、nginx 正则表达式之匹配操作符
~ 区分大小写匹配成功
~* 不区分大小写匹配成功
!~ 区分大小写匹配失败
!~* 不区分大小写匹配失败
^ 以什么开头的匹配
$ 以什么结尾的匹配
* 代表任意字符
1、测试 http://localhost/hello,返回 601,注意 #1 与 #2 不能同时打开,他们都是普通字符串
以 ^~ 开头,表示uri以某个普通字符串开头,不是正则匹配
location ^~ /hello/ { #1
return 601;
}
# location /hello/ { #2
# return 602;
# }
location ~ /hello/ {
return 603;
}
2、测试 http://localhost/hello,返回 603,#2 是普通字符串匹配,成功后还要进行正则匹配
# location ^~ /hello/ { #1
# return 601;
# }
location /hello/ { #2
return 602;
}
location ~ /hello/ {
return 603;
}
3、测试 http://localhost/hello/a.html,返回 602,普通字符串的匹配与顺序无关,与长短有关
location /hello/test/ {
return 601;
}
location /hello/ {
return 602;
}
4、测试 http://localhost/hello/test/a.html,返回 602,正则表达式的匹配与顺序有关
location /hello/test/ { #1
return 601;
}
location ~ /hello/ { #2
return 602;
}
location ~ /hello/test/ { #3
return 603;
}