Nginx 服务之location及rewrite

目录

1.location和rewrite的区别

2.location

2.1 location分类

2.2 location匹配规则

2.3 location优先级

2.4 示例

1.location = / {}

2.location / {}

3.location /documents/ {}

4.location /documents/abc {}

5.location ^~ /images/ {}

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

7.location /images/abc {}

8.location ~ /images/abc {}

9.location /images/abc/1.html {}

3.rewrite

3.1 基于域名的跳转

3.2 基于客户端 IP 访问跳转

3.3 基于旧域名跳转到新域名后面加目录

3.4 基于参数匹配的跳转

3.5 基于目录下所有 php 结尾的文件跳转

3.6 基于最普通一条 url 请求的跳转


1.location和rewrite的区别

从功能看 rewrite 和 location 似乎有点像,都能实现跳转,主要区别在于 rewrite 是在同一域名内更改获取资源的路径,而 location 是对一类路径做控制访问或反向代理,还可以proxy_pass 到其他机器。

  • rewrite 对访问的域名或者域名内的URL路径地址重写
  • location 对访问的路径做访问控制或者代理转发

2.location

2.1 location分类

location 大致可以分为三类:

  • 精准匹配:location = / {...}
  • 一般匹配:location / {...} 
  • 正则匹配:location ~ / {...}

2.2 location匹配规则

  • = :进行普通字符精确匹配,也就是完全匹配。
  • ^~ :表示普通字符匹配。使用前缀匹配。如果匹配成功,则不再匹配其它 location。
  • ~ :区分大小写的匹配。
  • ~* :不区分大小写的匹配。
  • !~ :区分大小写的匹配取非。
  • !~* :不区分大小写的匹配取非。

2.3 location优先级

  • 首先精确匹配 =
  • 其次前缀匹配 ^~
  • 其次是按文件中顺序的正则匹配 ~或~*
  • 然后匹配不带任何修饰的前缀匹配
  • 最后是交给 / 通用匹配

2.4 示例

1.location = / {}

=为精确匹配 / ,主机名后面不能带任何字符串,比如访问 / 和 /data,则 / 匹配,/data 不匹配
再比如 location = /abc,则只匹配/abc ,/abc/或 /abcd不匹配。若 location  /abc,则即匹配/abc 、/abcd/ 同时也匹配 /abc/。

2.location / {}

因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求 比如访问 / 和 /data, 则 / 匹配, /data 也匹配,但若后面是正则表达式会和最长字符串优先匹配(最长匹配)

3.location /documents/ {}

匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索其它 location
只有其它 location后面的正则表达式没有匹配到时,才会采用这一条

4.location /documents/abc {}

匹配任何以 /documents/abc 开头的地址,匹配符合以后,还要继续往下搜索其它 location
只有其它 location后面的正则表达式没有匹配到时,才会采用这一条

5.location ^~ /images/ {}

匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条

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

匹配所有以 gif、jpg或jpeg 结尾的请求
然而,所有请求 /images/ 下的图片会被 location ^~ /images/ 处理,因为 ^~ 的优先级更高,所以到达不了这一条正则

7.location /images/abc {}

最长字符匹配到 /images/abc,优先级最低,继续往下搜索其它 loca

你可能感兴趣的:(nginx,运维,https)