Hello, You may need to use SSLProxyCheckPeerCN / SSLProxyCheckPeerName off
From: Weare Borg [mailto:kernelfr...@gmail.com] Sent: 25 August 2017 09:14 To: users@httpd.apache.org Subject: [users@httpd] Websockets not working with Apache proxypass, keep getting 400. Distribution : Debian server. 3.2.0-4-amd64 #1 SMP Debian 3.2.73-2+deb7u2 x86_64 GNU/Linux Server version: Apache/2.2.22 (Debian) Hello friends, I am working on integrating Websocket based functionality into our Spring-MVC application. It works on my localhost, where I neither have SSL, nor apache web server with ProxyPass. We have a library called cometd which supports websocket functionality which we are trying to make it work. When I add it on the server, the situation changes, with proxypass, whenever I try to make the connection from https go to wss, it doesn't work and I keep getting a 400. What am I doing wrong? I had added the same question on SO, but didn't got any good answer even after a bounty, hoping something more would be here. Question link : QuestionLink<https://stackoverflow.com/questions/45275229/apacheserver-proxypass-websockets-not-working-url-changed-to-https-instead-o> 000-default.conf <VirtualHost *:443> ServerName www.oursite.de<http://www.oursite.de> ServerAlias oursite.de<http://oursite.de> ProxyRequests off ProxyPreserveHost On <Proxy https://www.oursite.de:8444/> Order deny,allow Allow from all </Proxy> ProxyPass /nagios ! ProxyReceiveBufferSize 4096 ErrorDocument 503 /error/message.html ProxyPass /error/ ! ProxyPass /error/message.html ! SSLEngine on SSLProxyEngine on SSLCertificateFile /etc/letsencrypt/live/www.oursite.de-0002/cert.crt SSLCertificateKeyFile /etc/letsencrypt/live/www.oursite.de-0002/private.key SSLCertificateChainFile /etc/letsencrypt/live/www.oursite.de-0002/chain.pem ProxyPass / https://localhost:8444/ ProxyPassReverse / https://localhost:8444/ ProxyPass /cometd/ wss://localhost:8444/cometd/ ProxyPassReverse /cometd wss://localhost:8444/cometd/ <Location / > Order allow,deny Allow from all </Location> </VirtualHost> As we have 3 different applications running on the same server, application running on port 8444 is the one where we have cometd instance running. The URL is always /cometd, and it's calculated in this manner : var cometURL = location.protocol + "//" + location.host+ config.contextPath + "/cometd"; If there is anything else required. Kindly let me know. Thanks.