我的网站的一部分受 auth_basic
保护:
location / {
auth_basic "Authorization Required";
auth_basic_user_file .htpasswd;
index app.php;
try_files $uri @rewriteapp;
}
对于未经授权的用户(点击“取消”的用户),我想显示一个自定义错误页面。这是我如何做到的:
error_page 401 = @error401;
location @error401 {
rewrite ^ /error/401.html redirect;
}
location /error {
expires max;
add_header Pragma public;
add_header Cache-Control "public";
index app.php;
try_files $uri @rewriteapp;
}
我必须创建@error401 别名,以便我可以指定“重定向”,因为如果我使用内部重定向,我的应用程序将处理原始请求(并允许访问实际请求的页面!)
所以这工作正常,页面显示。
问题是现在 nginx 甚至不要求用户提供凭据。
有没有什么办法解决这一问题 ?或者有什么更好的方法来处理这个问题?
最佳答案
这就是我能够完成您想要做的事情的方式:
## Path must be prefixed with a /, i.e. /401.html, NOT 401.html
error_page 401 /401.html;
location ~ (401.html)$ {
alias /usr/share/nginx/html/$1;
}
关于nginx - 自定义 401 页面不提示在 nginx 上输入凭据,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14501016/