前端WebSocket配置

2023-05-16

代码

initWebSocket: function () {
      // WebSocket与普通的请求所用协议有所不同,ws等同于http,wss等同于https
      var url = "http://localhost:39010".replace("https://","wss://").replace("http://","ws://")+"/websocket/"+"1";
      console.log(url);
      this.websock = new WebSocket(url);
      this.websock.onopen = this.websocketOnopen;
      this.websock.onerror = this.websocketOnerror;
      this.websock.onmessage = this.websocketOnmessage;
      this.websock.onclose = this.websocketOnclose;
    },
    websocketOnopen: function () {
      console.log("WebSocket连接成功");
      //心跳检测重置
      //this.heartCheck.reset().start();
    },
    websocketOnerror: function (e) {
      console.log("WebSocket连接发生错误");
      this.reconnect();
    },
    websocketOnmessage: function (e) {
      console.log("-----接收消息-------",e.data);
      var data = eval("(" + e.data + ")"); //解析对象
      if(data.cmd == "time"){
        this.time = data.data;
      }else if(data.cmd == "random"){
        this.uuid = data.data.uuid;
      }

      //心跳检测重置
      //this.heartCheck.reset().start();
    },
    websocketOnclose: function (e) {
      console.log("connection closed (" + e + ")");
      if(e){
        console.log("connection closed (" + e.code + ")");
      }
      this.reconnect();
    },
    websocketSend(text) { // 数据发送
      try {
        this.websock.send(text);
      } catch (err) {
        console.log("send failed (" + err.code + ")");
      }
    },

    openNotification (data) {
      var text = data.msgTxt;
      const key = `open${Date.now()}`;
      this.$notification.open({
        message: '消息提醒',
        placement:'bottomRight',
        description: text,
        key,
        btn: (h)=>{
          return h('a-button', {
            props: {
              type: 'primary',
              size: 'small',
            },
            on: {
              click: () => this.showDetail(key,data)
            }
          }, '查看详情')
        },
      });
    },

    reconnect() {
      var that = this;
      if(that.lockReconnect) return;
      that.lockReconnect = true;
      //没连接上会一直重连,设置延迟避免请求过多
      setTimeout(function () {
        console.info("尝试重连...");
        that.initWebSocket();
        that.lockReconnect = false;
      }, 5000);
    },
    heartCheckFun(){
      var that = this;
      //心跳检测,每20s心跳一次
      that.heartCheck = {
        timeout: 2000,
        timeoutObj: null,
        serverTimeoutObj: null,
        reset: function(){
          clearTimeout(this.timeoutObj);
          //clearTimeout(this.serverTimeoutObj);
          return this;
        },
        start: function(){
          var self = this;
          this.timeoutObj = setTimeout(function(){
            //这里发送一个心跳,后端收到后,返回一个心跳消息,
            //onmessage拿到返回的心跳就说明连接正常
            that.websocketSend("HeartBeat");
            console.info("客户端发送心跳");
            //self.serverTimeoutObj = setTimeout(function(){//如果超过一定时间还没重置,说明后端主动断开了
            //  that.websock.close();//如果onclose会执行reconnect,我们执行ws.close()就行了.如果直接执行reconnect 会触发onclose导致重连两次
            //}, self.timeout)
          }, this.timeout)
        }
      }
    },
    getList: function(){
      var that = this;
      setInterval(function(){
        //这里发送一个心跳,后端收到后,返回一个心跳消息,
        //onmessage拿到返回的心跳就说明连接正常
        that.websocketSend("random");
        console.info("定时向服务器获取数据....");
        //self.serverTimeoutObj = setTimeout(function(){//如果超过一定时间还没重置,说明后端主动断开了
        //  that.websock.close();//如果onclose会执行reconnect,我们执行ws.close()就行了.如果直接执行reconnect 会触发onclose导致重连两次
        //}, self.timeout)
      }, 10000)
    }
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

前端WebSocket配置 的相关文章

随机推荐

  • Vue项目如何安装使用moment.js

    Vue项目如何安装使用moment js 1 什么是moment js 它是一个简单易用的轻量级Javascript日期处理类库 xff0c 提供了日期格式化 日期解析等功能 xff0c 且支持在浏览器和NodeJS两种环境中运行 2 Vu
  • 【Chrome插件】打包扩展程序错误:清单文件缺失或不可读取——正确打包步骤

    亲测有效 xff1a https www cnblogs com Marydon20170307 p 7114775 html utm source 61 itdadao amp utm medium 61 referral
  • 【Linux】conda: command not found解决办法

    在终端输入conda info envs检验anaconda是否安装成功 xff0c 发现报错 xff1a conda command not found 原因是因为 bashrc文件没有配置好 vim bashrc 在最后一行加上 exp
  • Linux下设置DISPLAY问题总结

    Linux下设置DISPLAY问题总结 问题描述 xff1a 想要在Linux下展示图形界面 xff0c 需要配置DISPLAY xff1b 如何通过命令进行配置 xff1f 一 export命令 export DISPLAY 61 这值代
  • iOS设置圆角的四种方法

    iOS设置圆角的四种方法 1 设置CALayer的cornerRadius2 设置CALayer的mask3 通过Core Graphics重新绘制带圆角的视图4 通过混合图层5 总结 1 设置CALayer的cornerRadius co
  • Python运行时,提示SyntaxError: invalid syntax怎么解决

    Python真是太火了 xff0c 最近我也入了Python的坑 xff0c 开始自学Python 昨天在编写一个基于python 3的小游戏 xff0c 但是出现了这个错误 xff1a SyntaxError xff1a invalid
  • hive:函数:json_tuple处理json数据

    在处理日志数据时 xff0c 会遇到json格式的数据 那么 xff0c 在hive中如何处理它呢 xff1f 一般情况下 xff0c json数据会以string类型 xff0c 字符串格式进行存储 创建案例 create databas
  • 知乎火爆问题:CV 和 NLP 哪个前景更好?

    又到一年毕业季 xff0c 小编看到不少马上要毕业的学生在知乎名为 cv和nlp哪个前景更好的 帖子下热烈讨论 xff01 xff08 图片来源于知乎 xff09 相信不少人有这样的疑问 xff0c 甚至有人说今天AI的行业 xff0c C
  • 旧电脑改造攻略

    1 手头电脑 联想A8 笔记本 xff08 A核A卡 xff09 华硕 i5 6033U xff08 A卡 xff09 Dell 笔记本 i5 NVIDIA 还能用 联想台式机 xff08 2G内存 xff0c 已经换SSD xff09 2
  • 大恒相机实时采图

    目录 前言正文准备工作设备的初始化设备信息的获取主动采图相机参数配置创建doc树获取doc树下的每一个元素并将其信息写入xml文件中 被动采图 总结 前言 本篇博客稍微记录一下我所写的插件 具体内容是有关于大恒相机的 xff0c 关于这个相
  • 转:MySQL 8.0 配置mysql_native_password身份验证插件的密码

    https blog csdn net zhengbin9 article details 82729861 方法一 xff1a 登录MySQL后输入 xff1a ALTER USER 39 root 39 64 39 localhost
  • Debian系统的LNMP网站(Web)环境搭建+MySQL数据库可视化工具phpMyAdmin的安装

    开始 提示 每次完成对Nginx PHP MariaDB phpMyAdmin做配置文件修改后 重启Nginx php mariadb服务再查看配置效果是一个好习惯 安装Nginx 1 安装Nginx 指令 sudo apt install
  • TDengine时序数据库性能测试

    前言 TDengine Database官方及社区里有一些性能测试对比案例 xff0c 不过发布的都比较早 xff0c 其使用的版本都是早期低版本 本次测试参考官方提测的 使用 taosdemo 对 TDengine 进行性能测试 文章进行
  • ubuntu安装anaconda后,终端输入conda,未找到命令解决

    1 linux出现permission denied权限不足的解决方案 输入 sudo chmod R 777 文件路径 执行完即可看到文件夹的锁消失了 2 ubuntu安装anaconda后 xff0c 终端输入conda xff0c 出
  • 用OpenCV实现目标追踪的八种方法(转)

    原文地址 xff1a http m elecfans com article 722414 html 编者按 xff1a 目标跟踪作为机器学习的一个重要分支 xff0c 加之其在日常生活 军事行动中的广泛应用 xff0c 很多国内外学者都对
  • selenium 常用API

    Selenium 常用API 之操作浏览器 上文我们讲解了如何打开浏览器 xff0c 本文讲讲解关于操作浏览器的更多API 后退 span class token comment 后退 span driver span class toke
  • JAVA List 获取两个集合的交集 并集 差集

    public class ExtractIdUtils public static Map lt String List lt Long gt gt extractList List lt Long gt newIds List lt Lo
  • 获取用户IP的API

    http span class token punctuation span span class token operator span pv span class token punctuation span sohu span cla
  • 矩阵相乘最优解

    define CRT SECURE NO WARNINGS include lt iostream gt include lt vector gt include lt algorithm gt using namespace std in
  • 前端WebSocket配置

    代码 initWebSocket span class token punctuation span span class token keyword function span span class token punctuation s