我有一个节点快速服务器,我用它作为后端来支持我网站上的即时聊天功能。我遇到的问题是当有人关闭他们的浏览器时,他们的状态不会在他们朋友的好友列表中更新为“离线”。我知道节点中有一个名为req.on的函数('close',function(){});但我只是不确定如何将它包含在我的服务器文件中。任何正确方向的提示将不胜感激。以下是我认为相关的快速服务器代码片段:
var app = express();
app.use(express.methodOverride());
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "X-Requested-With");
next();
});
app.use(require('./middleware/im')({
maxAge: 60 * 1000,
reapInterval: 60 * 1000,
authentication: require('./libs/authentication/' + AUTH_LIBRARY)
}));
app.set('root', __dirname);
//监听端点;在中间件中处理 app.get('/ listen',function(){});
app.post('/message', function(req, res) {
res.find(req.body['to'], function(user) {
if(!user)
return res.send(new packages.Error('not online'));
res.message(user, new packages.Message(
req.session.data('username'),
req.body.body
));
});
});
app.post('/message/typing', function(req, res) {
if(~packages.TYPING_STATES.indexOf('typing' + req.body['state'])) {
res.find(req.body['to'], function(user) {
if(user) {
res.message(user, new packages.Status(
req.session.data('username'),
'typing' + req.body.state
));
}
// Typing updates do not receive confirmations,
// as they are not important enough.
res.send('');
});
} else {
res.send(new packages.Error('invalid state'));
}
});
app.post('/status', function(req, res) {
if(~packages.STATUSES.indexOf(req.body['status'])) {
res.status(req.body.status, req.body.message);
res.send(new packages.Success('status updated'));
} else {
res.send(new packages.Error('invalid status'));
}
});
app.post('/clear', function(req, res) {
app.use(require('./middleware/im')({
clear: req.sessionID,
maxAge: 60 * 1000,
reapInterval: 60 * 1000,
authentication: require('./libs/authentication/' + AUTH_LIBRARY)
}));
req.sessionID = null;
res.send(new packages.Success('cleared session'));
app.use(require('./middleware/im')({
clear: 0,
maxAge: 60 * 1000,
reapInterval: 60 * 1000,
authentication: require('./libs/authentication/' + AUTH_LIBRARY)
}));
});
app.post('/online', function(req, res) {
var d = new Date();
var n = d.getTime() + 60;
req.sessionID.expires = n;
res.status(req.body.status, 'available');
res.send(new packages.Success('Online'));
});
app.post('/signoff', function(req, res) {
res.signOff();
res.send(new packages.Success('goodbye'));
});
https.createServer(options, app).listen(8000);
答案 0 :(得分:2)
HTTP是无状态协议,因此它没有“连接用户”的任何概念。您需要使用某种客户端机制在用户导航时通知您的服务器(可能使用向服务器发送消息的onbeforeunload
处理程序)。你提到的close
事件是没用的,除非你使用某种长轮询机制(但我不认为你是这样)。
要实现聊天,更好的解决方案可能是socket.io
,它可以在浏览器和服务器之间保持永久连接,并且内置机制可以通知浏览器是否已关闭连接(如果用户导航例如,离开。