SSE是基于HTTP的服务器向浏览器推送技术,使用EventSource API实现,适合日志、通知等场景。前端通过onmessage和addEventListener接收消息,后端以text/event-stream类型发送数据,每条消息以\n\n结尾,支持事件类型与自动重连。Node.js可用Express写入流式响应,Nginx需关闭缓冲,服务端可发心跳防超时,消息可通过id标识与Last-Event-ID恢复,实现简单高效的实时更新。

服务器推送事件(Server-Sent Events,简称 SSE)是一种让服务器通过 HTTP 连接持续向浏览器推送数据的技术。相比 WebSocket,SSE 更轻量、使用简单,适用于日志实时更新、通知推送、股票行情等场景。本文带你实战 JavaScript 中的 SSE 技术,掌握其核心用法与常见问题处理。
SSE 基于 HTTP 协议,允许服务器单向向客户端发送文本数据流。客户端使用 EventSource API 接收消息,连接自动重连,支持事件类型区分,适合服务端主动推送更新的场景。
与 WebSocket 不同,SSE 是单向通信(仅服务端 → 客户端),但胜在简单、兼容性好、可利用现有 HTTP 机制(如认证、CORS)。
JavaScript 提供了原生的 EventSource 接口,使用非常直观:
立即学习“Java免费学习笔记(深入)”;
const eventSource = new EventSource('/api/stream');
eventSource.onmessage = function(event) {
console.log('收到消息:', event.data);
};
eventSource.addEventListener('notification', function(event) {
console.log('通知:', event.data);
});
eventSource.onerror = function(err) {
console.error('SSE 连接出错', err);
};
说明:
悟空CRM是一种客户关系管理系统软件.它适应Windows、linux等多种操作系统,支持Apache、Nginx、IIs多种服务器软件。悟空CRM致力于为促进中小企业的发展做出更好更实用的软件,采用免费开源的方式,分享技术与经验。 悟空CRM 0.5.5 更新日志:2017-04-21 1.修复了几处安全隐患; 2.解决了任务.日程描述显示问题; 3.自定义字段添加时自动生成字段名
284
以 Express 为例,实现一个简单的 SSE 接口:
app.get('/api/stream', (req, res) => {
// 设置响应头
res.writeHead(200, {
'Content-Type': 'text/event-stream',
'Cache-Control': 'no-cache',
'Connection': 'keep-alive',
'Access-Control-Allow-Origin': '*'
});
// 发送一条普通消息
res.write('data: 欢迎连接到 SSE 服务\n\n');
// 定时推送时间
const interval = setInterval(() => {
res.write(`data: ${new Date().toLocaleTimeString()}\n\n`);
}, 1000);
// 自定义事件推送
setInterval(() => {
res.write('event: notification\n');
res.write('data: 系统有新消息提醒\n\n');
}, 5000);
// 客户端断开时清理
req.on('close', () => {
clearInterval(interval);
res.end();
});
});
关键点:
SSE 虽然简单,但在生产中需要注意以下几点:
基本上就这些。SSE 技术门槛低、调试方便,特别适合不需要双向通信的实时场景。只要前后端配合好协议格式和连接管理,就能快速实现稳定的消息推送功能。
以上就是JavaScriptSSE技术_服务器推送事件实战应用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号