nginx 路径匹配


nginx 路径匹配

 

 

**********************

location

 

精准匹配(=):只匹配指定的请求路径

location = /aaa {     #只匹配请求路径:/aaa,其余路径均不匹配
  ...
}

 

前缀匹配(^ ~):不使用正则表达式,匹配指定前缀开头的请求路径

location ^~ /aaa {   #匹配以/aaa开头的请求路径,如:/aaa、/aaa/b、/aaa/bbb/ccc
  ...
}

 

正则匹配(~):匹配符合正则表达式的请求路径,区分大小写

location ~ \.html$ {           #匹配以 .html结尾的请求路径
  ...
}


location ~ ^/aaa/.*\.html$ {   #匹配以 /aaa开头、.html结尾的请求路径
  ...
}

 

正则匹配(~*):匹配符合正则表达式的请求路径,不区分大小写

location ~* \.html$ {  #匹配以 .html结尾的请求路径
  ...
}

 

最大前缀匹配(无符号):使用前缀匹配度最大的location

#location 1
location  /aaa {
  ...
}

#location 2
location  /aaa/bbb {
  ...
}


/aaa/c      ==> 匹配location 1
/aaa/bbb/c  ==> 匹配location 2

 

匹配优先级: ==>  ^~  ==>  ~/ ~*  ==>  无符号匹配,优先级逐次降低

说明:当有多个正则匹配,使用最先匹配的location

 

 

**********************

注意事项

 

如果最大前缀相同,^~、无符号不能同时使用,会报错(前缀不同,可同时使用)

    location ^~ /aaa {
        root   /usr/share/nginx/html;
    }

    location   /aaa {
        root   /usr/share/nginx/html2;
    }

 

报错信息:

[root@centos html]# docker logs nginx
2020/10/15 02:08:43 [emerg] 1#1: duplicate location "/aaa" in /etc/nginx/conf.d/default.conf:28
nginx: [emerg] duplicate location "/aaa" in /etc/nginx/conf.d/default.conf:28

 

 

**********************

优先级比较

 

^~ ==> ~

    location ^~ /aaa {
        root   /usr/share/nginx/html2/2;
    }

    location ~ /aaa {
        root   /usr/share/nginx/html2/3;
    }

 

curl localhost:8080/aaa

[root@centos html]# curl localhost:8080/aaa
location ^~ /aaa         # ^~ 优先于 ~

 

 

~ ==> 无符号

    location ~ /aaa {
        root   /usr/share/nginx/html2/3;
    }

    location   /aaa {
        root   /usr/share/nginx/html2/4;
    }

 

curl localhost:8080/aaa

[root@centos html]# curl localhost:8080/aaa
location ~ /aaa           # ~ 优先于 无符号

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nginx中,location指令用于匹配请求的URI,以便决定如何处理这个请求。location指令可以接受一个字符串参数,也可以接受一个正则表达式作为参数。 以下是nginx location的路径匹配规则: 1. 以“=”开头的location指令表示严格匹配,只有当请求的URI与location指令的参数完全一致时,才会匹配成功。 2. 如果location指令的参数是一个目录名称,例如“/user/”,那么匹配规则如下: - 如果请求的URI是“/user/”,那么匹配成功。 - 如果请求的URI是“/user”(没有斜杠结尾),那么nginx会自动将其转换为“/user/”,然后再进行匹配。 - 如果请求的URI是“/user/login”,那么匹配成功,因为“/user/login”包含“/user/”这个目录名称。 3. 如果location指令的参数是一个正则表达式,例如“~^/user/(.*)$”,那么匹配规则如下: - 如果请求的URI与正则表达式匹配成功,那么这个location指令就匹配成功。 - 正则表达式中可以使用捕获组,例如“~^/user/(\d+)/(\w+)$”表示匹配形如“/user/123/abc”的URI,并将“123”和“abc”作为变量传递给后端处理程序。 4. 如果location指令的参数是“/”,那么这个location指令会匹配所有请求。 5. 如果存在多个location指令,nginx会按照定义的顺序依次进行匹配,直到找到第一个匹配成功的location指令为止。 需要注意的是,nginx的location匹配规则是从上到下依次匹配的,一旦匹配成功就不再继续匹配。因此,如果存在多个location指令,需要注意定义的顺序,避免出现匹配错误的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值