2017-01-19 5 views
0

Я разместил сайт на VPS с использованием Apache Virtual Server, так как я планирую разместить еще несколько сайтов на этом VPS позже. Виртуальный хост работал правильно, пока я не установил SSL на нем с помощью LetsEncrypt Certbot. После этого https://techkernel.org отлично работает, но http-вариант, http://techkernel.org перенаправляется на веб-страницу Apache по умолчанию. Конфигурации виртуального хоста не работают должным образом, и они попадают в каталог по умолчанию/var/www/html.Apache Virtual Host: HTTP получает перенаправление на сайт Apache по умолчанию

Если вы могли бы рассказать мне, как исправить это, чтобы как HTTP, так и HTTPS-запросы перенаправлялись на HTTPS, а также отображали правильный веб-сайт, это было бы очень полезно. Спасибо.

Соответствующая информация:

и т.д./apache2/сайты-доступные/techkernel.org.conf

<VirtualHost *:80> 
    # The ServerName directive sets the request scheme, hostname and port that 
    # the server uses to identify itself. This is used when creating 
    # redirection URLs. In the context of virtual hosts, the ServerName 
    # specifies what hostname must appear in the request's Host: header to 
    # match this virtual host. For the default virtual host (this file) this 
    # value is not decisive as it is used as a last resort host regardless. 
    # However, you must set it for any further virtual host explicitly. 
    ServerName www.techkernel.org 

    ServerAdmin [email protected] 
    DocumentRoot "/var/www/techkernel.org/public" 

    ServerAlias techkernel.org 

    # Available loglevels: trace8, ..., trace1, debug, info, notice, warn, 
    # error, crit, alert, emerg. 
    # It is also possible to configure the loglevel for particular 
    # modules, e.g. 
    #LogLevel info ssl:warn 

    ErrorLog ${APACHE_LOG_DIR}/error.log 
    CustomLog ${APACHE_LOG_DIR}/access.log combined 

    # For most configuration files from conf-available/, which are 
    # enabled or disabled at a global level, it is possible to 
    # include a line for only one particular virtual host. For example the 
    # following line enables the CGI configuration for this host only 
    # after it has been globally disabled with "a2disconf". 

    Include conf-available/serve-cgi-bin.conf 
    RewriteEngine on 
    RewriteCond %{SERVER_NAME} =www.techkernel.org [OR] 
    RewriteCond %{SERVER_NAME} =techkernel.org 
    RewriteRule^https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent] 

</VirtualHost> 

# vim: syntax=apache ts=4 sw=4 sts=4 sr noet 

вар/WWW/techkernel.org/государственные/.htaccess

# BEGIN WordPress 
<IfModule mod_rewrite.c> 
RewriteEngine On 
RewriteCond %{HTTPS} off 
RewriteRule (.*) https://%{SERVER_NAME}/%$1 [R,L] 

RewriteBase/
RewriteRule ^index\.php$ - [L] 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteRule . /index.php [L] 
</IfModule> 

# END WordPress 

ls -l/e дц/apache2/сайты с поддержкой

lrwxrwxrwx 1 root root 35 Dec 28 11:08 000-default.conf -> ../sites-available/000-default.conf 
lrwxrwxrwx 1 root root 38 Jan 21 04:31 techkernel.org.conf -> ../sites-available/techkernel.org.conf 
lrwxrwxrwx 1 root root 55 Dec 28 19:46 techkernel.org-le-ssl.conf -> /etc/apache2/sites-available/techkernel.org-le-ssl.conf 

Ls -l/и т.д./apache2/сайты с поддержкой

-rw-r--r-- 1 root root 1332 Jul 5 2016 000-default.conf                           
-rw-r--r-- 1 root root 6437 Aug 7 10:56 default-ssl.conf                           
-rw-r--r-- 1 root root 1574 Jan 19 16:05 techkernel.org.conf                           
-rw-r--r-- 1 root root 1613 Dec 28 19:46 techkernel.org-le-ssl.conf 

ответ

0

Ну, оказалось, что 000-default.conf испортился. И это дошло до моего сведения только после запуска команды apachectl -S. После его исправления (ввода правильных ServerName и DocumentRoot, а также некоторых условий перезаписи URL) и reload ing apache2, он отлично работает.

0

Вы вставили свой конфиг в качестве образца из сайтов Недоступные. Вы связали его с сайтами - ENABLED, на самом деле, вы знаете, включите его?

Редактировать - извините, это казалось излишним snippy. Я хочу сказать, что ваш вариант HTTPS работает и находится в отдельном файле конфигурации. Ваш HTTP-код не соответствует мне, потому что вы не создали эту символическую ссылку, поэтому Apache не имеет конфигурации для «того, что вы делаете, когда получаете запрос на порт 80 с заголовком Host: set, установленным на techkernel.org», поэтому он попадая на сайт по умолчанию. Ваша конфигурация в противном случае выглядит отлично для меня, она просто не используется Apache.

+0

Я новичок в них. Как создать символическую ссылку? – SkullTech

+0

@SkullTech a2ensite techkernel.org – scampbell

+0

@scampbell Это не работает. Сначала он сказал, что «Сайт techkernel.org уже включен». Поэтому я 'a2dissite''d, а затем снова« a2ensite ». И перезагрузили 'apache2'. Но результата нет. – SkullTech

0

Кроме ошибки вы, может быть найден в вашем 000-default.conf следующие проблемы были в правилах перезаписи:

RewriteEngine on 
RewriteCond %{SERVER_NAME} =www.techkernel.org [OR] 
RewriteCond %{SERVER_NAME} =techkernel.org 
RewriteRule^https://%{SERVER_NAME}%{REQUEST_URI} [END,QSA,R=permanent] 

должен быть

RewriteEngine on 
RewriteCond %{HTTP_HOST} ^(www\.)?techkernel.org 
RewriteRule ^/(.*) https://%{HTTP_HOST}/$1 [NC,R=301,L] 

%{SERVER_NAME} может быть значение из Конфигурация VirtualHost, если установлено UseCanonicalName On. Таким образом, он перенаправляет все независимо от того, какой URI используется посетителем. Если это намерение, то просто удалите RewriteCond и использовать

RewriteEngine on 
RewriteRule ^/(.*) https://www.techkernel.org/$1 [NC,R=301,L] 

Если фиксирована, вы можете/должны удалить все записи об этом в вашем.htaccess

RewriteCond %{HTTPS} off 
RewriteRule (.*) https://%{SERVER_NAME}/%$1 [R,L]