websocket的封装

import { MessageWarning } from "./message";

import useMemberStore from "@/stores/member";

interface ISocket {

  websocket: any;

  connectURL: string;

  reconnect_count: number;

  reconnect_current: number;

  reconnect_timer: any;

  reconnect_interval: number;

  stopWs: boolean;

  init: (receiveMessage: Function | null, errorFun: Function | null) => any;

  send: (data: any) => void;

  close: () => void;

  handleReconnect: () => void;

}

const socket: ISocket = {

  websocket: null, //实例

  connectURL: "", //地址

  reconnect_timer: null, //重连timer

  reconnect_count: 3, //最大重连次数

  reconnect_current: 0, //已发起重连次数

  reconnect_interval: 10000, //重连频率

  stopWs: false, //彻底终止ws

  // 初始化连接

  init: (receiveMessage: Function | null, errorFun: Function | null) => {

    if (!("WebSocket" in window)) {

      MessageWarning("浏览器不支持WebDocket");

      return;

    }

    if (socket.reconnect_current === 0) {

      console.log("websocket", "初始化连接中...");

    }

    if (

      socket.websocket &&

      socket.websocket.readyState == socket.websocket.OPEN

    ) {

      return;

    }

    const memberStore = useMemberStore();

    if (!memberStore.token) return;

    socket.websocket = new WebSocket(socket.connectURL, [memberStore.token]);

    // 连接成功

    socket.websocket.onopen = () => {

      socket.stopWs = false;

      // 重置重连尝试成功连接

      socket.reconnect_current = 0;

      console.log("websocke", "连接成功,等待数据推送...");

    };

    socket.websocket.onmessage = (e: any) => {

      if (receiveMessage) {

        receiveMessage(e);

      }

    };



    socket.websocket.onclose = () => {

      if (socket.reconnect_current === 0) {

        console.log("websocket", "连接异常[onclose]...");

      }

      if (!socket.stopWs) {

        socket.handleReconnect();

      }

    };



    // 连接失败

    socket.websocket.onerror = () => {

      if (socket.reconnect_current === 0) {

        console.log("websocket", "连接失败[onerror]...");

      }

      if (errorFun) errorFun(socket.websocket.readyState);

    };

  },

  // 重连逻辑

  handleReconnect: () => {

    if (socket.reconnect_current < socket.reconnect_count) {

      socket.reconnect_current++;

      console.log("websocket", "尝试重连...");

      socket.reconnect_timer = setTimeout(() => {

        socket.init(null, null);

      }, socket.reconnect_interval);

    } else {

      clearTimeout(socket.reconnect_timer);

      console.log("wesocket", "最大重连失败,终止重连...");

    }

  },

  // 消息发送

  send: (data) => {

    // 开启状态直接发送

    if (

      socket.websocket &&

      socket.websocket.readyState === socket.websocket.OPEN

    ) {

      socket.websocket.send(JSON.stringify(data));

    } else {

      console.error("websocket", "未连接");

    }

  },

  // 关闭连接

  close: () => {

    if (socket.websocket) {

      console.log("关闭websocket...");

      socket.stopWs = true;

      socket.websocket.close();

      socket.websocket = null;

    }

  },

};

export default socket;

websocket在页面里使用

onMounted(()=>{
     socket.connectURL = `${import.meta.env.VITE_WS_AI_CHAT}`;
     await socket.init(receiveMessage, errorFun);
)
//处理接收的data

 const receiveMessage = (message: any) => {
        console.log(message.data)
 };

//websocket 连接失败,关闭sriptloading
 const errorFun = () => {
  
};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值