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 并开放访问权限