Nignx location匹配及重定向
location
分类
精准匹配:location = / {}
一般匹配:location / {}
正则匹配:location ~ / {}
匹配规则
= :进行普通字符精确匹配,也就是完全匹配
^~ :表示普通字符匹配,使用前缀匹配 匹配即停止
~ :区分大小写的匹配
~* :不区分大小写的匹配
!~ :区分大小写的匹配取反
!~* :不区分大小写的匹配取反
优先级
- 精确匹配 =
- 前缀匹配 ^~
- 按文件中顺序的正则匹配 ~或 ~*
- 匹配不带任何修饰的一般匹配
- 通用匹配
示例
location = / {}
=为精确匹配 / ,主机名后面不能带任何字符串,比如访问 / 和 /data,则 / 匹配,/data 不匹配
再比如 location = /abc,则只匹配/abc ,/abc/或 /abcd不匹配
location / {}
因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求
比如访问 / 和 /data, 则 / 匹配, /data 也匹配,
但若后面是正则表达式会和最长字符串优先匹配(最长匹配)
location /documents/ {}
匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索其它 location
location /documents/abc {}
匹配任何以 /documents/abc 开头的地址,匹配符合以后,还要继续往下搜索其它 location
location ^~ /images/ {}
匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下匹配
location ~* \.(gif|jpg|jpeg)$ {}
匹配所有以 gif、jpg或jpeg 结尾的请求
location /images/abc/1.html {}
匹配/images/abc/1.html 文件,如果和正则 ~ /ima