ssl的Websocket apache代理问题



所以我有一个使用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"

相关内容

  • 没有找到相关文章

最新更新