0

0

什么是javascript的websocket_它如何实现实时通信

夢幻星辰

夢幻星辰

发布时间:2026-01-12 23:52:02

|

591人浏览过

|

来源于php中文网

原创

WebSocket 是全双工、长生命周期的 TCP 连接,握手复用 HTTP 但后续脱离其协议栈,以轻量帧通信;原生 JS 通过 WebSocket 构造函数创建,依赖 onopen 发送数据,不自动重连,需手动实现并注意代理、CDN、兼容性等部署限制。

什么是javascript的websocket_它如何实现实时通信

WebSocket 不是 HTTP 的升级版,也不是轮询的替代包装,它是浏览器与服务器之间建立的**全双工、长生命周期 TCP 连接**——连接一旦建立,双方可随时主动收发数据,没有请求-响应约束。

WebSocket 与普通 HTTP 请求的根本区别

HTTP 是无状态、单向、短连接:客户端发请求,服务端回响应,连接立刻关闭。而 WebSocket 在握手阶段复用 HTTP(用 Upgrade: websocket 头),但之后完全脱离 HTTP 协议,进入二进制帧通信模式。

  • 每次 HTTP 请求都带完整头信息(可能几百字节),WebSocket 帧头部最小仅 2 字节
  • HTTP 轮询需反复建连、TLS 握手,WebSocket 复用一个连接,首屏后通信开销趋近于零
  • 服务端无法主动推数据给 HTTP 客户端;WebSocket 下 server.send() 可随时触发客户端 onmessage

如何用原生 JavaScript 创建并使用 WebSocket

核心是 WebSocket 构造函数,它接受 URL(必须是 wss://ws://)并立即发起握手。连接状态和消息通过事件监听:

const ws = new WebSocket('wss://echo.websocket.events');

ws.onopen = () => {
  console.log('已连接');
  ws.send('hello'); // 连接就绪后才能 send
};

ws.onmessage = (event) => {
  console.log('收到:', event.data); // event.data 总是字符串或 Blob
};

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

ws.onclose = (event) => {
  console.log('断开,代码:', event.code, '原因:', event.reason);
};
  • ws.readyState 有四个值:0(CONNECTING)、1(OPEN)、2(CLOSING)、3(CLOSED),别在 0 时调 send()
  • event.data 类型取决于服务端发送的内容:文本为 string,二进制为 BlobArrayBuffer,可用 ws.binaryType = 'arraybuffer' 统一处理
  • 不要用 setTimeout 轮询 readyState,应严格依赖 onopen 回调

为什么 WebSocket 会“自动重连”不是默认行为

浏览器原生 WebSocket 对象**不提供自动重连**。断开后对象即失效,再次 new WebSocket() 才算新连接。常见错误是监听 onclose 后直接 ws = new WebSocket(...),但旧 ws 引用未清理,导致内存泄漏和重复监听。

天工大模型
天工大模型

中国首个对标ChatGPT的双千亿级大语言模型

下载

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

  • 重连需手动实现:记录重试次数、指数退避(如 1s → 2s → 4s)、最大尝试上限
  • 避免在 onclose 中立即重连,先清空定时器、取消未完成的 send()、重置 onmessage 绑定
  • 服务端若返回 event.code === 4000,通常表示业务层拒绝接入,不应盲目重连

实际部署中容易被忽略的三个硬性限制

开发时本地 ws://localhost:3000 很顺畅,上线后常卡在连接失败——问题往往不在代码逻辑,而在基础设施层面:

  • 反向代理(如 Nginx)必须显式透传 WebSocket 头:proxy_http_version 1.1proxy_set_header Upgrade $http_upgradeproxy_set_header Connection "upgrade"
  • CDN 或 WAF 默认拦截非标准 HTTP 方法/头,Upgrade 请求会被 403 拦截,需在 CDN 控制台开启 WebSocket 支持
  • 移动端某些 WebView(如早期 Android 4.x)不支持 WebSocket,降级方案不能只靠 typeof WebSocket !== 'undefined',要加 try/catch new WebSocket() 实测

真正难的不是写通第一行 ws.send(),而是让连接在弱网、代理、混合 CDN、老旧终端下稳定存活超过 30 分钟——这需要服务端心跳保活、客户端网络状态感知、以及对 close 事件中 codereason 的精确分类处理。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
nginx 重启
nginx 重启

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

246

2023.07.27

nginx 配置详解
nginx 配置详解

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

522

2023.08.04

nginx配置详解
nginx配置详解

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

610

2023.08.04

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

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

244

2024.02.23

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

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

693

2024.07.09

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

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

3618

2024.08.07

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

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

54

2026.01.13

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

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

72

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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