location语法
location [=|~|~*|^~] /uri/ { … }
= 开头表示精确匹配
^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。
~ 开头表示区分大小写的正则匹配
~* 开头表示不区分大小写的正则匹配
!~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则
/ 通用匹配,任何请求都会匹配到。
1、精准匹配和一般匹配
http://192.168.0.201/index/ 访问时匹配的是:=/index/
2、精准匹配和一般匹配,uri后面不带“/”匹配
请求URL:http://192.168.0.201/index/ 访问时匹配的是:/index
3、精准匹配和一般匹配,uri前面和后面都不带“/”
请求URL:http://192.168.0.201/index/ 访问时匹配的是:= index
4、精准匹配和一般匹配,uri带"/"和不带"/"匹配
请求URL:http://192.168.0.201/index/ 访问时匹配的是:/index/ 顺序换也是一样
综上所述:路径相同时的精准匹配优先,必须是满足/uri/或者uri,要么uri两边都加/,要么uri两边都不加斜杆的情况
5、一般匹配时的匹配规则
请求url:http://192.168.0.201/index/aa,既能匹配/index/,又能匹配/index/aa,这时以最长uri匹配优先,匹配的是:/index/aa
最后总结:
1. 先判断精准命中,如果命中,立即返回结果并结束解析过程
2. 判断普通命中,如果有多个命中,记录下来最长的命中结果
3、如果是^~开头的命中,则不会继续搜索正则命中,但是会继续搜索一般命中
4. 继续判断正则表达式的解析结果,按配置里的正则表达式顺序为准,由上到下开始匹配,一旦匹配成功立刻返回结果,并结束解析过程。
延伸分析:a. 普通命中:顺序无所谓,是因为按命中长短来确定的 b. 正则命中:顺序有所谓,因为是从前往后命中的
————————————————
原文链接:https://blog.csdn.net/luoyang_java/article/details/83507193