WebSocket
自动断开的情况
在此,提供一个使用定时器的解决方案 …【分析原因】
WebSocket断开原因、心跳机制防止自动断开连接
【解决步骤】
// 心跳间隔
$gateway->pingInterval = 60;
$gateway->pingNotResponseLimit = 1; // 代表客户端必须定时发送心跳给服务端
$gateway->pingData = '';
var interval_timer = null;//计时器
var timer_count = 0;
var ws = new WebSocket("wss://eee.com/ssssmn");
ws.onmessage = function (e) {
var message = eval('(' + e.data + ')');
switch (message.type) {
case 'init':
changeNoReadLogs();
var bind = '{"type":"bind","from_id":"' + from_id + '","to_id":"' + to_id + '"}';
ws.send(bind);
message_load();
break;
....... 具体代码省略......
}
};
ws.onclose = function (e) {
console.log('websocket 断开: ' + e.code + ' ' + e.reason + ' ' + e.wasClean);
};
// 开启定时器
init_start_timer();
/**
* 设置一个 30秒的轮询监听方法,避免页面关闭
*/
function init_start_timer() {
//重置计数器
timer_count = 0;
if(interval_timer != null){
clearInterval(interval_timer);
interval_timer = null;
}
interval_timer = setInterval(function(){ myTimer() }, 30000);
}
/**
*定时器具体实现方法
*/
function myTimer() {
//TODO 如果超过半小时没有交互,则关闭计时器
if(timer_count >= 1800){
clearInterval(interval_timer);
}else {
timer_count += 30;
var online = '{"type":"timer","from_id":"' + from_id + '","to_id":"' + to_id + '"}';
ws.send(online);
console.log('timer_count',timer_count);
}
}
然后,注意在发送消息时,比如点击发送键时首先判断用户是否在线,如果还是在线状态就再次调用 "init_start_timer()"
从而初始化定时计数
/**
* 判断当前用户是否 还在线
*/
function isOnlineCurrUser() {
if(ws.readyState == WebSocket.OPEN){
console.log('open',ws.readyState);
init_start_timer();
return true;
}else {
console.log('close',ws.readyState);
return false;
}
}
【参考文章】