nginx路径匹配踩坑

24 篇文章 0 订阅
23 篇文章 0 订阅
nginx路径匹配踩坑
  • 页面403 Forbidden errors

原因: 权限问题,查看日志:*1 open() “/root/a.jpg” failed (13: Permission denied)

解决:nginx.conf 中加入user root;
在这里插入图片描述

  • 页面 404 Not Found

原因: 这里我用的正则匹配, 表达式是location ~ .(gif|jpg|png|js|css)$匹配任意的以gif、jpg、png、js、css结尾的路径,
我输入的地址是: ip:端口/1.jpg ,匹配上了怎么会找不到报404呢?因为
nginx会去location中的root指向的目录里找1.jpg
, 而我目录里没有这个文件

解决: 如此如此这般这般…
在这里插入图片描述

补充:
在这里插入图片描述
如果请求的URI是/t/xxd/test.jpg时候,会去/www/root/htm/new_t/xxd/test.jpg


在这里插入图片描述

location = / {
  # 精确匹配 / ,主机名后面不能带任何字符串
  [ configuration A ]
}
location / {
  # 因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求
  # 但是正则和最长字符串会优先匹配
  [ configuration B ]
}
location /documents/ {
  # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
  # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
  [ configuration C ]
}
location ~ /documents/Abc {
  # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
  # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
  [ configuration CC ]
}
location ^~ /images/ {
  # 匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条。
  [ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
  # 匹配所有以 gif,jpg或jpeg 结尾的请求
  # 然而,所有请求 /images/ 下的图片会被 config D 处理,因为 ^~ 到达不了这一条正则
  [ configuration E ]
}
location /images/ {
  # 字符匹配到 /images/,继续往下,会发现 ^~ 存在
  [ configuration F ]
}
location /images/abc {
  # 最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在
  # F与G的放置顺序是没有关系的
  [ configuration G ]
}
location ~ /images/abc/ {
  # 只有去掉 config D 才有效:先最长匹配 config G 开头的地址,继续往下搜索,匹配到这一条正则,采用
  [ configuration H ]
}
/ -> config A  #精确完全匹配,即使/index.html也匹配不了
/downloads/download.html -> config B    #匹配B以后,往下没有任何匹配,采用B
/images/1.gif -> configuration D   # 匹配到F,往下匹配到D,停止往下
/images/abc/def -> config D  #最长匹配到G,往下匹配D,停止往下                      可以看到 任何以/images/开头的都会匹配到D并停止,FG写在这里是没有任何意义的,H是永远轮不到的,这里只是为了说明匹配顺序
/documents/document.html -> config C    #匹配到C,往下没有任何匹配,采用C
/documents/1.jpg -> configuration E     #匹配到C,往下正则匹配到E
/documents/Abc.jpg -> config CC    #最长匹配到C,往下正则顺序匹配到CC,不会往下到E

配置rewrite last时,请求跳出当前location,进入server块,重新进行location匹配,超过10次匹配不到报500错误。客户端的url不变.

配置rewrite break时,请求不会跳出当前location,但资源匹配会按照重写后的url进行,如果location里面配置的是proxy_pass到后端,后端服务器收到的请求url也会是重写后的url。客户端的url不变。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
nginx中,location指令用于匹配请求的URI,以便决定如何处理这个请求。location指令可以接受一个字符串参数,也可以接受一个正则表达式作为参数。 以下是nginx location的路径匹配规则: 1. 以“=”开头的location指令表示严格匹配,只有当请求的URI与location指令的参数完全一致时,才会匹配成功。 2. 如果location指令的参数是一个目录名称,例如“/user/”,那么匹配规则如下: - 如果请求的URI是“/user/”,那么匹配成功。 - 如果请求的URI是“/user”(没有斜杠结尾),那么nginx会自动将其转换为“/user/”,然后再进行匹配。 - 如果请求的URI是“/user/login”,那么匹配成功,因为“/user/login”包含“/user/”这个目录名称。 3. 如果location指令的参数是一个正则表达式,例如“~^/user/(.*)$”,那么匹配规则如下: - 如果请求的URI与正则表达式匹配成功,那么这个location指令就匹配成功。 - 正则表达式中可以使用捕获组,例如“~^/user/(\d+)/(\w+)$”表示匹配形如“/user/123/abc”的URI,并将“123”和“abc”作为变量传递给后端处理程序。 4. 如果location指令的参数是“/”,那么这个location指令会匹配所有请求。 5. 如果存在多个location指令,nginx会按照定义的顺序依次进行匹配,直到找到第一个匹配成功的location指令为止。 需要注意的是,nginx的location匹配规则是从上到下依次匹配的,一旦匹配成功就不再继续匹配。因此,如果存在多个location指令,需要注意定义的顺序,避免出现匹配错误的情况。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值