У меня есть система Ubuntu 18.04 под управлением apache2 и SSL от LetsEncrypt. Также я подключил доменное имя к моему серверу. Я пытался изменить права доступа и владельцев папок, но независимо от того, что я делаю, я все равно получаю ошибку 403 Forbidden, когда пытаюсь получить доступ к своему домену (это автоматически перенаправляет к https между прочим). Вот файлы конфигурации (я заменяю свой домен на sample-domain.eu ниже):
apache2.conf:
DefaultRuntimeDir ${APACHE_RUN_DIR}
PidFile ${APACHE_PID_FILE}
Timeout 300
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 5
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}
HostnameLookups Off
ErrorLog ${APACHE_LOG_DIR}/error.log
LogLevel warn
IncludeOptional mods-enabled/*.load
IncludeOptional mods-enabled/*.conf
Include ports.conf
<Directory />
Options FollowSymLinks
AllowOverride All
Require all denied
</Directory>
<Directory /usr/share>
AllowOverride All
Require all granted
</Directory>
AccessFileName .htaccess
<FilesMatch "^\.ht">
Require all denied
</FilesMatch>
LogFormat "%v:%p %h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" vhost_combined
LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %O" common
LogFormat "%{Referer}i -> %U" referer
LogFormat "%{User-agent}i" agent
IncludeOptional conf-enabled/*.conf
IncludeOptional sites-enabled/*.conf
Envvars:
unset HOME
if [ "${APACHE_CONFDIR##/etc/apache2-}" != "${APACHE_CONFDIR}" ] ; then
SUFFIX="-${APACHE_CONFDIR##/etc/apache2-}"
else
SUFFIX=
fi
export APACHE_RUN_USER=www-data
export APACHE_RUN_GROUP=www-data
export APACHE_PID_FILE=/var/run/apache2$SUFFIX/apache2.pid
export APACHE_RUN_DIR=/var/run/apache2$SUFFIX
export APACHE_LOCK_DIR=/var/lock/apache2$SUFFIX
export APACHE_LOG_DIR=/var/log/apache2$SUFFIX
export LANG=C
export LANG
/sites-enabled/000-default.conf
<VirtualHost *:80>
ServerAdmin webmaster@sample-domain.eu
DocumentRoot /var/www/sample-domain.eu/public_html
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
/sites-enabled/sample-domain.eu.conf
<VirtualHost *:80>
ServerName sample-domain.eu
ServerAlias www.sample-domain.eu
ServerAdmin webmaster@sample-domain.eu
DocumentRoot /var/www/sample-domain.eu/public_html
<Directory /var/www/sample-domain.eu/public_html>
Options -Indexes +FollowSymLinks
AllowOverride All
</Directory>
ErrorLog ${APACHE_LOG_DIR}/sample-domain.eu-error.log
CustomLog ${APACHE_LOG_DIR}/sample-domain.eu-access.log combined
RewriteEngine on
RewriteCond %{SERVER_NAME} =sample-domain.eu [OR]
RewriteCond %{SERVER_NAME} =www.sample-domain.eu
RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]
</VirtualHost>
sites-enabled / sample-domain.eu -le-ssl.conf
<IfModule mod_ssl.c>
<VirtualHost *:443>
ServerName sample-domain.eu
ServerAlias www.sample-domain.eu
ServerAdmin webmaster@sample-domain.eu
DocumentRoot /var/www/sample-domain.eu/public_html
<Directory /var/www/sample-domain.eu/public_html>
Options -Indexes +FollowSymLinks
AllowOverride All
</Directory>
ErrorLog ${APACHE_LOG_DIR}/sample-domain.eu-error.log
CustomLog ${APACHE_LOG_DIR}/sample-domain.eu-access.log combined
Include /etc/letsencrypt/options-ssl-apache.conf
SSLCertificateFile /etc/letsencrypt/live/sample-domain.eu/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/sample-domain.eu/privkey.pem
</VirtualHost>
</IfModule>
Также у меня есть файл index.html в /var/www/sample-domain.eu/public_html РЕДАКТИРОВАТЬ: забыл упомянуть, что у меня установлены phpmyadmin и webmin, и оба работая с их URL: / phpmyadmin /: 10000
Я заставил его работать, однако я не уверен - ли это безопасная опция сделать.
В /etc/apache2/apache2.conf
файл, я изменился, "Требуют, чтобы все отклоненные" "Потребовали всех предоставленных" здесь:
<Directory />
Options FollowSymLinks
AllowOverride All
Require all granted
</Directory>
я не уверен, почему это было установлено на все отклоненные, так как я не изменил его. Однако сервер теперь работает и больше не бросает ошибку 403.