快速了解Nginx_location的匹配规则

一 Nginx的location语法
  location [=|——|——|^——] /uri/ { … }
  = 严格匹配。如果请求匹配这个location,那么将停止搜索并立即处理此请求
  —— 区分大小写匹配(可用正则表达式)
  ——
不区分大小写匹配(可用正则表达式)
  !—— 区分大小写不匹配
  !——* 不区分大小写不匹配FTP
  ^—— 如果把这个前缀用于一个常规字符串,那么告诉nginx 如果路径匹配那么不测试正则表达式
  示例1:
  location / { }
  匹配任意请求
  示例2:
  location ——* .(gif|jpg|jpeg)$ {
  rewrite .(gif|jpg|jpeg)$ /logo.png;
  }
  不区分大小写匹配任何以gif、jpg、jpeg结尾的请求,并将该请求重定向到 /logo.png请求
  示例3:
  location —— ^.+.txt$ {
  root /usr/local/nginx/html/;
  }
  区分大小写匹配以.txt结尾的请求,并设置此location的路径是/usr/local/nginx/html/。也就是以.txt结尾的请求将访问/usr/local/nginx/html/ 路径下的txt文件
二 alias与root的区别
  root 实际访问文件路径会拼接URL中的路径
  alias 实际访问文件路径不会拼接URL中的路径
  示例如下:
  location ^—— /sta/ {
  alias /usr/local/nginx/html/static/;
  }
  请求:http://test.com/sta/sta1.html
  实际访问:/usr/local/nginx/html/static/sta1.html 文件
  location ^—— /tea/ {
  root /usr/local/nginx/html/;
  }
  请求:http://test.com/tea/tea1.html
  实际访问:/usr/local/nginx/html/tea/tea1.html 文件
三 last 和 break关键字的区别
  (1)last 和 break 当出现在location 之外时,两者的作用是一致的没有任何差异
  (2)last 和 break 当出现在location 内部时:
  last 使用了last 指令,rewrite 后会跳出location 作用域,重新开始再走一次刚才的行为
  break 使用了break 指令,rewrite后不会跳出location 作用域,它的生命也在这个location中终结
四 permanent 和 redirect关键字的区别
  rewrite … permanent 永久性重定向,请求日志中的状态码为301
  rewrite … redirect 临时重定向,请求日志中的状态码为302
五 综合实例
  将符合某个正则表达式的URL重定向到一个固定页面
  比如:我们需要将符合“/test/(\d+)/[\w-.]+” 这个正则表达式的URL重定向到一个固定的页面。符合这个正则表达式的页面可能是:http://test.com/test/12345/abc122.html、http://test.com/test/456/11111cccc.js等
  从上面的介绍可以看出,这里可以使用rewrite重定向或者alias关键字来达到我们的目的。因此,这里可以这样做:
  (1)使用rewrite关键字:
  location —— ^.+.txt$ {
  root /usr/local/nginx/html/;
  }
  location ——* ^/test/(\d+)/[\w-.]+$ {
  rewrite ^/test/(\d+)/[\w-.]+$ /testpage.txt last;
  }
  这里将所有符合条件的URL(PS:不区分大小写)都重定向到/testpage.txt请求,也就是 /usr/local/nginx/html/testpage.txt 文件
  (2)使用alias关键字:
  location ——* ^/test/(\d+)/[\w-.]+$ {
  alias /usr/local/nginx/html/static/sta1.html;
  }
  这里将所有符合条件的URL(PS:不区分大小写)都重定向到/usr/local/nginx/html/static/sta1.html 文件
  原文链接:http://www.iis7.com/a/nr/292755.html

猜你喜欢

转载自blog.csdn.net/weixin_44400506/article/details/86298695
0条评论
添加一条新回复