84669인 학습
152542인 학습
20005인 학습
5487인 학습
7821인 학습
359900인 학습
3350인 학습
180660인 학습
48569인 학습
18603인 학습
40936인 학습
1549인 학습
1183인 학습
32909인 학습
上图是我根据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 并开放访问权限
location / 可以匹配到所有的请求
你可以如下修改
语法规则: location [=|~|~*|^~] /uri/ { … }
= 开头表示精确匹配
^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。
~ 开头表示区分大小写的正则匹配
~* 开头表示不区分大小写的正则匹配
!~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则
/ 通用匹配,任何请求都会匹配到
因为rewrite之后的 /test00 匹配到了 location /
你应该加一个 location ~ ^/test00 并开放访问权限