vue3之 websoket发送消息

发布时间:2024-01-24 15:51:48

在这里插入图片描述

1.封装websoket

var ws = null; //建立的连接
var lockReconnect = false;//是否真正建立连接
var timeout = 6 * 1000 * 5;//30秒一次心跳
var timeoutObj = null;//心跳心跳倒计时
var serverTimeoutObj = null;//心跳倒计时
var timeoutnum = null;//断开 重连倒计时
var global_callback = null; //监听服务端消息
var openId = localStorage.getItem('openId')
// uri: 长链接地址<br>// jwt: 前后端连接凭证, 按需添加<br>// callback: 服务端消息回调函数
export function createWebscoket(uri, callback) {
    global_callback = callback
    ws = new WebSocket(uri)
    ws.onopen = () => {
        lockReconnect = true
        ws.send(JSON.stringify({ "userId": openId, "toUserId": openId, "msgType": 0 }));
        //开启连接心跳
        start()
    }
    ws.onmessage = onMessage
    ws.onerror = onError
    // ws.onclose = onClose
    ws.onsend = onSend
}

//发送消息
export function onSend(message) {
    console.log(`发送消息: ${message}`)
    console.log(ws.readyState)
    if (ws.readyState != 1) {
        reset()
        // reconnect()
        // ws.send(message)
    } else {
        ws.send(message)
    }

}

//接受服务端消息
// export function onMessage(res) {
//     let msgData = res ? res.data : {}
//     console.log(msgData)
//     if (typeof msgData != 'object') {
//         // var data = msgData.replace(/\ufeff/g, "");
//         var message = JSON.parse(msgData);
//         if (message.code == 0) {
//             return 
//         } else {
//             //重置心跳
//             reset()
//         }
//         //服务端消息回掉
//         // ws.onmessage()
//         global_callback(message)
//         // console.log(   ws.onmessage())
//     }
// }
export function onMessage(res){
    let msgData = res ? res.data : {}
    if (typeof msgData != 'object' && msgData != 'Connect success') {
      var data = msgData.replace(/\ufeff/g, "");
      var message = JSON.parse(data)
     //服务端消息回掉
      global_callback(message)
     //重置心跳
      reset()
    }
  }
   
//连接失败
export function onError() {
    console.log('连接失败')
    ws.close()
    ws = null
    lockReconnect = false
}

//连接关闭
export function onClose() {
    console.log('连接关闭')
}
//断开关闭
export function closeWs() {
    if (lockReconnect) {
        ws.close()
        ws = null
        lockReconnect = false
    }
}

// 发送心跳
export function start() {
    timeoutObj && clearTimeout(timeoutObj);
    serverTimeoutObj && clearTimeout(serverTimeoutObj);
    timeoutObj = setTimeout(function () {
        //这里发送一个心跳,后端收到后,返回一个心跳消息
        if (ws.readyState == 1) { //如果连接正常
            ws.send(JSON.stringify({ "userId": openId, "toUserId": openId, "msgType": 0 }));
            // ws.send(data)
        } else {  //否则重连
            reconnect()
        }
        serverTimeoutObj = setTimeout(function () {
            //超时关闭
            ws.close();
        }, timeout);
    }, timeout + 3000)
}
//重置心跳
export function reset() {
    var that = this;
    //清除时间
    clearTimeout(timeoutObj);
    //清除时间
    clearTimeout(serverTimeoutObj);
    start(); //重启心跳
}

//重新连接
export function reconnect() {
    if (lockReconnect) {
        return;
    };
    lockReconnect = true;
    //没连接上会一直重连,设置延迟避免请求过多
    timeoutnum && clearTimeout(timeoutnum);
    timeoutnum = setTimeout(function () {
        createWebscoket();//新连接
        lockReconnect = false;
    }, 5000);
}

2.页面调用

import { createWebscoket, onSend, closeWs, start } from '@/utils/socket.js'
onMounted(() => {
     let host = process.env.VUE_APP_WS_HOST //ws地址
    createWebscoket(host + token.value, messagesCallBack)
  })

//新消息监听
const messagesCallBack = (msg) => {
  console.log(msg)
}


//断开socket
const closeWsTxt = () => {
  closeWs()
}

//发送socket消息到服务器
const sendMessagext = (data) => {
  onSend(JSON.stringify(data))
}
文章来源:https://blog.csdn.net/weixin_42268006/article/details/135821221
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。