Apache抛出401未经授权

问题描述 投票:2回答:1

这是我的VirtualHost配置:

<VirtualHost *:80>

     ServerName example.com
     DocumentRoot /var/www/example.com/public

     <Directory /var/www/example.com/public>
             Options +FollowSymLinks
             AllowOverride All
             Require user user1 user2
     </Directory>

     <Location /error/401>
             Require all granted
     </Location>

     ErrorLog ${APACHE_LOG_DIR}/example.com.error.log
     LogLevel warn
     CustomLog ${APACHE_LOG_DIR}/example.com.access.log combined

     ErrorDocument 500 /error/500
     ErrorDocument 404 /error/404
     ErrorDocument 401 /error/401

</VirtualHost>

但是当我故意使身份验证失败(或直接打开/ error / 401)时,我得到了:]

Unauthorized

This server could not verify that you are authorized to access the document requested. Either you supplied the wrong credentials (e.g., bad password), or your browser doesn't understand how to supply the credentials required.

Additionally, a 401 Unauthorized error was encountered while trying to use an ErrorDocument to handle the request.

我做错了什么?根据下面链接的文档,Location应该在Directory之后处理,这样才可以工作。

http://httpd.apache.org/docs/current/sections.html#merging

编辑:

很明显,这是有问题的部分:

Additionally, a 401 Unauthorized error was encountered while trying to use an ErrorDocument to handle the request.

这是我的VirtualHost配置:ServerName example.com DocumentRoot /var/www/example.com/public ...

apache location virtualhost unauthorized errordocument
1个回答
0
投票

我遇到了一个非常相似的问题。关键的实际问题是,在站点的DocumentRoot级别上身份验证失败时,无法访问位于DocumentRoot(即/ error / 401)下方的自定义错误页面,因此将发出默认的Apache错误消息。

© www.soinside.com 2019 - 2024. All rights reserved.