nginx location语法

第一优先级 = : 完全匹配。如果这个查询匹配,那么将停止搜索并立即处理此请求。

第二优先级 ^~ : 普通字符匹配。优先使用前缀匹配。如果匹配成功,则不再匹配其他location。

第三优先级 ~ : 区分大小写匹配

第三优先级 !~ : 区分大小写不匹配

第三优先级 ~* : 不区分大小写匹配

第三优先级 !~* : 不区分大小写不匹配

第四优先级 /{uri} : 不带任何修饰符,也表示前缀匹配,但是在正则匹配之后。

第四优先级 / : 通用匹配,任何未匹配到其它location的请求都会匹配到,相当于switch中的default。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
location = / {
# 只匹配 / 查询。
}

location / {
# 匹配任何查询,因为所有请求都已 / 开头。但是正则表达式规则和长的块规则将被优先和查询匹配。
}

location ^~ /p_w_picpaths/ {
# 匹配任何已 /p_w_picpaths/ 开头的任何查询并且停止搜索。任何正则表达式将不会被测试。
# 此种方式一般也是服务中带有静态文件的访问方式(假如访问你的服务静态文件是http://xxx:xx/p_w_picpaths/xx.css格式的)
}

location ~* .(gif|jpg|jpeg)$ {
# 匹配任何已 gif、jpg 或 jpeg 结尾的请求。
}

location ~*.(gif|jpg|swf)$ {
valid_referers none blocked start.igrow.cn sta.igrow.cn;
if ($invalid_referer) {
#防盗链
rewrite ^/ http://$host/logo.png;
}
}

对于请求: http://example.com/static/img/logo.jpg

如果命中精确匹配,例如:

1
2
location = /static/img/logo.jpg {
}

则优先精确匹配,并终止匹配。

如果命中多个前缀匹配,例如:

1
2
3
4
location /static/ {
}
location /static/img/ {
}

则记住最长的前缀匹配,即上例中的 /static/img/,并继续匹配

如果最长的前缀匹配是优先前缀匹配,即:

1
2
3
4
location /static/ {
}
location ^~ /static/img/ {
}

则命中此最长的优先前缀匹配,并终止匹配

否则,如果命中多个正则匹配,即:

1
2
3
4
5
6
7
8
location /static/ {
}
location /static/img/ {
}
location ~* /static/ {
}
location ~* /static/img/ {
}

则忘记上述 2 中的最长前缀匹配,使用第一个命中的正则匹配,即上例中的 location ~* /static/ ,并终止匹配(命中多个正则匹配,优先使用配置文件中出现次序的第一个)

否则,命中上述 2 中记住的最长前缀匹配