It's been a while since I used the Apache httpd web server. I'm firing up a local server for a project and when I try to request localhost/index.html, I get a 500 error and I see this in the error log:
[Tue Jan 21 09:23:58 2014] [crit] [client ::1] configuration error: couldn't perform authentication. AuthType not set!: /index.html
[Tue Jan 21 09:23:58 2014] [error] an unknown filter was not added: DEFLATE
[Tue Jan 21 09:23:58 2014] [crit] [client ::1] configuration error: couldn't perform authentication. AuthType not set!: /favicon.ico
It looks like there are possibly 2 errors here in the apache config, one related to "AuthType not set!" and possibly another related to "filter was not added: DEFLATE". I dont know what these means or where to start digging in.
A basic Google search revealed this link which indicates that the culprit may be "Require all granted". This line in my httpd.conf may be involved.
<Directory "/var/www">
AllowOverride None
# Allow open access:
Require all granted
</Directory>
This apache config is mostly what is used in production for this project, so I know this works, just not currently on my workstation. What does this mean and what should I try next? I did try commenting out "Require all granted" and restarting apache but to no avail.
Following this SO question I also loaded mod_authz_host
LoadModule authz_host_module modules/mod_authz_host.so
and added "Allow from all", restarted the server,. but the issue persists. The deflate issue appears to be unrelated, and was easily solved by adding
LoadModule deflate_module modules/mod_deflate.so
The question remains, how do I solve this 500 error?
[Tue Jan 21 09:44:20 2014] [crit] [client ::1]
configuration error: couldn't perform authentication.
AuthType not set!: /index.html
Remove the line that says
Require all granted
it's only needed on Apache >=2.4
The problem here can be formulated another way: how do I make a config that works both in apache 2.2 and 2.4?
Require all granted
is only in 2.4, but Allow all ...
stops working in 2.4, and we want to be able to rollout a config that works in both.
The only solution I found, which I am not sure is the proper one, is to use:
# backwards compatibility with apache 2.2
Order allow,deny
Allow from all
# forward compatibility with apache 2.4
Require all granted
Satisfy Any
This should resolve your problem, or at least did for me. Now the problem will probably be much harder to solve if you have more complex access rules...
See also this fairly similar question. The Debian wiki also has useful instructions for supporting both 2.2 and 2.4.
Alternatively, this solution works with both Apache2 version < 2.4 as well as >= 2.4. Make sure that the "version" module is enabled:
a2enmod version
And then use this code instead:
<IfVersion < 2.4>
Allow from all
</IfVersion>
<IfVersion >= 2.4>
Require all granted
</IfVersion>
Just remove/comment the following line from your httpd.conf file (etc/httpd/conf)
Require all granted
This is needed till Apache Version 2.2 and is not required from thereon.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With