”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 服务器发送事件 (SSE) 的工作原理

服务器发送事件 (SSE) 的工作原理

发布于2024-11-05
浏览:544

How Server-Sent Events (SSE) Work

SSE(服务器发送事件)在 Web 开发领域并未广泛使用,本文将深入探讨 SSE 是什么、它是如何工作的以及它如何受益您的申请。


什么是上交所?

SSE 是一种通过 HTTP 连接从服务器向客户端发送实时更新的简单而有效的方法。它是 HTML5 规范的一部分,并受到所有现代 Web 浏览器的支持。 SSE 基于单向数据流,服务器向客户端发送消息,但客户端无法将消息发送回服务器。

SSE 使用称为“服务器发送事件”的基于文本的格式将数据发送到客户端。数据作为一系列事件发送,每个事件包含一条消息和一个可选的事件类型。事件类型用于区分不同类型的消息,并允许客户端以不同的方式处理它们。

上交所如何运作?

SSE 协议的工作原理是在服务器和客户端之间建立持久的 HTTP 连接。只要客户端想要从服务器接收更新,此连接就会保持打开状态。当服务器有新数据要发送时,它会发送具有特殊 MIME 类型“text/event-stream”的 HTTP 响应。

响应包含一系列事件,每个事件由换行符(“\n”)分隔。每个事件都有以下格式:

event: [event type]\n
data: [message]\n\n

“事件”字段是可选的,用于提供事件的名称。 “数据”字段包含正在发送的实际消息。每个事件末尾的两个换行符用于表示事件结束。

这是一个简单的 SSE 响应示例:

HTTP/1.1 200 OK
Content-Type: text/event-stream

event: message
data: Hello, world!

event: message
data: This is a test message.

event: customEvent
data: {"foo": "bar", "baz": 123}

在此示例中,我们向客户端发送三个事件。前两个事件的事件类型为“消息”并包含简单的文本消息。第三个事件的事件类型为“customEvent”,并包含一个 JSON 对象作为其消息。

当客户端收到 SSE 响应时,它使用该数据来更新其用户界面。例如,这可以使用 JavaScript 来操作 DOM 来完成。

实施上交所

在您的应用程序中实现 SSE 相对简单。以下是如何使用 Node.js 和 Express 框架实现 SSE 的示例:

const express = require('express');
const app = express();

// Set up SSE endpoint
app.get('/events', (req, res) => {
  // Set headers
  res.setHeader('Content-Type', 'text/event-stream');
  res.setHeader('Cache-Control', 'no-cache');
  res.setHeader('Connection', 'keep-alive');
  // Send initial event
  res.write('data: Connected\n\n');
  // Set interval to send periodic events
  const intervalId = setInterval(() => {
    res.write('data: Hello, world!\n\n');
  }, 1000);
  // Clean up on connection close
  req.on('close', () => {
    clearInterval(intervalId);
  });
});

// Start server
app.listen(3000, () => {
  console.log('Server started on port 3000');
});

在此示例中,我们在“/events”处设置 SSE 端点。我们正在为 SSE 设置必要的标头并向客户端发送初始事件以确认连接已建立。

然后我们设置一个间隔,每秒向客户端发送周期性事件。最后,我们清理客户端关闭连接的时间间隔。

在客户端,我们可以使用以下JavaScript代码来监听SSE事件:

const source = new EventSource('/events');

source.addEventListener('message', (event) => {
  console.log(event.data);
});
source.addEventListener('error', (event) => {
  console.error('Error:', event);
});

在此示例中,我们将创建一个新的 EventSource 对象并传入 SSE 端点的 URL。然后,我们监听“消息”事件并将数据记录到控制台。我们还会监听“错误”事件,以防出现任何连接问题。

注意前端的EventSource路径只能被GET请求使用,如果要使用POST等HTTP方法,需要自己解析响应数据。

如果您想要原生 Node.js 实现,这里有一个

SSE 用例

SSE 可用于各种需要实时更新的应用程序。以下是一些示例:

  • 社交媒体平台:SSE可用于为社交媒体平台提供实时更新,例如新消息、评论或点赞的通知。

  • 金融应用:上交所可用于为金融应用提供实时更新,例如股票价格、货币汇率或新闻。

  • 在线游戏:SSE可用于为在线游戏应用程序提供实时更新,例如游戏事件、比分或排名的通知。

使用 SSE 的好处

与其他实时通信方法(例如轮询或 WebSockets)相比,使用 SSE 有几个好处:

效率

SSE 使用持久 HTTP 连接,这意味着建立和维护连接的开销比其他方法低得多。这使得 SSE 更加高效且资源占用更少,这在处理大量客户时尤其重要。

简单

SSE 是一个简单的协议,易于理解和实现。它不需要任何特殊的库或框架,可以使用标准的 Web 技术(例如 JavaScript 和 HTTP)来实现。

可靠性

SSE 是一种可靠的协议,可以在网络中断的情况下提供自动重新连接。这确保即使连接暂时丢失,客户端也将继续接收更新。

结论

服务器发送事件 (SSE) 是一种通过 HTTP 连接从服务器向客户端发送实时更新的简单而有效的方法。它是 HTML5 规范的一部分,并受到所有现代 Web 浏览器的支持。 SSE 使用单向数据流,服务器向客户端发送消息,但客户端无法将消息发送回服务器。这使您无需不断轮询服务器以查找事件,这不仅提高了性能,还降低了复杂性。

如果您觉得这有帮助,请考虑 订阅我的时事通讯 以获取更多有关 Web 开发的有用文章和工具。感谢您的阅读!

版本声明 本文转载于:https://dev.to/zacharylee/how-server-sent-events-sse-work-450a?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    解决MySQL插入Emoji时出现的\\"字符串值错误\\"异常
    Resolving Incorrect String Value Exception When Inserting EmojiWhen attempting to insert a string containing emoji characters into a MySQL database us...
    编程 发布于2025-06-09
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-06-09
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-06-09
  • 为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    网格超过身体,用100%grid-template-columns 为什么在grid-template-colms中具有100%的显示器,当位置设置为设置的位置时,grid-template-colly修复了?问题: 考虑以下CSS和html: class =“ snippet-code”> g...
    编程 发布于2025-06-09
  • 在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在JTable中维护jtable单元格渲染后,在JTable中,在JTable中实现自定义单元格渲染和编辑功能可以增强用户体验。但是,至关重要的是要确保即使在编辑操作后也保留所需的格式。在设置用于格式化“价格”列的“价格”列,用户遇到的数字格式丢失的“价格”列的“价格”之后,问题在设置自定义单元格...
    编程 发布于2025-06-09
  • C++中如何将独占指针作为函数或构造函数参数传递?
    C++中如何将独占指针作为函数或构造函数参数传递?
    在构造函数和函数中将唯一的指数管理为参数 unique pointers( unique_ptr [2启示。通过值: base(std :: simelor_ptr n) :next(std :: move(n)){} 此方法将唯一指针的所有权转移到函数/对象。指针的内容被移至功能中,在操作...
    编程 发布于2025-06-09
  • 为什么不````''{margin:0; }`始终删除CSS中的最高边距?
    为什么不````''{margin:0; }`始终删除CSS中的最高边距?
    在CSS 问题:不正确的代码: 全球范围将所有余量重置为零,如提供的代码所建议的,可能会导致意外的副作用。解决特定的保证金问题是更建议的。 例如,在提供的示例中,将以下代码添加到CSS中,将解决余量问题: body H1 { 保证金顶:-40px; } 此方法更精确,避免了由全局保证金重置引...
    编程 发布于2025-06-09
  • 为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    为什么PHP的DateTime :: Modify('+1个月')会产生意外的结果?
    使用php dateTime修改月份:发现预期的行为在使用PHP的DateTime类时,添加或减去几个月可能并不总是会产生预期的结果。正如文档所警告的那样,“当心”这些操作的“不像看起来那样直观。 ; $ date->修改('1个月'); //前进1个月 echo $ date->...
    编程 发布于2025-06-09
  • FastAPI自定义404页面创建指南
    FastAPI自定义404页面创建指南
    response = await call_next(request) if response.status_code == 404: return RedirectResponse("https://fastapi.tiangolo.com") else: ...
    编程 发布于2025-06-09
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-06-09
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-06-09
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-06-09
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样,如何?答案:是的,可以将您的Encryption库从McRypt升级到OpenSSL。可以使用openssl。附加说明: [openssl_decrypt()函数要求iv参...
    编程 发布于2025-06-09
  • 表单刷新后如何防止重复提交?
    表单刷新后如何防止重复提交?
    在Web开发中预防重复提交 在表格提交后刷新页面时,遇到重复提交的问题是常见的。要解决这个问题,请考虑以下方法: 想象一下具有这样的代码段,看起来像这样的代码段:)){ //数据库操作... 回声“操作完成”; 死(); } ?> ...
    编程 发布于2025-06-09
  • 如何实时捕获和流媒体以进行聊天机器人命令执行?
    如何实时捕获和流媒体以进行聊天机器人命令执行?
    在开发能够执行命令的chatbots的领域中,实时从命令执行实时捕获Stdout,一个常见的需求是能够检索和显示标准输出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    编程 发布于2025-06-09

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3