websocket

‌1、含义

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议‌,允许客户端与服务器之间建立持久连接,实现低延迟、高效率的双向数据传输。解决了传统 HTTP 只能客户端主动请求的问题

2、核心特点

‌全双工通信‌:客户端和服务器可同时主动发送数据,无需等待对方响应

‌持久连接‌:握手成功后连接保持打开,避免频繁建立/断开 TCP 连接的开销

‌轻量级头部‌:相比 HTTP 每次请求携带完整头部,WebSocket 数据帧头部很小仅 2--10 字节(客户端到服务器额外加 4 字节掩码)‌

基于 TCP,兼容 HTTP‌:使用 ws://(明文)或 wss://(加密,推荐生产环境)协议,默认复用 HTTP 的 80/443 端口,便于穿透防火墙

广泛浏览器支持‌:所有主流现代浏览器均原生支持 ‌

3、与HTTP的区别

|--------|----------------|------------------|
| 特性 | HTTP | WebSocket |
| 连接方式 | 短连接,请求 - 响应即断开 | 长连接,一直保持 |
| 通信方向 | 只能客户端主动请求 | 双向随时推送 |
| 实时性 | 差(轮询 / 长轮询) | 高 |
| 开销 | 每次请求带大量头信息 | 仅握手时 HTTP 头,后续极小 |
| 适用场景 | 页面、接口、数据查询 | 聊天、直播、通知、大屏、游戏等 |

4、如何使用websocket
javascript 复制代码
// 1. 创建连接
const ws = new WebSocket('ws://localhost:8080'); // 或 wss://... 用于生产环境

// 2. 监听事件
ws.onopen = () => {
  console.log('连接已建立');
  ws.send('Hello Server!'); // 发送消息
};

ws.onmessage = (event) => {
  console.log('收到消息:', event.data);
  // 若服务端发送 JSON,需解析:JSON.parse(event.data)
};

ws.onclose = (event) => {
  console.log('连接关闭,代码:', event.code, '原因:', event.reason);
};

ws.onerror = (error) => {
  console.error('连接异常:', error);
};

// 3. 发送数据(必须为字符串)
ws.send(JSON.stringify({ type: 'login', user: 'alice' }));

// 4. 关闭连接(如页面卸载时)
window.addEventListener('beforeunload', () => {
  ws.close();
});

关键注意事项‌:

send() 只能传 ‌字符串‌,对象需用 JSON.stringify() 转换

发送前应检查 ws.readyState === WebSocket.OPEN(值为 1),避免在非开放状态发送报错 ‌

页面离开前务必调用 close() 防止连接泄漏 ‌

相关推荐
小辰记事本1 小时前
从零读懂RoCEv2数据包构造:从WQE到线缆上的完整旅程
服务器·网络·网络协议·rdma
北京耐用通信2 小时前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
在角落发呆3 小时前
Linux转发配置:解锁网络互联的核心密码
linux·运维·网络
YMWM_5 小时前
UDP协议详解:从原理到Python实践
网络·网络协议·udp
pengyi8710156 小时前
共享 IP 与独享 IP 怎么选?被封后升级方案避坑
网络·网络协议·tcp/ip
YuanDaima20486 小时前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
凯勒姆7 小时前
网工网络设备原理及配置
网络·智能路由器
上海云盾-小余8 小时前
网站恶意爬虫拦截策略:智能识别与封禁实操方案
网络·爬虫·安全·web安全
xhbh6668 小时前
网关端口映射和路由器端口转发有什么区别?配置要点全解析
运维·服务器·网络·智能路由器·端口映射·映射·无痕网关
半壶清水8 小时前
用P4 Tutorial、BMv2 和 Mininet‌解析网络第一集------模拟环境搭建
运维·服务器·网络·网络协议·tcp/ip