前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WebSocket is already in CLOSING or CLOSED state. 报错信息的解决方案

WebSocket is already in CLOSING or CLOSED state. 报错信息的解决方案

作者头像
泥豆芽儿 MT
发布2020-11-02 14:34:02
8.5K0
发布2020-11-02 14:34:02
举报
文章被收录于专栏:木头编程 - moTzxx
  • 背景 近期在对 【GatewayWorker】的开发过程中 注意到,当客户端长时间没有反应时,会发生 WebSocket 自动断开的情况 在此,提供一个使用定时器的解决方案 …

【分析原因】

【解决步骤】

  • 第一步、首先,根据前面的手册介绍,我在服务端补充了如下的代码:
代码语言:javascript
复制
// 心跳间隔
$gateway->pingInterval = 60;
$gateway->pingNotResponseLimit = 1; // 代表客户端必须定时发送心跳给服务端
$gateway->pingData = '';
  • 第二步、在客户端创建 连接及定时器核心代码如下:
代码语言:javascript
复制
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()" 从而初始化定时计数

代码语言:javascript
复制
  /**
   * 判断当前用户是否 还在线
   */
  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;
      }
  }
  • 第三步、测试效果 (基本解决了我的需求)

【参考文章】

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/10/27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档