首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在Node.js中实现服务器发送事件的简单方法?

在Node.js中实现服务器发送事件的简单方法?
EN

Stack Overflow用户
提问于 2016-03-28 00:19:48
回答 6查看 27.7K关注 0票数 14

我环顾四周,似乎所有在Node.js中实现SSE的方法都是通过更复杂的代码实现的,但似乎应该有一种更简单的发送和接收SSE的方法。有没有什么API或模块可以让这一切变得更简单?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2016-05-16 00:38:03

您应该能够使用Socket.io来做这样的事情。首先,您需要使用npm install socket.io安装它。在那里,在您的代码中,您将希望拥有var io = require(socket.io);

你可以看到more in-depth examples given by Socket.IO

您可以在服务器上使用类似以下内容:

代码语言:javascript
复制
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('../..')(server);
var port = process.env.PORT || 3000;

server.listen(port, function () {
  console.log('Server listening at port ' + port);
});

app.use(express.static(__dirname + '/public'));

io.on('connection', function (socket) {
    socket.emit('EVENT_NAME', {data});
});

在客户机上是这样的:

代码语言:javascript
复制
<script src="socket_src_file_path_here"></script>
<script>
  var socket = io('http://localhost');
  socket.on('EVENT_NAME', function (data) {
    console.log(data);
    //Do whatever you want with the data on the client
  });
</script>
票数 -40
EN

Stack Overflow用户

发布于 2018-05-30 07:15:44

下面是一个express服务器,它每秒发送一个Server-Sent Event (SSE),从10倒数到0:

代码语言:javascript
复制
const express = require('express')

const app = express()
app.use(express.static('public'))

app.get('/countdown', function(req, res) {
  res.writeHead(200, {
    'Content-Type': 'text/event-stream',
    'Cache-Control': 'no-cache',
    'Connection': 'keep-alive'
  })
  countdown(res, 10)
})

function countdown(res, count) {
  res.write("data: " + count + "\n\n")
  if (count)
    setTimeout(() => countdown(res, count-1), 1000)
  else
    res.end()
}

app.listen(3000, () => console.log('SSE app listening on port 3000!'))

将上面的代码放入一个文件(index.js)并运行它:node index

接下来,将以下HTML放入一个文件(public/index.html):

代码语言:javascript
复制
<html>
<head>
  <script>
  if (!!window.EventSource) {
    var source = new EventSource('/countdown')

    source.addEventListener('message', function(e) {
      document.getElementById('data').innerHTML = e.data
    }, false)

    source.addEventListener('open', function(e) {
      document.getElementById('state').innerHTML = "Connected"
    }, false)

    source.addEventListener('error', function(e) {
      const id_state = document.getElementById('state')
      if (e.eventPhase == EventSource.CLOSED)
        source.close()
      if (e.target.readyState == EventSource.CLOSED) {
        id_state.innerHTML = "Disconnected"
      }
      else if (e.target.readyState == EventSource.CONNECTING) {
        id_state.innerHTML = "Connecting..."
      }
    }, false)
  } else {
    console.log("Your browser doesn't support SSE")
  }
  </script>
</head>
<body>
  <h1>SSE: <span id="state"></span></h1>
  <h3>Data: <span id="data"></span></h3>
</body>
</html>

在浏览器中,打开localhost:3000并观察上交所的倒计时。

票数 50
EN

Stack Overflow用户

发布于 2018-04-11 17:14:31

我在这里添加了一个简单的SSE实现。这只是一个Node.js文件。

您可以在此处查看结果:https://glossy-ox.glitch.me/

代码语言:javascript
复制
const http = require('http');
const port = process.env.PORT || 3000;

const server = http.createServer((req, res) => {
  // Server-sent events endpoint
  if (req.url === '/events') {
    res.writeHead(200, {
      'Content-Type': 'text/event-stream',
      'Cache-Control': 'no-cache',
      'Connection': 'keep-alive',
    });

    const refreshRate = 1000; // in milliseconds
    return setInterval(() => {
      const id = Date.now();
      const data = `Hello World ${id}`;
      const message =
        `retry: ${refreshRate}\nid:${id}\ndata: ${data}\n\n`;
      res.write(message);
    }, refreshRate);
  }

  // Client side
  res.writeHead(200, {'Content-Type': 'text/html'});
  res.end(`
    <!DOCTYPE html>
    <html lang="en" dir="ltr">
      <head>
        <meta charset="utf-8">
        <title>SSE</title>
      </head>
      <body>
        <pre id="log"></pre>
      </body>
      <script>
        var eventSource = new EventSource('/events');
        eventSource.onmessage = function(event) {
          document.getElementById('log').innerHTML += event.data + '<br>';
        };
      </script>
    </html>
  `);
});

server.listen(port);

server.on('error', (err) => {
  console.log(err);
  process.exit(1);
});

server.on('listening', () => {
  console.log(`Listening on port ${port}`);
});
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36249684

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档