2

我正在使用 node.js 和 express.js 编写一个简单的聊天应用程序,感觉自己做错了什么。聊天本身在第一页加载时工作正常,但在每次重新加载页面时,我都会将所有消息打印两次或更多(取决于页面重新加载的数量)。看起来我在每次重新加载页面时都会创建新的侦听器。据我了解,我需要从路由器处理程序中移出侦听器代码(io.socket),但我不知道在哪里移动以及稍后如何调用它,以及页面请求上的渲染页面。任何帮助表示赞赏。谢谢。

这是我的应用程序代码:

./app.js

var express = require("express");
var app = express();
var test = require("./routes/test")

var port = 3000;
app.set("port", port);
app.set("views", __dirname + "/views");
app.set("view engine", "jade");

app.get("/test", test.test);

var io = require("socket.io").listen(app.listen(port));
app.set("io", io);

console.log("Listening on port " + port);

和 ./routes/test.js

exports.test= function(req, res) {

res.render('test');
var app = req.app;
var io = app.get('io');

io.sockets.on('connection', function (socket) {
    socket.emit('message', { message: 'welcome to the chat' });
    socket.on('send', function (data) {
        io.sockets.emit('message', data);
    });
});
}
4

2 回答 2

1

我在 test.js 中添加了一个 socket.io('disconnect', function () {...}) ,并在 'connection' 和 'disconnect' 事件中添加了 console.log(...) 。这证实了在第 n 个页面刷新时,服务器收到了 n 个断开连接和 n+1 个连接事件,这就是您所说的您所看到的。

您的页面刷新看起来像与 socket.io 的断开连接,它重新连接到丢失的连接,这会触发连接事件。同时你的 socket.io('connection', ...) 触发另一个连接。

每次刷新都会为传入消息添加一个侦听器,并且每个侦听器都会收到 socket.emit('message', ...) 消息。

我尝试了一些代码,如果您更改,您的代码应该运行

io.sockets.on('connection', function (socket) {

io.sockets.once('connection', function (socket) {

因为后者仅第一次运行事件处理程序。

于 2013-06-20T15:24:11.673 回答
0

我之前遇到过这个问题。

尝试将这些代码移到回调test.test 之外

io.sockets.on('connection', function (socket) {
    socket.emit('message', { message: 'welcome to the chat' });
    socket.on('send', function (data) {
        io.sockets.emit('message', data);
    });
});

希望这会有所帮助

于 2013-08-26T13:35:00.057 回答