当 WebSocket 遇见 Socket.io

"给我一个浏览器,我要让服务器主动开口说话。"

这句话在 2011 年以前的答案只能是轮询;今天,我们有了 WebSocket 和 Socket.io

一、WebSocket:浏览器里的"对讲机"

WebSocket 不是 HTTP 的补丁,而是一条全新的全双工通道

握手阶段借 HTTP 的路,升级协议后就完全脱离 HTTP,数据变成二进制帧在 TCP 里自由穿梭。

原生 API 三板斧

js 复制代码
const ws = new WebSocket('wss://example.com/chat');

ws.onopen    = () => ws.send('天王盖地虎');
ws.onmessage = e  => console.log('收到:', e.data);
ws.onclose   = () => console.log('连接断开');

短短五行,你就能让浏览器和服务器互相喊话。

但真实项目往往不止"喊话"这么简单:

  • 消息类型多样,谁来解析?
  • 断线重连、心跳、鉴权、房间管理,谁来兜底?
  • 老浏览器不支持怎么办?

于是,Socket.io 出现了。

二、Socket.io

Socket.io 不是 WebSocket 的替代品,而是工程化后的增强层

它在 WebSocket 之上做了三件事:

  1. 事件驱动

    把裸字符串变成语义化事件,告别手写解析器。

    js 复制代码
    socket.emit('$message', { text: '你好', sender: '张三' });
    socket.on('$message', data => renderChat(data));
  2. 自动降级

    浏览器不支持 WebSocket?Socket.io 悄悄切到长轮询,开发者无感知。

  3. 高级特性

    命名空间、房间、广播、确认回调、心跳、重连、二进制传输......开箱即用。

三、从裸连接到聊天室

1. 服务端(Node.js + Socket.io

js 复制代码
import { Server } from 'socket.io';
const io = new Server(9528, { cors: true });

io.on('connection', socket => {
  // 分配随机昵称
  socket.emit('$name', `用户-${Math.random() * 1000 | 0}`);

  // 推送历史消息
  socket.emit('$history', messages);

  // 监听新消息
  socket.on('$message', text => {
    const msg = { text, date: Date.now() };
    messages.push(msg);
    io.emit('$message', msg); // 广播给所有人
  });
});

2. 客户端

html 复制代码
<script src="https://cdn.socket.io/4.7/socket.io.min.js"></script>
<script>
  const socket = io('ws://localhost:9528');

  socket.on('$name',   name => (myName = name));
  socket.on('$history', list => renderHistory(list));
  socket.on('$message', msg  => appendMessage(msg));

  function send(text) {
    socket.emit('$message', text);
  }
</script>

四、何时用裸 WebSocket,何时用 Socket.io

  • 只需要一条简单通道,且环境可控 → 原生 WebSocket
  • 需要事件分发、降级兼容、房间广播 → Socket.io
  • IE8、企业内网老环境 → Socket.io 自动回退到长轮询
相关推荐
27669582922 小时前
京东随机变速滑块拼图验证码识别(京东E卡)
java·服务器·前端·python·京东滑块·京东变速滑块·京东e卡绑卡
এ慕ོ冬℘゜2 小时前
手写生产级 jQuery Toast 轻量提示组件|零插件依赖、动画流畅、极简高
前端·javascript·jquery
Oneslide2 小时前
UI设计-企业OA风格
前端
是小王同学啊~3 小时前
Kafka 面试通关笔记:高频八股 + 生产实战 + 追问链路(上)
笔记·面试·kafka
程序员海军3 小时前
我用了 8 个月 Codex CLI,总结出这套 AI 编程工作流
前端·后端·aigc
大家的林语冰3 小时前
Express 团队官宣:全新网站正式上线,Logo 重做,支持两个主版本文档无缝切换!
javascript·node.js·express
এ慕ོ冬℘゜3 小时前
手写一款高兼容、零BUG图片预览组件|前端
前端·bug
铁链鞭策大师3 小时前
javaEE之多线程(2)
java·前端·java-ee
KaMeidebaby3 小时前
卡梅德生物技术快报|生信实操:ChIP 染色质免疫共沉淀技术流程、短板与替代方案详解
前端·人工智能·物联网·百度·新浪微博
weixin199701080163 小时前
[特殊字符] 【性能提升300%】仿1688首页的Webpack优化全记录(附构建分析Python脚本)
前端·python·webpack