vue3之 websoket发送消息

在这里插入图片描述

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))
}
  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue3中使用WebSocket需要通过导入socket.io-client模块的io方法来创建WebSocket连接的实例。具体的代码示例如下: 在.vue组件中,你可以按需导入io方法: ```javascript import { io } from 'socket.io-client' ``` 然后,在需要使用WebSocket的地方,你可以使用io方法创建WebSocket连接的实例,如下所示: ```javascript const socket = io('url') ``` 其中,'url'是WebSocket服务器的地址。 你可以根据需要,通过socket实例来进行WebSocket的各种操作,比如发送消息、接收消息、关闭连接等。具体的操作方法可以根据你的需求来调用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [使用vue3简单实现WebSocket通信](https://blog.csdn.net/weixin_44096999/article/details/131204105)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue中使用websocket](https://download.csdn.net/download/weixin_38747444/14040501)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vue3中websocket用法](https://blog.csdn.net/yusirxiaer/article/details/120257358)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jiojio冲冲冲

能帮助你是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值