feat: node原生实现sse连接

main
LCJ-MinYa 10 months ago
parent ed2571b851
commit 219f431053

@ -0,0 +1,57 @@
import http from 'http';
const server = http.createServer(async (req, res) => {
// 设置 CORS 头
res.setHeader('Access-Control-Allow-Origin', '*'); // 允许所有域名访问
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS'); // 允许的 HTTP 方法
res.setHeader('Access-Control-Allow-Headers', 'Content-Type'); // 允许的请求头
if (req.method === 'OPTIONS') {
// 对于预检请求,直接返回
res.writeHead(204);
res.end();
return;
}
if (req.url === '/events') {
// 设置响应头
res.writeHead(200, {
'Content-Type': 'text/event-stream',
'Cache-Control': 'no-cache',
Connection: 'keep-alive',
});
// 发送事件
const sendEvent = (msg) => {
return new Promise((resolve) => {
setTimeout(() => {
const data = `data: ${msg ? msg : new Date().toLocaleTimeString()}\n\n`;
res.write(data);
resolve();
}, 1000);
});
};
// 每秒发送一次消息
await sendEvent('Start');
for (let i = 0; i < 10; i++) {
await sendEvent();
}
await sendEvent('End');
res.end();
// 清理连接
req.on('close', () => {
console.log('Client disconnected');
res.end();
});
} else {
res.writeHead(404);
res.end();
}
});
// 监听端口
server.listen(3000, () => {
console.log('SSE server is running at http://localhost:3000/events');
});

@ -0,0 +1,13 @@
{
"name": "node-local-server",
"version": "1.0.0",
"description": "",
"main": "index.js",
"type": "module",
"scripts": {
"start": "node ./index.js"
},
"keywords": [],
"author": "",
"license": "ISC"
}
Loading…
Cancel
Save