Назад | Перейти на главную страницу

Как мне найти причину цикла перенаправления http на https?

Недавно я установил 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).