HTTP + HTTPS + www + non-www Конфигурация Apache

В моей конфигурации Apache все перенаправлено на HTTPS (что хорошо). Но оба https://www.example.com а также https://example.com все-еще существует.

Вопрос: как иметь только https://www.example.com а не без www?

Должен ли я использовать 301 Redirection или другая техника?

Как изменить такую ​​конфигурацию:

<VirtualHost *:80>
  ServerName example.com
  ServerAlias *.example.com
  RewriteEngine on
  RewriteCond %{HTTPS} !on
  RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI}
</VirtualHost>

<IfModule mod_ssl.c>
<VirtualHost *:443>
  ServerName example.com
  ServerAlias *.example.com
  DocumentRoot /home/www/example
  <Directory />
    Options FollowSymLinks
    AllowOverride All
    Order deny,allow
    Allow from all
    Require all granted
  </Directory>
  SSLCertificateFile /etc/letsencrypt/live/example.com/cert.pem
  SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
  Include /etc/letsencrypt/options-ssl-apache.conf
  SSLCertificateChainFile /etc/letsencrypt/live/example.com/chain.pem
</VirtualHost>
</IfModule>

?

2 ответа

Решение

Один из способов сделать это - изменить текущий виртуальный хост. ServerName www.example.com и добавьте новый виртуальный хост для не-www

<VirtualHost *:443> ServerName example.com Redirect 301 / https://www.example.com/ </VirtualHost>

Ответ Relymcd решил проблему, но он также должен иметь строки сертификата (если не потерпит неудачу):

<VirtualHost *:443>
    ServerName example.com
    Redirect 301 / https://www.example.com/
    SSLCertificateFile /etc/letsencrypt/live/example.com/cert.pem
    SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
    Include /etc/letsencrypt/options-ssl-apache.conf
    SSLCertificateChainFile /etc/letsencrypt/live/example.com/chain.pem
</VirtualHost>
Другие вопросы по тегам