URL地址匹配是Nginx配置中最灵活的部分 Location 支持正则表达式匹配,也支持条件匹配,用户可以通过location指令实现Nginx对动、静态网页的过滤处理
1.Nginx location 配置语法
1. location [ = | ~ | ~* | ^~ ] uri { ... }
2. location @name { ... }
location 配置可以有两种配置方法
前缀 + uri(字符串/正则表达式)
@ + name
前缀含义
=
:精确匹配(必须全部相等)~
:大小写敏感~*
:忽略大小写^~
:只需匹配uri部分@
:内部服务跳转
2.Location 基础知识
location 是在 server 块中配置。
- 可以根据不同的 URI 使用不同的配置(location 中配置),来处理不同的请求。
- location 是有顺序的,会被第一个匹配的location 处理。
Location 配置演示
=
精确匹配
location = / {
#规则
}
# 则匹配到 `http://www.example.com/` 这种请求。
~
大小写敏感
location ~ /Example/ {
#规则
}
#请求示例
#http://www.example.com/Example/ [成功]
#http://www.example.com/example/ [失败]
~*
大小写忽略
location ~* /Example/ {
#规则
}
# 则会忽略 uri 部分的大小写
#http://www.example.com/Example/ [成功]
#http://www.example.com/example/ [成功]
^~
只匹配以 uri 开头
location ^~ /img/ {
#规则
}
#以 /img/ 开头的请求,都会匹配上
#http://www.example.com/img/a.jpg [成功]
#http://www.example.com/img/b.mp4 [成功]
@nginx
内部跳转
location /img/ {
error_page 404 @img_err;
}
location @img_err {
# 规则
}
#以 /img/ 开头的请求,如果链接的状态为 404。则会匹配到 @img_err 这条规则上。
3.规则分类
其中"~
"和"~
"以及"!~
"和"!~
"前缀表示正则location .
其他前缀(包括:"=
","^~
"和"@
")和无任何前缀的都属于普通location
4.匹配规则
- 普通
location
的匹配规则是最大前缀.(特殊的是"=
"和"^~
",前缀指令将严格匹配uri
,如果匹配,停止搜索.) - 正则
location
的匹配规则是顺序匹配,且只要匹配到第一个就停止后面的匹配. - 通用匹配 "
/
"最后匹配
先匹配普通 location
,再考虑匹配正则 location
。注意这里的考虑是可能的意思,也就是说匹配完普通 location
后,有的时候需要继续匹配正则 location
,有的时候则不需要继续匹配正则 location
。两种情况下,不需要继续匹配正则 location :
( 1 )当普通 location
前面指定了^~
,特别告诉 Nginx 本条普通 location
一旦匹配上,则不需要继续正则匹配;
( 2 )当普通 location
恰好严格匹配上,不是最大前缀匹配,则不再继续匹配正则.
总结:正则 location
匹配让步普通 location 的严格精确匹配结果;但覆盖普通 location
的最大前缀匹配结果.
Nginx
中的 location
并没有想象中的很难懂,不必害怕。多找资料看看,多尝试。你就会有收获。