Muszę skonfigurować mój VirtualHost na Apache, aby obsługiwał zarówno HTTP, jak i https (używając standardowych portów)
Jeśli włączę silnik SSL (jak poniżej) - na porcie 80 pojawia się błąd.
Powodem jest to, że części witryny muszą być SSL, ale inne nie. Jak mogę zacząć wyświetlać zarówno http + https w witrynie?
Oto mój wirtualny plik hosta ....
NameVirtualHost *
<VirtualHost *>
ServerAdmin webmaster@localhost
ServerName mysite.co.uk
DocumentRoot /var/www/mysite/public
<Directory />
Options FollowSymLinks
AllowOverride None
</Directory>
<Directory /var/www/mysite/public>
Options Indexes FollowSymLinks MultiViews
AllowOverride All
Order allow,deny
allow from all
</Directory>
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
ErrorLog /var/log/apache2/error.log
# Possible values include: debug, info, notice, warn, error, crit,
# alert, emerg.
LogLevel warn
CustomLog /var/log/apache2/access.log combined
ServerSignature On
Alias /doc/ "/usr/share/doc/"
<Directory "/usr/share/doc/">
Options Indexes MultiViews FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
Allow from 127.0.0.0/255.0.0.0 ::1/128
</Directory>
#SSL STUFF...
SSLEngine on
SSLCertificateFile /etc/apache2/crts/mysite.crt
SSLCertificateKeyFile /etc/apache2/crts/mysite.key
SSLCertificateChainFile /etc/apache2/crts/DigiCertCA.crt
</VirtualHost>
źródło
UseCanonicalPhysicalPort Off
. Jeśli włączysz tę opcję, prawdopodobnie użyjesz faktycznego portu. (Co zabawne, musiałem zrezygnować zSSLEngine On
mojego podwójnie używanego vhosta i jako domyślny dostałem port 80.)%{HTTPS}
również zostanie ustawiony poprawnie, ale%{REQUEST_SCHEME}
nie jest (zawszehttp
). Głupio byłoby jednak zgłosić prośbę oUseCanonicalRequestScheme
dyrektywę.