Недавно я установил owncloud на новом компьютере (Apache / 2.4.10 Debian). Это было до того, как я получил ssl-сертификат через Let's Encrypt. Я пытался заставить http на https, но всегда получаю петли перенаправления. Я погуглил и попытался добавить:
Redirect permanent / https://www.example.com
Это не устранило проблему.
Моя текущая конфигурация выглядит так:
<VirtualHost *:80>
ServerAdmin webmaster@localhost
ServerName www.example.com
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI}
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
<VirtualHost *:443>
ServerName www.example.com
DocumentRoot /var/www/owncloud
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
Это тоже дает мне цикл перенаправления.
Кроме того, если я оставлю только *:80
виртуальный хост и удалите часть перезаписи, я могу получить доступ к обоим http
и https
без проблем. Так что у меня это получилось.
Запрошенный раздел дополнительной информации
apachectl -S
вывод:
VirtualHost configuration:
*:80 www.example.com (/etc/apache2/sites-enabled/ssl-owncloud.conf:1)
*:443 www.example.com (/etc/apache2/sites-enabled/ssl-owncloud.conf:14)
ServerRoot: "/etc/apache2"
Main DocumentRoot: "/var/www/html"
Main ErrorLog: "/var/log/apache2/error.log"
Mutex rewrite-map: using_defaults
Mutex default: dir="/var/lock/apache2" mechanism=fcntl
Mutex mpm-accept: using_defaults
Mutex watchdog-callback: using_defaults
PidFile: "/var/run/apache2/apache2.pid"
Define: DUMP_VHOSTS
Define: DUMP_RUN_CFG
User: name="www-data" id=33
Group: name="www-data" id=33
Проверьте свою конфигурацию owncloud (/var/www/owncloud/config/config.php
) и ищите 'forcessl' => true,
, и поместите его в false
. Это опция owncloud для перенаправления трафика http на https без какого-либо кода перезаписи apache.
Надеюсь, это вам поможет.
Сообщенные конфигурации в порядке. Возможно ли, что другие определения виртуального хоста скрываются?
Вы бы хотели убедиться:
sudo apache2ctl -t -DDUMP_VHOSTS
затем? Разумный вывод:
VirtualHost configuration:
*:80 www.example.org (/etc/apache2/sites-enabled/000-default.conf:1)
*:443 www.example.org (/etc/apache2/sites-enabled/default-ssl.conf:4)
(где: 1 и: 4 - номер строки, в которой определен vhost).