WebSocket是一种基于TCP的全双工通信协议,通过HTTP升级建立持久连接,实现客户端与服务器间的实时双向数据传输,适用于在线聊天、游戏等高频交互场景。其特点包括低开销、事件驱动机制,使用ws://或加密wss://协议,需注意连接管理、心跳检测及消息格式约定,配合Node.js、Java或Go等后端技术构建高效实时应用。

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议,允许客户端与服务器之间实时、双向地传输数据。相比传统的 HTTP 请求-响应模式,WebSocket 更适合需要高频交互的应用场景,比如在线聊天、实时游戏、股票行情推送等。
WebSocket 协议的基本特点
WebSocket 协议通过一次 HTTP 握手建立连接后,将协议从 HTTP 升级为 WebSocket(使用 Upgrade: websocket 头部),之后通信不再依赖 HTTP 机制。
- 持久连接:连接一旦建立,保持打开状态,双方可随时发送数据。
- 双向通信:客户端和服务器都可以主动向对方发送消息。
- 低开销:数据帧头部小,避免了每次请求重复携带大量 HTTP 头信息。
- 基于事件驱动:JavaScript 中通过 onopen、onmessage、onerror、onclose 四个事件处理通信过程。
JavaScript 中的 WebSocket 使用方法
在浏览器中,可以通过原生 WebSocket 构造函数创建连接并监听消息。
const socket = new WebSocket('ws://localhost:8080');
// 连接成功建立
socket.onopen = function(event) {
console.log('WebSocket 已连接');
socket.send('Hello Server!');
};
// 接收服务器消息
socket.onmessage = function(event) {
console.log('收到消息:', event.data);
};
// 处理错误
socket.onerror = function(error) {
console.error('发生错误:', error);
};
// 连接关闭
socket.onclose = function(event) {
console.log('连接已关闭');
};
也可以通过 send() 方法向服务器发送数据,支持字符串、Blob 或 ArrayBuffer 类型的数据。
立即学习“Java免费学习笔记(深入)”;
WebSocket 通信的安全性与升级
生产环境中推荐使用加密的 wss:// 协议(类似 HTTPS),防止数据被窃听或篡改。wss 使用 TLS 加密传输层,确保通信安全。
实际应用中的注意事项
虽然 WebSocket 提供了高效的双向通信能力,但在实际开发中需要注意以下几点:
- 连接管理:网络不稳定时应实现重连机制,例如监听 onclose 后延迟重新 new WebSocket。
- 心跳检测:通过定时 send ping/pong 消息判断连接是否存活。
- 消息格式约定:前后端需协商数据格式(常用 JSON),包含类型、时间戳、业务字段等。
- 服务端支持:Node.js 可使用 ws、Socket.IO;Java 可用 Spring WebSocket;Go 可用 gorilla/websocket 等库实现服务端逻辑。
基本上就这些。WebSocket 让 Web 实时通信变得简单高效,掌握其核心机制有助于构建高性能交互式应用。










