本文实例讲述了nodejs结合socket.io实现websocket通信功能的方法。分享给大家供大家参考,具体如下:
因为项目中有需要实时获取后台数据的场景,之前一直是使用http心跳请求的方法。因为websocket与此模式相比有很大的性能提升,而且可以提高实时性,所以对websocket作了一些研究。这里是使用nodejs+socket.io来实现的。
达成目标
将原来心跳请求后台数据的方式,修改为通过socket连接后台统一推送的方式。后台的数据由别的进程写入文件或写入redis,这里实现的是读取文件的方式。
前期准备
安装nodejs(略)
服务器端
新建一个项目目录,这里是sockettest 进入sockettest目录,安装express模块和socketio模块
新建index.html,用于作为默认的访问显示页面,因为这里不会用到它,内容随意; 新建trends.js文件,在其中写入内容:
文件
app.get('/',function(req,res){
res.sendfile('index.html');
});
#用于存储所有socket以广播数据
var iolist = [];
#定义socket on connection(连入)事件行为
io.on('connection',function(socket){
#将连入socket加入列表
iolist.push(socket);
#记录index,在disconnect(断开连接)发生时将对应的socket删除
var sockex = iolist.indexOf(socket);
#定义on disconnect事件行为
socket.on('disconnect',function(){
#将断开连接的socket从广播列表里删除
iolist.splice(sockex,1);
});
});
# 数据广播进程:每1秒钟广播一次
setInterval(function() {
# 如果没有正在连接的socket,直接返回;
if (iolist.length <= 0) return;
var trends = fs.readFileSync('./data/trends.json','utf-8');#trends数据
var coins = fs.readFileSync('./data/coins.json','utf-8');#coins数据
#向所有socket连接发送数据
for (i in iolist) {
# 向客户端发送trends数据
iolist[i].emit('trends',trends);
# 向客户端发送coins数据
iolist[i].emit('coins',coins);
}
},1000);
# 服务器侦听在sockettest.com的3000端口上
http.listen(3000,function(){
# 输出到标准输出
console.log('listening on sockettest.com:3000');
});
新建data目录,并在下面新建两个文件trends与coins,用于存放socket服务器将要读取的数据。 新建public目录,在其中新建一个文件index.html,文件内容如下: