Nginx的location区块的作用及设置

location  [ = | ~ | ~* | ^~ ]    uri          { .... }
# | 指令  | |    匹配标识    |  |匹配的网站网址|  |匹配URI之后要执行的配置段|

其中"="的优先级为最高,为精确匹配;特殊字符"~"和"~*"的区别在于前者区分大小写,后者不区分大小写,他们还可以用逻辑操作符"!"来取反匹配;"^~"的意思是匹配之后不做正则表达式的检查,就是不用匹配类似于"\.(gif|jpg|jpeg)$"的正则表达式了,也就是说"^~"后面跟了正则表达式也没有用的。

location的匹配示例:

location = / { [ configuration A ] }                    #用户请求"/"时,匹配A,例如:
location / { [ configuration B ] }                      #当用户请求"/index.html"时,匹配B,例如:
location /documents/ { [ configuration C ] }            #当用户请求"/documents/"时,匹配C,例如:     
location ^~ /images/ { [ configuration D ] }            #当用户请求"/images/"时,匹配D,:
location ~* \.(gif|jpg|jpeg)$ { [ configuration E ] }    #当用户请求".gif|.jpg|.jpeg"时,匹配E,例如:
 #上面的反斜杠是转义字符,$的意思是结尾

3.location实验验证

我们在bbs的主机上做验证,配置文件如下:

server {
 listen      80;
 server_name  bbs.pcm.com;
 root  html/bbs;
 location = / {
  return 401;
 }
 location / {
  return 402;
 }
 location /documents/ {
  return 403;
 }
 location ^~/images/ {
  return 404;
 }
 location ~* \.(gif|jpg|jpeg)$ {
  return 405;
 }
}

检查语法,没问题的话重新加载配置文件,平滑重启nginx

Nginx的location区块的作用及设置

实验的结果如下:

Nginx的location区块的作用及设置

从上图可以验证到结果没问题的。其中location配对的方法是每条规则都去匹配,直到匹配到最为匹配的结果才输出;还有就是"/"这个是默认匹配的,如果都匹配不上的时候,最后就会默认匹配"/",所以输出的结果为402.

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/1af8bb1d58ff130127629c46b591fd77.html