当前位置: 首页 > news >正文

WebSocket学习总结

WebSocket 是一种基于TCP的网络通信协议,允许浏览器和服务器之间进行全双工、实时、低延迟的双向数据传输。它突破了传统HTTP协议的限制(请求-响应模式),特别适合需要实时通信的场景(如聊天、实时数据推送、游戏等)。

核心特点

  1. 全双工通信
    客户端和服务器可以同时发送和接收数据,无需等待对方的响应。

  2. 持久连接
    连接建立后(通过HTTP握手),会保持打开状态,直到任意一方主动关闭,避免了频繁建立连接的开销。

  3. 低延迟
    由于连接复用和实时传输,相比轮询或长轮询(Long Polling),延迟显著降低。

  4. 二进制和文本数据支持
    可以传输文本(如JSON)和二进制数据(如图片、视频)。

  5. 跨域支持
    原生支持跨域通信,无需额外配置(如CORS)。

工作原理

  1. 握手阶段(HTTP升级)
    客户端通过HTTP请求发送升级协议头,服务器确认后,连接从HTTP升级为WebSocket:

    // 客户端请求
    GET /chat HTTP/1.1
    Host: example.com
    Upgrade: websocket
    Connection: Upgrade
    Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw==
    Sec-WebSocket-Protocol: chat
    Sec-WebSocket-Version: 13// 服务器响应
    HTTP/1.1 101 Switching Protocols
    Upgrade: websocket
    Connection: Upgrade
    Sec-WebSocket-Accept: HSmrc0sMlYUkAGmm5OPpG2HaGWk=
    Sec-WebSocket-Protocol: chat
    
  2. 数据传输阶段
    握手成功后,连接转为TCP通道,双方通过**帧(Frame)**格式交换数据,无需HTTP头部,开销极小。

  3. 连接关闭
    任意一方发送关闭帧(Close Frame)终止连接。

与HTTP的对比

特性HTTPWebSocket
通信模式请求-响应(半双工)全双工
连接状态短连接(每次请求新建)持久连接
实时性低(需轮询)高(实时推送)
协议开销高(每次请求带头部)低(仅握手时用HTTP)
典型场景静态资源、API调用聊天、实时数据更新

应用场景

  1. 实时通信

    • 即时聊天(如微信、QQ)、在线客服。
    • 多人协作工具(如Google Docs的实时编辑)。
  2. 数据推送

    • 股票行情、体育赛事比分、天气预报更新。
    • 消息通知(如邮件、社交平台提醒)。
  3. 游戏与直播

    • 实时多人游戏(如在线棋牌)。
    • 音视频直播弹幕、互动功能。
  4. 物联网(IoT)

    • 设备状态监控、远程控制(如智能家居)。

实现方式

客户端(浏览器)

使用JavaScript的WebSocket API:

// 建立连接
const ws = new WebSocket('ws://example.com/socket');// 连接打开时触发
ws.onopen = () => {ws.send('Hello, server!');
};// 收到消息时触发
ws.onmessage = (event) => {console.log('Received:', event.data);
};// 连接关闭时触发
ws.onclose = () => {console.log('Connection closed');
};
服务端

常见的服务器端实现:

  • Node.js:使用wssocket.iouWebSockets.js库。
  • Java:使用Spring WebSocket、Jetty或Tomcat内置支持。
  • Python:使用websocketsTornadoDjango Channels
  • Go:使用标准库net/http中的WebSocket支持。

注意事项

  1. 兼容性
    现代浏览器(IE 10+、Chrome、Firefox等)均支持,但需注意旧版浏览器的兼容性。

  2. 代理与防火墙
    部分企业防火墙可能限制WebSocket连接,需配置允许ws://wss://(TLS加密)协议。

  3. 心跳机制
    为避免连接被中间设备断开,需实现心跳包(Ping/Pong帧)。

  4. 安全性
    生产环境应使用wss://(WebSocket over TLS)加密传输,防止数据被窃听。

总结

WebSocket是现代Web应用中实现实时通信的首选技术,它通过持久连接和全双工通信,解决了HTTP协议在实时性方面的局限,广泛应用于需要即时数据交互的场景。

相关文章:

  • MySQL数据库第一章
  • Introduction to SQL
  • SQLord: 基于反向数据生成和任务拆解的 Text-to-SQL 企业落地方案
  • sqli_labs第二十九/三十/三十一关——hpp注入
  • 【手写数据库核心揭秘系列】第9节 可重入的SQL解析器,不断解析Structure Query Language,语言翻译好帮手
  • [STM32学习笔记(九)]CubeMX项目使用系统定时器SysTick的中断服务函数进行定时
  • 《计算机组成原理》第 1 章 - 计算机系统概论
  • DAY38打卡
  • Python PyMySQL
  • 嵌入式开发学习日志(linux系统编程--进程(3)——线程)Day29
  • Ubuntu20.04系统安装,使用系统盘安装
  • AD-PCB--电子设计学习思路 DAY 1
  • 通过HIVE SQL获取每个用户的最大连续登录时常
  • 0527漏洞原理:SQL注入笔记 SQL注入类型(联合查询注入、报错注入实操)
  • SQL Server 简介和与其它数据库对比
  • sqli-第三十二关——bypass addslashes
  • 一对多 多对一
  • SQL思路解析:窗口函数该如何使用?
  • LeetCode 高频 SQL 50 题(基础版)之 【连接】部分 · 上
  • 猿大师办公助手WebOffice用二进制数据流在Web前端打开Office文档
  • 政府招标网(免费)/重庆seo按天收费
  • 蚌埠网站建设文章/互联网企业营销策略
  • nat123做视频网站/网络舆情案例分析
  • 今日全国疫情最新数据/西安网站建设优化
  • 政府网站功能分析 选做/怎样建立自己网站
  • 上海环球金融中心电梯/青岛seo外包公司