实时数据推送:如何使用 Server-Sent Events

阅读时长 4 分钟读完

简介

在 Web 应用程序中,实时数据推送是一个关键的需求,特别是对于需要不间断地获取最新信息的应用程序。而常见的 HTTP 请求-响应模型则无法满足这一需求,因为它需要客户端不断地发出请求,即使数据没有发生改变。这很浪费带宽和服务器资源。

为了解决这个问题,HTML5 引入了 Server-Sent Events(SSE)技术,使得服务器可以向客户端推送数据,免去了客户端不断发出请求的负担。SSE 是一个相对简单和易用的技术,很适合用于实现实时数据推送功能。

本文将介绍如何使用 SSE 实现实时数据推送,包括 SSE 的基本原理、实现方法、服务器端和客户端的代码示例。

SSE 基本原理

SSE 基于 HTTP 协议,使用 HTTP 连接,但不同于传统的 HTTP 请求-响应模型。它采用单向通信,即服务器向客户端发送数据,客户端只接收数据,不能向服务器发出请求。

在 SSE 中,服务器端需要使用特殊的响应格式:text/event-stream。这种格式的响应包含一个或多个事件(event),每个事件占据一行。事件有三种类型:

  • data: 开头,后面跟着 JSON 格式的数据,表示发送的数据事件;
  • event: 开头,后面跟着事件名称,表示自定义事件;
  • id: 开头,后面跟着一个 ID 字符串,表示消息 ID。

客户端通过打开一个 SSE 连接,即可以接收服务端发送的事件数据。SSE 连接的建立和关闭都是通过 JavaScript 的 SSE API 实现的。

实现 SSE

下面是一个使用 Node.js 和 Express 框架的 SSE 服务器端代码示例。它实现了一个简单的计数器,并每秒向客户端发送计数器的当前值。

-- -------------------- ---- -------
----- ------- - -------------------
----- --- - ----------

----------------------------------

--------------- ----- ---- -- -
  ------------------ -
    --------------- --------------------
    ---------------- -----------
    ------------- ------------
  ---

  --- ----- - --
  -------------- -- -
    ---------------- ---------------
    --------
  -- ------
---

---------------- -- -- -
  ---------------- ------ ------- -- ---- -------
---

在这个示例中,/sse 路由返回的是 SSE 格式的响应。在响应的头部中设置了 Content-TypeCache-ControlConnection 等参数。其中,Connection 设置为 keep-alive 表示 SSE 连接不会在每次请求结束后断开。而 Cache-Control 则设置为 no-cache 表示不缓存响应。

另外,通过 setInterval 定时器,每秒发送一条数据事件,格式为 data: <count>\n\n,其中 <count> 表示当前计数器的值。

下面是一个使用 JavaScript 的 SSE API 的客户端代码示例。它创建了一个 SSE 连接,接收来自服务器的事件,并显示了计数器的值。

-- -------------------- ---- -------
--------- -----
------
------
  ----- ----------------
  ---------- ---------------
-------
------
  ---- --------------------
  --------
    ----- --------- - -----------------------------------
    ----- ------ - --- --------------------
    ---------------------------------- ----- -- -
      ----- ----- - -------------------
      --------------------- - ------
    ---
  ---------
-------
-------

在这个示例中,通过 EventSource 创建了一个 SSE 连接,将 /sse 路由指定为连接的 URL。然后,通过 addEventListener 注册了一个 message 事件监听器,当接收到服务器发送的事件时,就会更新计数器的值。

总结

本文介绍了如何使用 SSE 实现实时数据推送功能。SSE 是一种基于 HTTP 协议的简单易用的技术,非常适合用于实现实时通信,比如实时聊天、实时统计等。它不需要客户端不断地发出请求,减轻了服务器的负担,同时也节省了带宽和服务器资源。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/65382d1d7d4982a6eb0d536e

纠错
反馈