分类 Nginx 下的文章

Nginx匹配多个路径正则表达式

 #匹配/node /info /search
 location ~* ^/(node|info|search)/ {
     proxy_pass   http://localhost:8080;
 }

 #绝对匹配一个路径 /info    
 #location ^~ /info/ {
 #    proxy_pass   http://localhost:8080;
 #}

具体的location匹配命令

注意:一下的大括号和双引号是为乐凸显匹配规则 , 用的时候只有具体符号

1.” ~ ” 匹配区分大小写。

location ~ /js/ {

//如果是JS大写的是不会匹配到的   

}

2.” ~* “ 匹配不区分大小写。

location ~* /js/ {

//JS大写或者小写都可以匹配到   

}

3.” ^ “ 匹配字符串的开始标识.

4.” $ “ 匹配字符串的结束标识.

5.” . “ 点符号匹配除换行符以外的任意字符

6.” * “ 重复零次或更多次 (” + “) 重复一次或更多次 (” ? “) 重复零次或一次

7.” ^~ “ 注意: Nginx将在这个字符串匹配后停止进行正则表达式的匹配(location指令中正则表达式的匹配的结果优先使用) ,一般这种情况用来匹配目录

location ^~ /img/ {

 // 这个则匹配的目录, 当匹配到此规则即可终止往下匹配

}
location ~* .(gif|jpg|jpeg)${

// 这个规则则是访问的具体的文件 , 如xxxx.jpg等

}

8.” = “ 精确匹配

location = / {

 // 指定某一个规则进行精确的匹配 ,只能匹配" / "

}
location / {

 // 这个进行全部匹配

}

9.” @ “定义一个命名的 location,使用在内部定向时使用

// 例如出现异常400等 ,可以直接跳转到 单独定义的异常处理的location
error_page 404 = @fetch;

location @fetch(
proxy_pass http://fetch;
)

10.” [^x] “ 匹配除了x以外的任意字符 , “[^abcde]” 匹配除了abcde这几个字母以外的任意字符

” [/] “这个匹配所有的

二.location 匹配的优先级

location 匹配的优先级(与location在配置文件中的顺序无关)

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

免责声明
本博客部分内容来自于互联网,不代表作者的观点和立场,如若侵犯到您的权益,请联系[email protected]。我们会在24小时内进行删除。