贝利信息

HTML5 WebSocket怎么识别_HTML5实时通信特征判断【通信】

日期:2026-01-08 00:00 / 作者:雪夜
确认 HTML5 原生 WebSocket 实例需同时满足:ws instanceof WebSocket 为 true、ws.url 以 'ws' 开头,且 Chrome Network 面板中协议类型显示为 WS。

WebSocket 连接成功后怎么确认是 HTML5 原生 WebSocket 实例

只要通过 new WebSocket(url) 创建的对象,就是 HTML5 原生 WebSocket —— 它和长轮询、SSE、Socket.IO 封装层有本质区别。关键看构造方式和原型链,而不是行为特征。

判断逻辑很简单:

如何区分 WebSocket 和伪 WebSocket(如 Socket.IO、SSE、长轮询)

不能只看是否“实时”,得抓协议层和初始化痕迹:

WebSocket 连接建立时的 HTML5 特征响应头识别

服务器对 WebSocket 升级请求的响应,必须包含特定 HTTP 头才能算合规 HTML5 WebSocket 握手:

HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=

为什么 ws.readyState 不足以判断是否 HTML5 WebSocket

readyState 只反映连接状态(03),所有兼容 WebSocket API 的对象(包括降级 polyfill)都实现了它。真正容易被忽略的是:

真要确认,最稳的方式是结合 instanceof WebSocket + ws.url.startsWith('ws') + Network 面板看协议类型 —— 三者缺一不可。