我有一个按照这个例子构建的简单 websocket 服务器
import { createServer, Server } from 'http';
import * as express from 'express';
import * as socketIo from 'socket.io';
export class MobileObjectServer {
public static readonly PORT:number = 8081;
private app: express.Application;
private server: Server;
private io: socketIo.Server;
private port: string | number;
constructor() {
this.createApp();
this.config();
this.createServer();
this.sockets();
this.listen();
}
private createApp() {
this.app = express();
}
private createServer() {
this.server = createServer(this.app);
}
private config() {
this.port = process.env.PORT || MobileObjectServer.PORT;
}
private sockets() {
this.io = socketIo(this.server);
}
private listen() {
this.server.listen(this.port, () => {
console.log('Running server on port %s', this.port);
});
this.io.on('connect', (socket: any) => {
console.log('Connected client on port %s.', this.port);
socket.on('message', m => {
console.log('[server](message): %s', JSON.stringify(m));
this.io.emit('message', m);
});
socket.on('disconnect', () => {
console.log('Client disconnected');
});
});
}
public getApp(): express.Application {
return this.app;
}
}
这段代码运行流畅。我可以在我的机器上启动 websocket 服务器,如果我使用socket.io-client库,我可以连接。
现在我想使用 RxJs 提供的webSocket
和工具从客户端连接到这样的服务器,WebSocketSubject
但我在尝试连接时遇到了一些基本问题。
如果我做
import { webSocket } from 'rxjs/observable/dom/webSocket';
webSocket('http://localhost:8081')
没有任何反应,没有建立连接。
如果我'ws://localhost:8081'
用作连接字符串,那么我会收到这样的错误
WebSocketSubject.js:142 WebSocket connection to 'ws://localhost:8081/' failed: Connection closed before receiving a handshake response
我确信我犯了一个非常基本的错误,但我目前不知道在哪里。