Location匹配的url的语法规则:


location [=|~|~*|^~] /uri/ { … }


=  表示精确匹配

~  表示区分大小写的正则匹配

^~ 表示以某个常规字符串开头的url即可;

~* 表示不区分大消息的正则匹配

!~(*!~)表示不区分大小写不匹配的正则

/  通配符,任何请求都能匹配到这个location,如果有任何其他location可以匹配,则会覆盖该location

匹配顺序:

1)先匹配普通url,在匹配正则

2)“普通 location ”的匹配规则是“最大前缀”,因此“普通 location ”的确与 location 编辑顺序无关;

3)location的执行逻辑基本上跟顺序没有关系;但是针对正则匹配的方式,匹配上第一个url,就不在继续匹配后面的url;

这种情况,如果匹配上普通localtion,没有正则匹配,则使用普通匹配;如果既有普通location的最大前缀匹配,也有正则匹配,则正则匹配覆盖最大前缀匹配。

4)匹配完“普通 location ”后,有的时候需要继续匹配“正则 location ”,有的时候则不需要继续匹配“正则 location ”。

两种情况下,不需要继续匹配正则 location :(1) 当普通 location 前面指定了“ ^~ ”,特别告诉 Nginx 本条普通 location 一旦匹配上,则不需要继续正则匹配;(2) 当普通location 恰好严格匹配上,不是最大前缀匹配,则不再继续匹配正则。

例如:


location  = / {
  # matches the query / only.
  [ configuration A ] 
}
location  / {
  # matches any query, since all queries begin with /, but regular
  # expressions and any longer conventional blocks will be
  # matched first.
  [ configuration B ] 
}
location /documents/ {
  # matches any query beginning with /documents/ and continues searching,
  # so regular expressions will be checked. This will be matched only if
  # regular expressions don‘t find a match.
  [ configuration C ] 
}
location ^~ /images/ {
  # matches any query beginning with /images/ and halts searching,
  # so regular expressions will not be checked.
  [ configuration D ] 
}
location ~* \.(gif|jpg|jpeg)$ {
  # matches any request ending in gif, jpg, or jpeg. However, all
  # requests to the /images/ directory will be handled by
  # Configuration D.   
  [ configuration E ] 
}


请求示例,匹配的Location:

    •  / -> configuration A
    •  /index.html -> configuration B
    •  /documents/document.html -> configuration C
    •  /images/1.gif -> configuration D
    •  /documents/1.jpg -> configuration E


    ----------------------------------------------------------------------


    匹配的优先级如下

    1、如果查询精确的命中了一个使用=前缀的location,那个它将被使用,并结束匹配

    2、在剩下普通字符串中,将按照最大前缀匹配的原则进行匹配,将结果最后候选结果,如果最终命中的结果使用了^~前缀表示或者它是一个完全匹配,那么它将被使用,并结束匹配

    3、正则表达式匹配时,按照正则表达式在配置文件中出现的顺序,并且只有匹配到了一条正则local,就不在匹配下面的local了

    4、如果步骤3命中了一个匹配,那个它将被使用,否则将使用步骤2的候选结果

    (普通字符串和正则字符串的区别 ~和~*前缀表示location是正则字符串,其他前缀和无前缀表示location是普通字符串)





    ----------------------------------------------------------------------------------------------------------------------------------------




    语法规则: location [=|~|~*|^~] /uri/ { … }
    = 开头表示精确匹配
    ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。
    ~ 开头表示区分大小写的正则匹配
    ~*  开头表示不区分大小写的正则匹配
    !~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则

    / 通用匹配,任何请求都会匹配到。
     多个location配置的情况下匹配顺序为(参考资料而来,还未实际验证,试试就知道了,不必拘泥,仅供参考):
     首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
     例子,有如下匹配规则:
     location = / {
        #规则A
     }
     location = /login {
        #规则B
     }
     location ^~ /static/ {
        #规则C
     }
     location ~ \.(gif|jpg|png|js|css)$ {
        #规则D
     }
     location ~* \.png$ {
        #规则E
     }
     location !~ \.xhtml$ {
        #规则F
     }
     location !~* \.xhtml$ {
        #规则G
     }
     location / {
        #规则H
     }
     那么产生的效果如下:
     访问根目录/, 比如http://localhost/ 将匹配规则A
     访问 http://localhost/login 将匹配规则B,http://localhost/register 则匹配规则H
     访问 http://localhost/static/a.html 将匹配规则C
     访问 http://localhost/a.gif, http://localhost/b.jpg 将匹配规则D和规则E,但是规则D顺序优先,规则E不起作用,而 http://localhost/static/c.png 则优先匹配到规则C
     访问 http://localhost/a.PNG 则匹配规则E,而不会匹配规则D,因为规则E不区分大小写。
     访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到,所以想想看实际应用中哪里会用到。
     访问 http://localhost/category/id/1111 则最终匹配到规则H,因为以上规则都不匹配,这个时候应该是nginx转发请求给后端应用服务器,比如FastCGI(PHP),tomcat(jsp),nginx作为方向代理服务器存在。 
     所以实际使用中,个人觉得至少有三个匹配规则定义,如下:
     #直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理,官网如是说。
     #这里是直接转发给后端应用服务器了,也可以是一个静态首页
     # 第一个必选规则
     location = / {
         proxy_pass http://tomcat:8080/index }
     # 第二个必选规则是处理静态文件请求,这是nginx作为http服务器的强项
     # 有两种配置模式,目录匹配或后缀匹配,任选其一或搭配使用
     location ^~ /static/ {
         root /webroot/static/;
     }
     location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
         root /webroot/res/;
     }
     #第三个规则就是通用规则,用来转发动态请求到后端应用服务器
     #非静态文件请求就默认是动态请求,自己根据实际把握
     #毕竟目前的一些框架的流行,带.php,.jsp后缀的情况很少了
     location / {
         proxy_pass http://tomcat:8080/ } 三、ReWrite语法
     last – 基本上都用这个Flag。
     break – 中止Rewirte,不在继续匹配
     redirect – 返回临时重定向的HTTP状态302
     permanent – 返回永久重定向的HTTP状态301
     1、下面是可以用来判断的表达式:
     -f和!-f用来判断是否存在文件
     -d和!-d用来判断是否存在目录
     -e和!-e用来判断是否存在文件或目录
     -x和!-x用来判断文件是否可执行
     2、下面是可以用作判断的全局变量
     例:http://localhost:88/test1/test2/test.php $host:localhost
     $server_port:88
     $request_uri:http://localhost:88/test1/test2/test.php $document_uri:/test1/test2/test.php
     $document_root:D:\nginx/html
     $request_filename:D:\nginx/html/test1/test2/test.php
     四、Redirect语法
     server {
     listen 80;
     server_name start.igrow.cn;
     index index.html index.php;
     root html;
     if ($http_host !~ “^star\.igrow\.cn$" {
     rewrite ^(.*) http://star.igrow.cn$1 redirect;
     }
     }
     五、防盗链
     location ~* \.(gif|jpg|swf)$ {
     valid_referers none blocked start.igrow.cn sta.igrow.cn;
     if ($invalid_referer) {
     rewrite ^/ http://$host/logo.png;
     }
     }
     六、根据文件类型设置过期时间
     location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ {
     if (-f $request_filename) {
     expires 1h;
     break;
     }
     }
     七、禁止访问某个目录
     location ~* \.(txt|doc)${
     root /data/www/wwwroot/linuxtone/test;
     deny all;
     }
     一些可用的全局变量:
     $args
     $content_length
     $content_type
     $document_root
     $document_uri
     $host
     $http_user_agent
     $http_cookie
     $limit_rate
     $request_body_file
     $request_method
     $remote_addr
     $remote_port
     $remote_user
     $request_filename
     $request_uri
     $query_string
     $scheme
     $server_protocol
     $server_addr
     $server_name
     $server_port
     $uri