【问题标题】:Chrome WebSocket connection closes immediatelyChrome WebSocket 连接立即关闭
【发布时间】:2022-07-30 03:25:44
【问题描述】:

我一直在尝试使用 nodejs 设置 wss 服务器,但在尝试使用 chrome 连接到它时遇到了问题。禁用所有扩展程序并在隐身窗口中仍然会出现此问题,因此我已将其排除为问题。

尝试使用 chrome 连接时,出现错误:

WebSocket connection to 'wss://www.domain-name.com/' failed:

没有给出任何理由。在服务器上,socket.on('close') 被立即调用,描述为“远程对等点断开连接”关闭事件有 wasClean = false。从 safari 和 Firefox 连接时不会发生此错误,因此我不确定在哪里查看导致它的原因。它在 AWS Lightsail 上运行,并通过 Apache 代理服务器。

客户端代码:

var socket = new WebSocket("wss://www.domain-name.com", 'JSON')
socket.onopen = function (event) {
    console.log('open');
    socket.send('socket opened')};

socket.onclose = function (event) {
    console.log(event)};

socket.onmessage = function(message) {
    console.log('receiving message from server...')};

以及服务器代码:

const WebSocketServer = require('websocket').server;
app = express()
var server = app.listen(3000, () => {
    console.log('Server started');
});

app.use(express.static('public'));

var wsServer = new WebSocketServer({
    httpServer: server
});

wsServer.on('request', function(request){
    console.log('New connection');
    var connection = request.accept(null, request.origin);

    connection.send('welcome from server...');

    connection.on('message', function(message){
        console.log(message)};

    connection.on('close', function(reasonCode, description) {
        console.log('disconnecting', reasonCode, description);
        });
});

在切换到安全的 WebSocket 服务器之前,我也遇到了同样的错误。任何帮助将不胜感激,我已经没有地方可以寻找和尝试获取更多信息以帮助解决问题的方法了。

编辑:它似乎适用于我手机上的 chrome,但不适用于我朋友手机上的 chrome?

【问题讨论】:

    标签: javascript node.js apache google-chrome websocket


    【解决方案1】:

    问题在于接受连接时未指定协议。在处理相同的错误并实施 SSL 证书以使其正常工作大约 20 小时后,我进行了更改:

    request.accept(null, request.origin);
    

    到:

    request.accept('json', request.origin);
    

    由于某种原因,chrome 提供了一个非常无用的错误消息。 Microsoft edge 发生了同样的错误,但提供了更有用的错误消息,因此我可以弄清楚发生了什么。

    【讨论】:

      【解决方案2】:

      在我的例子中,这是由于将未使用的 options 值作为第三个参数传递给 WebSocket 构造函数引起的。 Node.js 的 ws 模块支持 options 参数,但 not by browsers;但是,Chrome 没有显示干净的错误消息,而是关闭了连接,并没有给出很好的描述。

      【讨论】:

        猜你喜欢
        • 2017-03-20
        • 2018-11-09
        • 2020-04-22
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2022-07-27
        • 2016-12-08
        • 2016-04-02
        相关资源
        最近更新 更多