SSE、WebSocket 和 HTTP

文章目录

一、介绍

HTTP(超文本传输协议)

本质:无状态的请求-响应协议。

数据方向:仅限客户端主动拉取,服务器无法主动推送。

SSE(Server-Sent Events,服务器推送事件)

本质:基于HTTP的单向长连接推送技术

工作方式:客户端通过 EventSource API 建立一个 HTTP 连接,服务器保持连接不关闭,并持续向客户端写入 text/event-stream 格式的数据流。

数据方向:仅服务器 → 客户端(单向),客户端发数据仍需另开普通 HTTP 请求。

WebSocket

本质:基于TCP的全双工通信协议,通过 HTTP 握手升级而来

工作方式:先走HTTP Upgrade头协商切换协议,之后在单个 TCP 连接上双向收发消息帧(二进制或文本)。

数据方向:双向,客户端和服务器可随时互相发送数据。

二、区别

核心区别是

SSE 单向通讯, 具有持续性
WebSocket 双向通讯, 具有持续性
HTTP 一次性通讯, 无持续性

下面是一些具体细节

维度 HTTP SSE WebSocket
通信方向 单向(请求→响应) 单向(服务器→客户端) 双向全双工
协议基础 HTTP/1.1, HTTP/2, HTTP/3 纯 HTTP (Content-Type: text/event-stream) TCP 长连,WS/WSS 独立协议
连接维持 短连接(可复用) 长连接(浏览器自动重连) 长连接(需代码处理重连)
消息格式 任意(JSON/HTML/文件) 纯文本流(带 data: 前缀) 帧(文本/二进制)
服务端推送 ❌ 不支持 ✅ 支持 ✅ 支持
客户端上传 ✅ 支持(默认行为) ❌ 不支持(需另发 HTTP) ✅ 支持(原生高效)
浏览器兼容性 100% IE/旧 Edge 不支持,现代全支持 IE10+,现代全支持
防火墙/代理友好 极好 较好(基于 HTTP 标准头) 略差(部分老旧代理可能阻断 Upgrade)

三、使用场景

方式 场景
HTTP 获取静态资源、提交表单
SSE AI对话流式输出(打字机效果------这是SSE的经典强项)、股票行情实时刷新(只需推价格变化)、社交媒体通知流(点赞、评论数更新)、大型文件上传处理进度条(服务器告知处理到 80% 了)
WebSocket 多人在线文档、客服聊天、棋牌对战
相关推荐
未来侦察班13 小时前
网络协议 网络层,万物归于IP
网络·网络协议·协议·ip·网络层·tcpip
colofullove14 小时前
实时游玩页与 WebSocket 状态管理实现
websocket·网络协议·状态模式
小短腿的代码世界14 小时前
WebSocket协议在Qt中的工业级实现:5层架构设计与万级并发压测验证
qt·websocket·网络协议
Patrick_Wilson15 小时前
Cookie 作用域避坑:父域泄漏、同名优先级与多环境隔离
前端·http·浏览器
葡萄皮sandy16 小时前
SSE和WebSocket
网络·websocket·网络协议
hyunbar77716 小时前
配置 Cloudflare Tunnel:把 Mac 上的 Web 服务变成安全域名
网络协议
我喜欢就喜欢16 小时前
C++ 连接 Ollama 本地大模型:从原生 HTTP 调用到高性能封装实践
开发语言·c++·http
酉鬼女又兒17 小时前
零基础入门IPv4地址:从基本概念、分类编址、子网划分到无分类编址与应用规划全解
网络·网络协议·计算机网络·考研·职场和发展·分类·智能路由器
未来侦察班17 小时前
网络协议 数据链路层,“帧”建立统一新秩序
网络·网络协议
极创信息18 小时前
信创产品适配测试认证,域名和SSL是必须的吗?
java·开发语言·网络·python·网络协议·ruby·ssl