0

0

怎样利用Server-Sent Events实现服务端推送功能?

betcha

betcha

发布时间:2025-09-26 10:59:01

|

547人浏览过

|

来源于php中文网

原创

SSE基于HTTP实现服务端向浏览器的单向实时推送,使用EventSource API建立连接,服务端以text/event-stream格式持续发送数据,支持自动重连与自定义事件,适合通知类低频实时场景。

怎样利用server-sent events实现服务端推送功能?

Server-Sent Events(SSE)是一种让服务器主动向浏览器推送数据的技术,基于HTTP协议,使用简单,适合实时性要求不高的场景,比如通知、状态更新或实时日志展示。它比WebSocket轻量,且天然支持文本数据的有序传输。

基本原理

SSE 建立在标准 HTTP 之上,客户端通过 EventSource API 发起连接,服务端保持连接不关闭,并以特定格式持续发送数据。每次推送的消息都会触发客户端的 message 事件。

关键特点:

  • 单向通信:仅服务端推送到客户端
  • 自动重连:断开后客户端会尝试重新连接
  • 支持自定义事件类型
  • 数据格式为 text/event-stream

前端实现

使用原生 EventSource 即可监听服务端推送:

const eventSource = new EventSource('/api/sse');

eventSource.onmessage = function(event) {
  console.log('收到消息:', event.data);
};

eventSource.onerror = function(err) {
  console.error('SSE 连接出错', err);
};

// 可监听自定义事件
eventSource.addEventListener('customEvent', function(event) {
  console.log('自定义事件:', event.data);
});

后端实现(Node.js 示例)

服务端需设置正确的响应头,并持续输出符合 SSE 格式的数据:

PicWish
PicWish

推荐!专业的AI抠图修图,支持格式转化

下载
app.get('/api/sse', (req, res) => {
  // 设置响应头
  res.writeHead(200, {
    'Content-Type': 'text/event-stream',
    'Cache-Control': 'no-cache',
    'Connection': 'keep-alive'
  });

  // 发送普通消息
  setInterval(() => {
    res.write(`data: ${Date.now()}\n\n`);
  }, 1000);

  // 发送自定义事件
  setInterval(() => {
    res.write(`event: customEvent\ndata: {"msg": "hello"}\n\n`);
  }, 5000);

  // 客户端断开时清理
  req.on('close', () => {
    res.end();
  });
});

SSE 数据格式说明

每条消息由一个或多个字段组成,常见字段包括:

  • data: 消息内容,可多行,以 \n\n 结尾
  • event: 自定义事件名称,对应前端 addEventListener 的类型
  • id: 消息ID,用于断线重连时定位位置
  • retry: 重连间隔毫秒数

示例:

event: userUpdate
data: {"id": 123, "status": "online"}
id: 456
retry: 3000
\n\n

基本上就这些。只要前后端遵守 SSE 协议格式,就能轻松实现实时推送。相比轮询更高效,比 WebSocket 更简单,适合大多数通知类场景。注意连接长时间保持可能受代理或Nginx配置影响,需调整超时设置。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

227

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

490

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

496

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

219

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

327

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3500

2024.08.07

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.10.25

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号