websocket长连接

1.安装依赖

2.新建websocket.js文件

import { Notification } from "element-ui";
import store from '../store'
// import { getToken } from "../utils/token";
 
var socket = null;//实例对象
var lockReconnect = false; //是否真正建立连接
// var timeout = store.state?.miaEnv?.heartbeatTimeout || 60 * 1000; //60秒一次心跳
var timeoutObj = null; //心跳倒计时
var serverTimeoutObj = null; //服务心跳倒计时
var timeoutnum = null; //断开 重连倒计时
 
const initWebSocket = async () => {
  if ("WebSocket" in window) {
    // const wsUrl = '链接地址';
    const token = store.state.loginInfo.accessToken
    const miaUniqueCode = store.state.miaEnv.miaUniqueCode
    // 初始化 这里的回调:在不发送数据时,其他链接发送了数据,通过这个回调接收数据
    const wsUrl = `${store.state.miaEnv.miaWebSocketUrl}/websocket?deptId=${store.state.userInfo.deptId}&token=${token}&miaUniqueCode=${miaUniqueCode}`
    console.log('wsUrl',wsUrl)
    socket = new WebSocket(wsUrl);
    socket.onerror = webSocketOnError;
    socket.onmessage = webSocketOnMessage;
    socket.onclose = closeWebsocket;
    socket.onopen = openWebsocket;
  } else {
    Notification.error({
      title: "错误",
      message: "您的浏览器不支持websocket,请更换Chrome或者Firefox",
    });
  }
}
 
//建立连接
const openWebsocket = (e) => {
  start();
}
 
const start = ()=> {
  const timeout = store.state?.miaEnv?.heartbeatTimeout || 60 * 1000; //60秒一次心跳
  //开启心跳
  timeoutObj && clearTimeout(timeoutObj);
  serverTimeoutObj && clearTimeout(serverTimeoutObj);
  timeoutObj = setTimeout(function() {
    console.log("心跳HeartBeat",socket.readyState);
    //这里发送一个心跳,后端收到后,返回一个心跳消息
    if (socket.readyState == 1) {
      //如果连接正常
      socket.send("HeartBeat");
    } else {
      console.log("重连");
      //否则重连
      reconnect();
    }
    
    serverTimeoutObj = setTimeout(function() {
      //超时关闭
      socket.close();
    }, timeout);
  }, timeout);
}
 
//重新连接
const reconnect =() => { 
  if (lockReconnect) {
    return;
  }
  lockReconnect = true;
  //没连接上会一直重连,设置延迟避免请求过多
  timeoutnum && clearTimeout(timeoutnum);
  timeoutnum = setTimeout(function() {
    //新连接
    initWebSocket();
    lockReconnect = false;
  }, 1000);
}
 
//重置心跳
const reset =() => {
  //清除时间
  clearTimeout(timeoutObj);
  clearTimeout(serverTimeoutObj);
  //重启心跳
  start();
}
 
const sendWebsocket =(e) =>{
  socket.send(`我发消息了`);
}
 
const webSocketOnError =(e) => {
  initWebSocket();
  reconnect();
  
}
 
//服务器返回的数据
const webSocketOnMessage=(e) => {
  //判断是否登录
  if (store?.state?.loginInfo?.accessToken && store?.state?.loginInfo?.refreshToken) {
    //window自定义事件[下面有说明]
    window.dispatchEvent(
      new CustomEvent("onmessageWS", {
        detail: {
          data: JSON.parse(e?.data),
        },
      })
    );
  }
  reset();
}
 
const closeWebsocket=(e) => {
  reconnect();
}
 
//断开连接
const close =() => {
//WebSocket对象也有发送和关闭的两个方法,只需要在自定义方法中分别调用send()和close()即可实现。
  socket.close();
}
//具体问题具体分析,把需要用到的方法暴露出去
export default { initWebSocket, sendWebsocket, webSocketOnMessage, close };

3.全局注册

import websocket from './util/websocket';
Vue.prototype.$websocket = websocket;

4.使用

// 登陆
loginSuccess(res) {
    this.$websocket.initWebSocket();//websocket连接
    window.addEventListener("onmessageWS", this.getSocketData);//接收websocket连接后台返回的消息
    //监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接
    window.onbeforeunload = () => {
        this.$websocket.close();
    }
},
// 登出
logOff() {
    this.$websocket.close();
},

待补充:订阅模式

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值