nginx里面的location 规则匹配

本文详细解析了Nginx中location指令的各种匹配规则,包括精确匹配、普通字符匹配、正则匹配及其大小写敏感性,以及这些规则的优先级顺序。通过具体示例,帮助读者理解如何灵活运用这些规则进行高效配置。
nginx location语法

~      # 区分大小写的正则匹配                                                                  location ~ \.(gif|jpg|png|js|css)$ {    #规则D  }
~*    # 不区分大小写的正则匹配(和~的功能相同,就是不区分大小写)    location ~* \.png$ {     #规则E }
^~    #^~表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配别的选项,一般用来匹配目录    location ^~ /static/ {   #规则C }
=      #进行普通字符精确匹配

否定用法:不匹配用法:
!~  区分大小写的不匹配
!~* 不区分大小写的 不匹配

location 匹配的优先级(与location在配置文件中的顺序无关)
= 精确匹配会第一个被处理。如果发现精确匹配,nginx停止搜索其他匹配。
普通字符匹配,正则表达式规则和长的块规则将被优先和查询匹配,也就是说如果该项匹配还需去看有没有正则表达式匹配和更长的匹配。
^~ 则只匹配该规则,nginx停止搜索其他匹配,否则nginx会继续处理其他location指令。
最后匹配理带有"~""~*"的指令,如果找到相应的匹配,则nginx停止搜索其他匹配;当没有正则表达式或者没有正则表达式被匹配的情况下,那么匹配程度最高的逐字匹配指令会被使用。


示例
location = / {
# 只匹配 / 查询。
}

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

location ^~ /images/ {
#匹配任何已 /images/ 开头的任何查询并且停止搜索。任何正则表达式将不会被测试。
}

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

location ~*.(gif|jpg|swf)$ {
valid_referers none blocked start.igrow.cn sta.igrow.cn;
if (KaTeX parse error: Expected '}', got '#' at position 22: …d_referer) { #̲防盗链 rewrite ^…host/logo.png;
}
}

 

转载于:https://www.cnblogs.com/kaishirenshi/p/11102812.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值