0

0

javascript如何与WebSocket通信_实现实时应用有何要点【教程】

紅蓮之龍

紅蓮之龍

发布时间:2026-01-29 08:08:03

|

693人浏览过

|

来源于php中文网

原创

WebSocket连接失败主因是建立阶段问题,需检查协议匹配、Origin校验、路径参数一致;二进制数据须预设binaryType为'blob'或'arraybuffer';需实现指数退避心跳保活与状态清理。

javascript如何与websocket通信_实现实时应用有何要点【教程】

WebSocket 连接失败的常见原因和快速排查

绝大多数 WebSocket 通信问题出在连接建立阶段,而不是后续收发消息。浏览器控制台报 WebSocket connection to 'ws://...' failed 时,优先检查这几点:

  • 协议必须匹配:前端ws://(开发环境)或 wss://(生产环境),后端服务必须实际监听对应协议,Nginx 反向代理需显式配置 UpgradeConnection
  • 跨域不是主因:WebSocket 协议本身不受同源策略限制,但浏览器仍会发送 Origin 头,后端若校验失败(如未白名单你的域名),会直接拒绝握手
  • 路径和查询参数要一致:比如前端连 new WebSocket('wss://api.example.com/ws?token=abc'),后端路由必须能接收并解析该 token 参数,否则鉴权失败静默断连

onmessage 回调里处理二进制数据容易踩的坑

WebSocket 默认接收文本(string),但传图片、音频或序列化数据时常用 BlobArrayBuffer。关键点在于:websocket.binaryType 必须提前设置,且不能在连接打开后动态改。

  • 设为 'blob':适合文件上传/下载场景,后续用 URL.createObjectURL() 预览图片,但注意 Blob 需手动 revokeObjectURL
  • 设为 'arraybuffer':适合结构化数据(如 Protocol Buffers、自定义二进制协议),用 Uint8ArrayDataView 解析,性能更好
  • 错误做法:不设 binaryType 就直接接收二进制,结果得到乱码字符串,且无法还原

示例:

const ws = new WebSocket('wss://example.com');
ws.binaryType = 'arraybuffer';
ws.onmessage = (e) => {
  if (e.data instanceof ArrayBuffer) {
    const view = new DataView(e.data);
    console.log('收到长度:', view.byteLength);
  }
};

心跳保活与自动重连的实用实现逻辑

浏览器不会主动维持 WebSocket 连接,NAT、代理、防火墙可能在空闲几十秒后切断连接。纯靠 onclose 触发重连远远不够,必须主动探测。

  • 服务端发 ping 帧最可靠:WebSocket 协议原生支持 ping/pong 帧(浏览器自动响应),但多数 JS 库不暴露该能力;更通用的是应用层心跳:客户端定时发 { type: 'ping' },服务端立刻回 { type: 'pong' }
  • 重连不能无脑轮询:首次失败后等 1s,第二次等 2s,第三次等 4s……指数退避,上限建议 30s;同时设置最大重试次数(如 5 次),避免无限卡死
  • 重连前务必清理旧状态:清除定时器、取消未完成的 send()、重置 readyState 判断逻辑,否则可能触发重复连接或 InvalidStateError

send() 调用时机与缓冲区溢出风险

WebSocket.send() 不是立即发包,它把数据压入浏览器内部发送队列。当 readyState !== 1(即非 OPEN)时调用会直接抛错;而队列积压过多时,bufferedAmount 持续增长,最终被浏览器强制关闭连接。

XPaper Ai
XPaper Ai

AI撰写论文、开题报告生成、AI论文生成器尽在XPaper Ai论文写作辅助指导平台

下载

立即学习Java免费学习笔记(深入)”;

  • 发消息前必判状态:
    if (ws.readyState === WebSocket.OPEN) {
      ws.send(JSON.stringify(data));
    }
  • 高频发送(如游戏帧同步)要节流:监听 ws.bufferedAmount,超过阈值(如 64KB)就暂停发送,等 onopenonmessage 后再恢复
  • 大消息拆分:单次 send() 超过几 MB 容易触发浏览器限制,应分片 + 序号标识,服务端拼接

真实项目里,连接不稳定、心跳不同步、send 时机失控,这三者叠加最容易导致“看起来连上了却收不到消息”的诡异问题——往往不是代码写错,而是状态管理没跟上连接生命周期。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

502

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

500

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

341

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3517

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

31

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

46

2026.01.13

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.3万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号