上次我们讲过了websocket断线重连的问题,那么久会有人提出疑问了,心跳包重连跟断线重连有什么区别呢?
其实这两个都是为了达到一个目的,那就是保证当前设备的网络状态保持通畅。。。而断线重连呢,只能保证网络失去连接的时候有效,并不能保证网络断开的时候有效。。。这么说可能就有很多人迷糊了,这两者之间有什么区别呢?
其实很简单哈,至少我是这么理解的。网络失去连接的时候是你手动关闭网络或禁用网络时,这个时候会触发到websocket中的onclose事件,也就是说他会触发断线重连,
而网络断开的时候呢,指的是比较简单粗暴的方法,例如直接拔网线之类的。。。。而这个时候呢是不会触发onclose事件的,那这个时候我们要怎么办呢,我们就需要用到心跳重连了
好啦,说了这么多,现在我们直接来看代码吧。。。。
首先是断线重连,这个我们就不说了,如果没明白的可以去看我写的另外一篇关于断线重连的文章,这里我就不多说了。。。。
那么我们重点来讲一下心跳包重连
if (jsonGotData.hasOwnProperty('id')) {
timestampVal = new Date(jsonGotData.now_time);
heartbeatLive(webSocket, timestampVal);
}
if (jsonGotData.hasOwnProperty('heartbeat')) {
timestampVal = new Date(jsonGotData.heartbeat);
return heartbeatLive(webSocket, timestampVal);
}
这是在onmessage中收到信息时候的处理,那么我们来具体分析
if (jsonGotData.hasOwnProperty('id')) {
timestampVal = new Date(jsonGotData.now_time);
heartbeatLive(webSocket, timestampVal);
}
首先这里我们是判断服务端发送的是不是id字段,这使得我们可以来初始化发送时间
if (jsonGotData.hasOwnProperty('heartbeat')) {
timestampVal = new Date(jsonGotData.heartbeat);
return heartbeatLive(webSocket, timestampVal);
}
然后是判断服务端有没有发送heartbeat字段来判断是不是在心跳周期之内
OK,那么来看具体的心跳函数
heartbeatLive = (function(_this) {
return function(conn, nowTime) {
var nowtime, hbt;
nowtime = new Date();
if ((nowTime.add({
minutes: 1
})).isBefore(androidNowtime)) {
clearTimeout(hbt);
return newConnection();
}
return hbt = setTimeout(function() {
return conn.send('heartbeat');
}, 60000);
};
})(this);
这个心跳函数的功能是怎么样的呢,主要的逻辑是将本地的时间与获取到服务器的心跳时间做一个比较,判断我们的心跳阶段是不是处于一个“健康期”,如果存在的话,那自然是继续正常的心跳啦,那如果不正常的话,我们就要来重连了。。。
而我们用这个心跳重连的方法呢,就可以保证某些傻小白把网线给拔了,都不知道问题出在哪里,这样就可以放心地使用我们的消息推送了,哈哈。。。
来源:oschina
链接:https://my.oschina.net/u/2658398/blog/634947