EventSource 和 WebSocket的区别

EventSource 和 WebSocket 都是用于在客户端和服务器之间进行实时通信的技术,但它们之间存在一些区别:

一、连接方式

  • EventSource
    • 建立连接相对简单,客户端通过向服务器发送一个 HTTP 请求来初始化连接,请求的 URL 指向服务器上的一个资源,该资源会持续不断地向客户端推送事件。
    • 连接是单向的,只能由服务器向客户端发送数据。
  • WebSocket
    • 建立连接时需要进行一个握手过程,这个过程是通过 HTTP 升级请求实现的。一旦连接建立,通信是双向的,可以在客户端和服务器之间互相发送数据。

二、数据传输类型

  • EventSource
    • 主要用于服务器向客户端发送文本数据,通常以事件流的形式进行推送。每个事件由一个事件类型和数据组成,客户端可以根据事件类型来处理不同的数据。
    • 数据格式相对简单,适合传递简单的文本消息或事件通知。
  • WebSocket
    • 可以传输任意类型的数据,包括文本、二进制数据等。这使得 WebSocket 更加灵活,可以用于传输各种类型的实时数据,如图像、音频、视频等。

三、适用场景

  • EventSource
    • 适用于那些只需要服务器向客户端单向推送消息的场景,比如实时新闻更新、股票行情推送、服务器端日志实时输出等。
    • 由于其连接建立相对简单,对于一些对实时性要求不是特别高的场景比较适用。
  • WebSocket
    • 适用于需要双向通信的场景,比如在线游戏、实时聊天应用、协作工具等。在这些场景中,客户端和服务器都需要能够随时发送数据。
    • 对于对实时性要求非常高的应用,WebSocket 可以提供更低的延迟和更高的性能。

四、错误处理和重连机制

  • EventSource
    • 当连接出现问题时,EventSource 会自动尝试重新连接。客户端可以通过监听 error 事件来处理连接错误。
    • 重新连接的行为是内置的,无需客户端进行复杂的错误处理和重连逻辑编写。
  • WebSocket
    • 客户端和服务器都可以检测到连接错误,并可以根据需要手动实现重连逻辑。
    • 由于 WebSocket 的双向通信特性,错误处理和重连机制通常需要客户端和服务器共同协作来实现。

五、兼容性

  • EventSource
    • 在现代浏览器中具有较好的兼容性,几乎所有主流浏览器都支持 EventSource。这使得它在开发面向广泛用户群体的应用时具有一定的优势。
  • WebSocket
    • 虽然也得到了广泛的支持,但在一些旧版本的浏览器中可能需要使用 polyfill 或降级方案来实现兼容性。

后端示例代码

import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.Date;
import java.util.Random;@RestController
public class EventSourceController {@GetMapping(value = "/events", produces = MediaType.TEXT_EVENT_STREAM_VALUE)public String eventSource() {Random random = new Random();while (true) {try {Thread.sleep(2000);int randomNumber = random.nextInt(100);return "data: 当前随机数:" + randomNumber + "\n\n";} catch (InterruptedException e) {e.printStackTrace();}}}
}

前端示例代码

<!DOCTYPE html>
<html><head><script>if (typeof (EventSource)!== "undefined") {var source = new EventSource("/events");source.onmessage = function (event) {document.getElementById("result").innerHTML += event.data + "<br>";};} else {document.getElementById("result").innerHTML = "你的浏览器不支持 Server-Sent Events。";}</script>
</head><body><div id="result"></div>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/54680.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Verilog学习之旅~

记录Verilog的学习日常~ 第一阶段&#xff1a;牛客网刷题 1.Verilog快速入门 基础语法 VL1:四选一多路器&#xff1a;case语句、条件表达符&#xff1b; VL2:异步复位的串联T触发器:T触发器的基本功能及代码实现、异步复位的概念&#xff1b; VL3:奇偶校验&#xff1a;缩…

spring boot导入多个配置文件

1、简介 Spring Boot从2.4.x版本开始支持了导入文件的方式来加载配置参数&#xff0c;与spring.config.additional-location不同的是不用提前设置而且支持导入的文件类型相对来说要丰富很多。 我们只需要在application.properties/application.yml配置文件中通过spring.config.…

通过document获取节点元素

1.层级节点 <ul><li id"li1">1</li><li>2</li><li id"li3">3</li><li>4</li><li>5</li></ul><script>//获取id名为li1的元素赋值给li1let li1document.getElementById(li…

Java语言程序设计基础篇_编程练习题**18.34 (游戏:八皇后问题)

目录 题目&#xff1a;**18.34 (游戏:八皇后问题) 代码示例 代码解析 输出结果 使用文件 题目&#xff1a;**18.34 (游戏:八皇后问题) 八皇后问题是要找到一个解决方案&#xff0c;将一个皇后棋子放到棋盘上的每行中&#xff0c;并且两个皇后棋子之间不能相互攻击。编写个…

Oracle Truncate和delete的区别

DropTruncatedelete语句类型 DDl &#xff08;数据定义语言 Data Definition Language DDl &#xff08;数据定义语言 Data Definition Language DML&#xff08;数据操作语言 Data Manipulation Language 速度 快 删除整个表 快 一次性删除 慢 逐行删除 回滚不可不可可del…

基于C#+SQL Server2005(WinForm)图书管理系统

图书管理系统 一、 首先把数据库脚本贴出来(数据库名为library) USE [library] GO /****** Object: Table [dbo].[books] Script Date: 06/12/2016 11:27:12 ******/ SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE TABLE [dbo].[books]([bNum] [nvarchar](10…

【python】利用python处理数据(stata等价命令)

1.一般运算 加法 # gen x y z df[x] df[y] df[z]减法 # gen x y - 1 df[x] df[y] - 1乘法 # gen var x * y df[var] df[x] * df[y]除法 # gen x z / y df[x] df[z] / df[y]取对数 # gen logx log(x) df[logx] np.log(df[x])开根号 # gen z sqrt(y) df[z] …

宝塔部署vue项目出现的各种问题

使用宝塔面板&#xff0c;网站页面&#xff0c;构建php静态网页 问题一&#xff1a;图片等静态资源无法加载 找到真正请求的url&#xff0c; 然后在项目目录下面创建对应的目录&#xff0c;将资源放入 问题二&#xff1a;刷新出现404 在这里任意位置添加 ## 添加上这个配…

socket.io-client实现实前后端时通信功能

这里我使用的后端 基于node.js的koa框架 前端使用的是vite {"name": "hou","version": "1.0.0","description": "","main": "app.js","scripts": {"test": "echo …

MongoDB-aggregate流式计算:去重操作

场景一&#xff1a;去重查询 在MongoDB的find查询里&#xff0c;可以直接使用distinct方法&#xff0c;但也有不少限制 在aggregate流式计算中&#xff0c;没有办法直接使用distinct方法&#xff0c;需要使用其他方法实现&#xff1a; 1、使用$group管道操作符&#xff0c;将需…

C语言中的typedef简介

type简介 在C语言中&#xff0c;typedef 是用于为现有的数据类型定义一个新的类型名称的关键字。它的作用是为类型取一个别名&#xff0c;使代码更简洁、更易于理解。 基本语法 typedef 原始类型 新类型名; 示例 为 int 类型定义一个别名&#xff1a; typedef int INTEGER…

网络安全:构建数字世界的坚固防线

网络安全&#xff1a;构建数字世界的坚固防线 在21世纪的今天&#xff0c;随着信息技术的飞速发展&#xff0c;互联网已经渗透到我们生活的方方面面&#xff0c;成为现代社会不可或缺的基础设施。从个人日常交流、在线购物、金融服务&#xff0c;到企业的运营管理、数据存储与…

浅谈虚拟内存(操作系统、Redis)

浅谈虚拟内存&#xff08;操作系统、Redis&#xff09; 参考&鸣谢 4.1 为什么要有虚拟内存&#xff1f; xiaolincoding 【简单说下】REDIS的虚拟内存机制,会吗?别翻书 aristo_boyunv Redis 虚拟内存 Java杨永杰 浅谈虚拟内存&#xff1a;操作系统与 Redis 在计算机系统中…

Vue3——Vite篇

Vite是一款由Vue.js的作者尤雨溪开发的前端构建工具&#xff0c;专为现代前端项目而设计。它以其快速的冷启动、按需编译和热更新能力而受到广泛关注。以下是对Vite的详细解析&#xff1a; 一、核心特性 快速启动&#xff1a; Vite利用浏览器原生支持的ES模块&#xff08;ESM…

ARM单片机的内存分布(重要)

ARM单片机的内存分布&#xff08;重要&#xff09; 一、S32K344的内存布局 MEMORY {int_pflash : ORIGIN 0x00400000, LENGTH 0x003D4000 /* 4096KB - 176KB (sBAF HSE)*/int_dflash : ORIGIN 0x10000000, LENGTH 0x00020000 /* 128KB …

BUUCTF [SCTF2019]电单车详解两种方法(python实现绝对原创)

使用audacity打开&#xff0c;发现是一段PT2242 信号 PT2242信号 有长有短&#xff0c;短的为0&#xff0c;长的为1化出来 这应该是截获电动车钥匙发射出的锁车信号 0 01110100101010100110 0010 0前四位为同步码0 。。。中间这20位为01110100101010100110为地址码0010为功…

不靠学历,不拼年资,怎么才能月入2W?

之前统计局发布了《2023年城镇单位就业人员年平均工资情况》&#xff0c;2023年全国城镇非私营单位和私营单位就业人员年平均工资分别为120698元和68340元。也就是说在去年非私营单位就业人员平均月薪1W&#xff0c;而私营单位就业人员平均月薪只有5.7K左右。 图源&#xff1a;…

两数之和、三数之和、四数之和

目录 两数之和 题目链接 题目描述 思路分析 代码实现 三数之和 题目链接 题目描述 思路分析 代码实现 四数之和 题目链接 题目描述 思路分析 代码实现 两数之和 题目链接 LCR 179. 查找总价格为目标值的两个商品 - 力扣&#xff08;LeetCode&#xff09; 题目…

在Java中如何利用ClassLoader动态加密、解密Class文件

文章目录 一、准备示例代码二、加密Class文件三、自定义ClassLoader四、使用自定义ClassLoader加载类五、进阶&#xff1a;使用更高安全性的AES加密算法六、注意事项 在Java开发中&#xff0c;保护代码的安全性是一个重要的课题。为了防止代码被轻易反编译&#xff0c;我们可以…

EfficientFormer实战:使用EfficientFormerV2实现图像分类任务(一)

摘要 EfficientFormerV2是一种通过重新思考ViT设计选择和引入细粒度联合搜索策略而开发出的新型移动视觉骨干网络。它结合了卷积和变换器的优势&#xff0c;通过一系列高效的设计改进和搜索方法&#xff0c;实现了在移动设备上既轻又快且保持高性能的目标。这一成果为在资源受…