WebSocket、SSE(Server-Sent Events)、HTTP 和 Axios关系总结

WebSocket、SSE(Server-Sent Events)、HTTP 和 Axios 在 Web 开发中扮演着不同的角色,它们之间的关系可以概括如下:

Http

HTTP(超文本传输协议)是一种用于在客户端和服务器之间传输数据的应用层协议。它是 Web 开发的基础,用于请求网页、图像、文件等资源。

‌WebSocket‌

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。与 HTTP 不同,WebSocket 允许服务器和客户端之间建立持久的连接,并可以在任意时刻相互发送数据。它通常用于需要实时双向通信的应用场景,如在线聊天、实时数据推送等。

‌SSE(Server-Sent Events)

SSE 是一种用于实现服务器主动向客户端推送数据的技术。与 WebSocket 类似,SSE 也允许服务器向客户端发送实时更新的数据。但不同的是,SSE 是单向通信协议,只能由服务器向客户端推送数据,而客户端不能主动向服务器发送数据。SSE 基于 HTTP 协议,利用了其长连接特性。

‌Axios‌

Axios 是一个基于 Promise 的 HTTP 客户端库,用于发送 HTTP 请求。它可以在浏览器和 Node.js 环境中使用,提供了一系列简洁的 API 来发送不同类型的 HTTP 请求(如 GET、POST、PUT、DELETE 等)。虽然 Axios 本身不直接支持 WebSocket 或 SSE,但它可以用于与 HTTP 服务器进行通信,包括在 WebSocket 握手阶段发送 HTTP 请求。

关系总结

‌HTTP‌ 是 Web 开发的基础协议,WebSocket 和 SSE 都基于 HTTP 协议进行通信,但在连接建立后的数据传输方式上有所不同。

‌WebSocket‌ 是一种全双工通信协议,适用于需要实时双向通信的应用场景。

‌SSE‌ 是一种单向通信协议,适用于需要服务器主动向客户端推送数据的场景,但客户端不能主动发送数据。

‌Axios‌ 是一个 HTTP 客户端库,用于发送 HTTP 请求。它本身不直接支持 WebSocket 或 SSE,但可以用于与 HTTP 服务器进行通信,包括在 WebSocket 握手阶段发送 HTTP 请求。

在实际开发中,你可以根据需要选择使用 WebSocket、SSE 或 HTTP(通过 Axios 或其他 HTTP 客户端库)来实现特定的通信需求。例如,如果你需要实时双向通信,可以选择 WebSocket;如果你只需要服务器向客户端推送数据,而客户端不需要主动发送数据,可以选择 SSE;如果你需要进行传统的请求-响应通信,可以选择 HTTP(通过 Axios 或其他 HTTP 客户端库)。

相关推荐
the_nov2 小时前
14.网络套接字TCP
linux·c++·网络协议
古希腊掌握嵌入式的神2 小时前
[物联网iot]对比WIFI、MQTT、TCP、UDP通信协议
网络·物联网·网络协议·tcp/ip·udp
硪就是硪3 小时前
内网环境将nginx的http改完https访问
nginx·http·https
鹅肝手握高V五色4 小时前
Wireshark入门教程:如何抓取和过滤网络数据包
websocket·网络协议·tcp/ip·http·网络安全·https·udp
老六ip加速器4 小时前
如何改电脑网络ip地址:一步步指导
网络·网络协议·tcp/ip
别说我什么都不会5 小时前
ohos.net.http请求HttpResponse header中set-ccokie值被转成array类型
网络协议·harmonyos
旧味清欢|5 小时前
关注分离(Separation of Concerns)在前端开发中的实践演进:从 XMLHttpRequest 到 Fetch API
javascript·http·es6
self-discipline6346 小时前
【计网速通】计算机网络核心知识点与高频考点——数据链路层(二)
网络·网络协议·计算机网络
CryptoPP6 小时前
深入实践:基于WebSocket的全球化金融数据实时对接方案。 马来西亚、印度、美国金融数据API
websocket·网络协议·金融
网络抓包与爬虫7 小时前
Wireshark——抓包分析
websocket·网络协议·tcp/ip·http·网络安全·https·udp