【nginx】不解的nginx rewrite规则

【nginx】不解的nginx rewrite规则

上图是我根据nginx最长匹配原则 配置的简单范例, 目的是访问 / 的时候全部拒绝, 但访问 /hello 的时候能进行正常跳转. 但是返现, 访问 /hello 依旧403, 但是重写日志里面记录 nginx确实匹配到了我的规则, 为何还是返回给我403呢? 求大神解惑, 不甚感激!

回答

location / 可以匹配到所有的请求

你可以如下修改

 location = / {

deny all;

}

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

因为rewrite之后的 /test00 匹配到了 location /

你应该加一个 location ~ ^/test00 并开放访问权限

以上是 【nginx】不解的nginx rewrite规则 的全部内容, 来源链接: utcz.com/a/85789.html

回到顶部