怎么用javascript操作websocket_javascript如何实现实时通信

发布时间 - 2026-01-06 00:00:00    点击率:
WebSocket连接必须用new WebSocket()创建,协议限于ws/wss,需等待onopen后发送消息,binaryType需设为arraybuffer处理二进制数据,断线重连需指数退避并限制次数。

WebSocket 连接必须用 new WebSocket() 创建,不能用 fetchXMLHttpRequest

WebSocket 是独立于 HTTP 的全双工协议,浏览器不支持用传统请求方式“发起”连接。你看到的 ws://wss:// 地址,只能传给 WebSocket 构造函数——其他任何 API 都无法建立真正的 WebSocket 连接。

  • fetch('ws://example.com') 会直接报错:TypeError: Invalid URL
  • new WebSocket('http://...') 会失败,协议必须是 wswss
  • 连接过程不可取消,没有类似 AbortController 的机制
  • 首次握手依赖 HTTP Upgrade,所以服务端必须明确支持 WebSocket 协议(如 Node.js 的 wssocket.io 或 Nginx 正确配置 Upgrade 头)

监听 onmessage 前必须确保 readyState === 1,否则消息会丢失

WebSocket 初始化后处于 CONNECTING(值为 0),此时调用 send() 会抛出异常,而 onmessage 回调即使已注册,也不会触发——因为连接尚未就绪。很多实时功能失效,根源就是没等连接完成就开始发/收数据。

  • 正确做法:在 onopen 回调里开始发送初始化消息或启用 UI 交互
  • 错误写法:
    const ws = new WebSocket('wss://api.example.com');
    ws.onmessage = e => console.log(e.data); // ✅ 注册了
    ws.send('hello'); // ❌ 此时 readyState 很可能还是 0,报错
  • 安全判断:
    if (ws.readyState === WebSocket.OPEN) {
      ws.send(data);
    } else {
      console.warn('WebSocket not ready, current state:', ws.readyState);
    }

服务端推送的二进制数据默认转成 Blob,需手动设 binaryType = 'arraybuffer'

WebSocket 收到二进制帧(如图片、音频、Protobuf 序列化数据)时,浏览器默认把 event.data 当作 Blob 处理。如果后端发的是 ArrayBuffer,前端却按 Blob 解析,就会卡在 blob.arrayBuffer() 异步流程里,破坏实时性。

  • 立即生效的设置:
    const ws = new WebSocket('wss://api.example.com');
    ws.binaryType = 'arraybuffer'; // 必须在 onopen 前或连接建立后立刻设
    ws.onmessage = e => {
      if (e.data instanceof ArrayBuffer) {
        const view = new Uint8Array(e.data);
        console.log('Received raw bytes:', view);
      }
    };
  • 不设 binaryType 时,e.dataBlob,必须用 e.data.arrayBuffer().then(...),引入 Promise 延迟
  • 该设置对文本消息无影响,string 类型仍正常接收

断线重连不能只靠 onclose,要主动轮询 readyState 并限制重试次数

onclose 只在连接已关闭后触发,但它不区分“服务端主动断开”和“网络闪断”。单纯监听它再 new WebSocket() 重建,容易陷入无限重连循环(比如 DNS 故障、防火墙拦截导致反复失败)。

  • 推荐模式:用 setTimeout + 指数退避,在 oncloseonerror 中统一触发重连逻辑
  • 必须加最大重试次数(如 5 次)和总超时(如 2 分钟),避免耗尽客户端资源
  • 每次重连前检查 ws.readyState,跳过重复新建:
    let reconnectCount = 0;
    const MAX_RECONNECT = 5;
    

    function connect() { ws = new WebSocket('wss://api.example.com'); ws.onopen = () => { reconnectCount = 0; }; ws.onclose = () => { if (reconnectCount < MAX_RECONNECT) { reconnectCount++; setTimeout(connect, Math.min(1000 Math.pow(2, reconnectCount), 30000)); } }; ws.onerror = () => { / 同上 */ }; }

WebSocket 的真实复杂度不在连接本身,而在状态同步、消息去重、心跳保活、序列化协议选型这些环节。别让 onmessage 成为唯一关注点。


# javascript  # java  # js  # 前端  # node.js  # node  # nginx  # 防火墙  # 浏览器  # websocket 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Swift中switch语句区间和元组模式匹配  怎么用AI帮你为初创公司进行市场定位分析?  实例解析Array和String方法  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  js代码实现下拉菜单【推荐】  重庆市网站制作公司,重庆招聘网站哪个好?  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  昵图网官网入口 昵图网素材平台官方入口  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  公司网站制作需要多少钱,找人做公司网站需要多少钱?  网站制作报价单模板图片,小松挖机官方网站报价?  如何自定义建站之星模板颜色并下载新样式?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何快速配置高效服务器建站软件?  高端建站如何打造兼具美学与转化的品牌官网?  七夕网站制作视频,七夕大促活动怎么报名?  Laravel如何使用.env文件管理环境变量?(最佳实践)  canvas 画布在主流浏览器中的尺寸限制详细介绍  Android GridView 滑动条设置一直显示状态(推荐)  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  WordPress 子目录安装中正确处理脚本路径的完整指南  javascript中闭包概念与用法深入理解  JavaScript数据类型有哪些_如何准确判断一个变量的类型  如何为不同团队 ID 动态生成多个独立按钮  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  北京企业网站设计制作公司,北京铁路集团官方网站?  如何用PHP快速搭建高效网站?分步指南  如何用景安虚拟主机手机版绑定域名建站?  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  linux写shell需要注意的问题(必看)  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  太平洋网站制作公司,网络用语太平洋是什么意思?  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  网站制作价目表怎么做,珍爱网婚介费用多少?  Laravel如何处理文件下载请求?(Response示例)  如何在IIS中新建站点并配置端口与IP地址?  php json中文编码为null的解决办法  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  UC浏览器如何设置启动页 UC浏览器启动页设置方法  Laravel如何实现一对一模型关联?(Eloquent示例)  如何在云主机快速搭建网站站点?  bing浏览器学术搜索入口_bing学术文献检索地址  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  简历在线制作网站免费版,如何创建个人简历?  JavaScript如何实现错误处理_try...catch如何捕获异常?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?