所以我有一个使用https和websockets以及socket.io(带node.js)的网站。websocket最初会尝试直接连接
var socket = io('https://' + socket_ip_addr + ":8443",{'forceNew': true, 'secure': true});
这是我的socket.io代码(可以直接连接)
var http = require('https')
var fs = require('fs');
var options = {
key: fs.readFileSync('../certs/ssl.key'),
cert: fs.readFileSync('../certs/ssl.crt'),
};
var app = http.createServer(options)
var io = require('socket.io').listen(app);
app.listen(8443);
这工作得很好,但有些用户可能会因为任何原因而阻止该随机端口,所以我有一个后备方法,尝试将端口443与apache代理一起使用。
var socket = io('https://' + socket_ip_addr,{'forceNew': true, 'secure': true});
apache设置:
<VirtualHost *:443>
ServerName somewebsite.ca
ServerAlias somewebsite.ca
DocumentRoot /var/www/html
SSLEngine on
SSLCertificateFile ../certs/ssl.crt
SSLCertificateKeyFile ../certs/ssl.key
RewriteEngine on
RewriteCond %{REQUEST_URI} ^/socket.io [NC]
RewriteCond %{QUERY_STRING} transport=websocket [NC]
RewriteRule /(.*) wss://localhost:8443/$1 [P,L]
ProxyRequests off
ProxyPass /socket.io/ https://localhost:8443/socket.io/
ProxyPassReverse /socket.io/ https://localhost:8443/socket.io/
</VirtualHost>
在我切换到https之前,我经常这样做,一切都很好。现在我正在尝试使用https和wss,它给了我很好的ol'error500(内部服务器错误)
我真正的问题是:我该如何开始尝试和调试出了问题。我能看看一些标题吗?我可以在中间步骤的某个位置打印一些消息吗?
谢谢。
好的。。我只是个傻瓜。我检查了apache日志并添加了一些额外的命令,现在它可以正常工作了。其他内容包括:
SSLProxyEngine on //apache log told me about this
SSLProxyVerify none
SSLProxyCheckPeerCN off
SSLProxyCheckPeerName off
SSLProxyCheckPeerExpire off
RequestHeader set Front-End-Https "On"