I would like to serve SNI-enabled clients that send the wrong host name a 400 Bad Request, but Apache always serves the default virtual host in this situation. I cannot add a default virtual host that sends the 400 Bad Request status, because SNI-disabled clients will always get this virtual host.
It seems that the ServerName virtual host directive is ignored for SNI-disabled clients when I enable name based virtual hosts on an SNI-enabled Apache installation.
See the following virtual host configuration:
NameVirtualHost 192.168.4.46:443 <VirtualHost 192.168.4.46:443> ServerName 192.168.4.46 DocumentRoot /var/www/error-page/ SSLEngine on SSLCertificateFile /path/to/certificate.crt SSLCertificateKeyFile /path/to/certificate.key </VirtualHost> <VirtualHost 192.168.4.46:443> ServerName test-ssl DocumentRoot /var/www/valid-website/ SSLEngine on SSLCertificateFile /path/to/certificate.crt SSLCertificateKeyFile /path/to/certificate.key </VirtualHost> If I use an SNI-disabled client, I would get the error page regardless of the Host: header I send in the request. Because I use the same certificate in both virtual hosts, I would like SNI-disabled clients to be able to still reach the second virtual host based on a match with ServerName.
If I'd switch the position of the virtual hosts, the website would be the default virtual host and then SNI-enabled clients would get the website instead of the error if they supply a wrong Host: in the headers.
So basically, how do I get Apache to serve an error for every wrong Host: header regardless of SNI support, while still serving the website when using an SNI-disabled client and serving the right virtual host when using an SNI-enabled client?
Hostheader sent by an SNI-disabled client should still be respected, which I've found to be the case in my testing - the default virtual host just selects what certificate is sent to SNI-disabled clients. Are you saying you're seeing it being served the wrong vhost in your testing, or are you just theorizing that it would be wrong?Hostheader. I think my tests were flawed.