node.js - 连接到 websocket NodeJS Express 服务器时出错

标签 node.js express websocket ws

我有一个配置了 Websocket 的 Express 服务器:

/tmp/ws-test $ cat httpServer.js
const express = require('express');
const WebSocket = require('ws');

const app = express();
const port = 8080;

app.get('/', function(req, res, next) {
  return res.send('Hello World!');
});

const wss = new WebSocket.Server({ server: app });

wss.on('connection', function connection(ws) {
  ws.on('message', function incoming(message) {
    console.log('received: %s', message);
  });
  ws.send('something from server');
});

app.listen(port, function(err) {
  if (err) {
    throw err;
  }
  console.log(`listening on port ${port}!`);
});

它按预期运行:

/tmp/ws-test $ node httpServer.js
listening on port 8080!

我有一个客户:

/tmp/ws-test $ cat client.js
const WebSocket = require('ws');

const ws = new WebSocket('ws://localhost:8080');

ws.on('open', function open() {
  ws.send('something from client');
});

ws.on('message', function incoming(data) {
  console.log(`received: ${data}`);
});

错误:

/tmp/ws-test $ node client.js
events.js:180
      throw er; // Unhandled 'error' event
      ^

Error: Unexpected server response: 200
    at ClientRequest.<anonymous> (/private/tmp/ws-test/node_modules/ws/lib/websocket.js:579:7)
    at ClientRequest.emit (events.js:203:13)
    at HTTPParser.parserOnIncomingClient [as onIncoming] (_http_client.js:575:27)
    at HTTPParser.parserOnHeadersComplete (_http_common.js:116:17)
    at Socket.socketOnData (_http_client.js:449:22)
    at Socket.emit (events.js:203:13)
    at addChunk (_stream_readable.js:295:12)
    at readableAddChunk (_stream_readable.js:276:11)
    at Socket.Readable.push (_stream_readable.js:210:10)
    at TCP.onStreamRead (internal/stream_base_commons.js:166:17)
Emitted 'error' event at:
    at abortHandshake (/private/tmp/ws-test/node_modules/ws/lib/websocket.js:697:15)
    at ClientRequest.<anonymous> (/private/tmp/ws-test/node_modules/ws/lib/websocket.js:579:7)
    [... lines matching original stack trace ...]
    at Socket.Readable.push (_stream_readable.js:210:10)

在客户端中,我还尝试使用 http 进行 Web 套接字连接。

const ws = new WebSocket('http://localhost:8080');

但它抛出了同样的错误。

为什么客户端在连接服务器时出错?

最佳答案

您应该将 http 服务器实例传递给 WebSocket.Server 构造函数,而不是 express 应用程序的实例:

const express = require('express');
const WebSocket = require('ws');
const http = require('http');

const app = express();
const port = 8080;

const server = http.createServer(app);

app.get('/', function(req, res, next) {
    return res.send('Hello World!');
});

const wss = new WebSocket.Server({ server });

wss.on('connection', function connection(ws) {
    ws.on('message', function incoming(message) {
        console.log('received: %s', message);
    });
    ws.send('something from server');
});

server.listen(port, function(err) {
    if (err) {
        throw err;
    }
    console.log(`listening on port ${port}!`);
});

关于node.js - 连接到 websocket NodeJS Express 服务器时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60230333/

相关文章:

node.js - 由于依赖问题, ionic 启动失败

angularjs - 在 AngularJS 应用程序中切换状态时,套接字事件会多次触发

javascript - 如何在 Nodejs 中查找所有用户的 geoip 位置

node.js - 为什么 mongoose.model.create 的回调不是从 Express 3.x HTTP 请求处理程序中执行(实际上 connect-mongodb 是原因)

java - 如何通过 WSO2(API 管理器)将自定义授权 header 传递到我的后端 Websocket 服务?

node.js - 如何将 Slack 机器人扩展到 1000 个团队

javascript - 我可以渲染动态内容并使用模板引擎(ejs)吗

javascript - 类型错误 : Object #<Socket> has no method 'set'

mongodb - Graphql 创建两个查询之间的关系。错误无法在初始化之前访问

php - XMPP (eJabberd) 如何为浏览器工作