location 介绍
location是Nginx中的块级指令(block directive),location指令的功能是用来匹配不同的url请求,进而对请求做不同的处理和响应
location有两种匹配规则:
- 1, 匹配URL类型,有四种参数可选,当然也可以不带参数。
1
| location [ = | ~ | ~* | ^~ ] uri { … }
|
- 2, 命名location,用@标识,类似于定于goto语句块。
location匹配参数解释
内容要同表达式完全一致才匹配成功
1 2 3 4 5 6 7
| location = /abc/ { ..... }
|
1 2 3 4 5
| location ~ /Abc/ { ..... }
|
1 2 3 4 5 6
| location ~* /Abc/ { ..... }
|
- (4)
^~
表示普通字符串匹配上以后不再进行正则匹配。
1 2 3 4 5 6
| location ^~ /index/ { ..... }
|
- (5)不加任何规则时,默认是大小写敏感,前缀匹配,相当于加了
~
与 ^~
1 2 3 4 5 6 7 8
| location /index/ { ...... }
|
1 2 3 4 5 6 7
| location /index/ { error_page 404 @index_error; } location @index_error { ..... }
|
3、location匹配顺序
=
> ^~
> ~ | ~*
> 最长前缀匹配
> /
1 2 3 4 5 6 7 8 9 10
| location =
location ^~
location ~ location ~* location /a location /
|
location URI结尾带不带 /
如果 URI 结构是 https://domain.com/ 的形式,尾部有没有 / 都不会造成重定向。因为浏览器在发起请求的时候,默认加上了 / 。虽然很多浏览器在地址栏里也不会显示 / 。这一点,可以访问百度验证一下。
如果 URI 的结构是 https://domain.com/some-dir/ 。尾部如果缺少 / 将导致重定向。因为根据约定,URL 尾部的 / 表示目录,没有 / 表示文件。所以访问 /some-dir/ 时,服务器会自动去该目录下找对应的默认文件。如果访问 /some-dir 的话,服务器会先去找 some-dir 文件,找不到的话会将 some-dir 当成目录,重定向到 /some-dir/ ,去该目录下找默认文件。
参考:
干货 | 一文彻底读懂nginx中的location指令