IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> vue+websocket封装使用 -> 正文阅读

[网络协议]vue+websocket封装使用

创建一个websocket.js

import { Message } from 'element-ui'
// websocket实例
let wsObj = null;
// ws连接地址
let wsUrl = null;
// let userId = null;
// 是否执行重连 true/不执行 ; false/执行
let lockReconnect = false;
// 重连定时器
let wsCreateHandler = null;
// 连接成功,执行回调函数
let messageCallback = null;
// 连接失败,执行回调函数
let errorCallback = null;
// 发送给后台的数据
let sendDatas = {};

//20秒一次心跳
let timeout = 10 * 1000; 
//心跳心跳倒计时
let timeoutObj = null; 
//心跳倒计时
let serverTimeoutObj = null; 


/**
 * 发起websocket请求函数
 * @param {string} url ws连接地址
 * @param {Object} agentData 传给后台的参数
 * @param {function} successCallback 接收到ws数据,对数据进行处理的回调函数
 * @param {function} errCallback ws连接错误的回调函数
 */
export const connectWebsocket = (url, agentData, successCallback, errCallback) => {
    wsUrl = url;
    createWebSoket();
    messageCallback = successCallback;
    errorCallback = errCallback;
    sendDatas = agentData;
}

// 手动关闭websocket (这里手动关闭会执行onclose事件)
export const closeWebsocket = () => {
    if (wsObj) {
        writeToScreen('手动关闭websocket');
        wsObj.close() // 关闭websocket
        // wsObj.onclose() // 关闭websocket(如果上面的关闭不生效就加上这一条)
        // 关闭重连
        lockReconnect = true;
        wsCreateHandler && clearTimeout(wsCreateHandler);
    }
}

// 创建ws函数
const createWebSoket = () => {
    if (typeof (WebSocket) === 'undefined') {
        Message.error("您的浏览器不支持WebSocket,无法获取数据");
        return false
    }
    try {
        wsObj = new WebSocket(wsUrl);
        initWsEventHandle();
    } catch (e) {
        Message.error("连接异常,开始重连");
        reconnect();
    }
}

const initWsEventHandle = () => {
    try {
        // 连接成功
        wsObj.onopen = (event) => {
            onWsOpen(event);
            // 开启心跳
            heartCheckWebSocket();
        }

        // 监听服务器端返回的信息
        wsObj.onmessage = (event) => {
            onWsMessage(event);
        }

        wsObj.onclose = (event) => {
            writeToScreen('onclose执行关闭事件');
            onWsClose(event);
        }

        wsObj.onerror = (event) => {
            Message.error('onerror执行error事件,开始重连');
            onWsError(event);
            reconnect();
        }
    } catch (err) {
        Message.error('绑定事件没有成功,开始重连');
        reconnect();
    }
}

const heartCheckWebSocket = () => {
    timeoutObj && clearTimeout(timeoutObj);
    serverTimeoutObj && clearTimeout(serverTimeoutObj);
    timeoutObj = setTimeout(function() {
        //这里发送一个心跳,后端收到后,返回一个心跳消息
        if (wsObj.readyState == 1) {
            //如果连接正常
            wsObj.send("heartBeat");
        } else {
            //否则重连
            reconnect();
        }
        serverTimeoutObj = setTimeout(function() {
            //超时关闭
            wsObj.close();
        }, timeout);
    }, timeout);
}

const heartCheckWebSocketReset = () => {
    //清除时间
    clearTimeout(timeoutObj);
    clearTimeout(serverTimeoutObj);
    // 重置心跳
    heartCheckWebSocket();
}

const onWsOpen = (event) => {
    writeToScreen('CONNECT');
    // // 客户端与服务器端通信
    // wsObj.send('我发送消息给服务端');
    // 添加状态判断,当为OPEN时,发送消息
    if (wsObj.readyState === wsObj.OPEN) { // wsObj.OPEN = 1
        console.log("开始通信发送消息")
        // 发给后端的数据需要字符串化
        wsObj.send(JSON.stringify(sendDatas));
    }
    if (wsObj.readyState === wsObj.CLOSED) { // wsObj.CLOSED = 3
        writeToScreen('wsObj.readyState=3, ws连接异常,开始重连');
        reconnect();
        errorCallback();
    }
}
const onWsMessage = (event) => {
    const jsonStr = event.data;
    // writeToScreen('onWsMessage接收到服务器的数据: '+event);
    messageCallback(jsonStr);
    // 收到服务数据信息,重置心跳
    heartCheckWebSocketReset() 
}
const onWsClose = (event) => {
    writeToScreen('DISCONNECT');
    // e.code === 1000  表示正常关闭。 无论为何目的而创建, 该链接都已成功完成任务。
    // e.code !== 1000  表示非正常关闭。
    console.log('onclose event: ', event)
    if (event && event.code !== 1000) {
        writeToScreen('非正常关闭');
        errorCallback();
        // 如果不是手动关闭,这里的重连会执行;如果调用了手动关闭函数,这里重连不会执行
        reconnect();
    }
}
const onWsError = (event) => {
    writeToScreen('onWsError: ', event.data);
    errorCallback();
}

const writeToScreen = (massage) => {
    console.log(massage);
}

// 重连函数
const reconnect = () => {
    if (lockReconnect) {
        return;
    }
    writeToScreen('3秒后重连');
    lockReconnect = true;
    // 没连接上会一直重连,设置延迟避免请求过多
    wsCreateHandler && clearTimeout(wsCreateHandler);
    wsCreateHandler = setTimeout(() => {
        writeToScreen('重连...' + wsUrl);
        createWebSoket();
        lockReconnect = false;
        writeToScreen('重连完成');
    }, 3000);
}

在vue页面中移入该JS

import {connectWebsocket, closeWebsocket} from "@/api/websocket"

注:自己引入自己vue文件下的该文件路径

使用方法websocket.js方法

methods: {
    // ws连接成功,后台返回的ws数据,组件要拿数据渲染页面等操作
            wsMessage (data) {
                console.log(data,"链接成功的回调");
            },
            // ws连接失败,组件要执行的代码
            wsError () {
                console.log("链接失败的回调");
            },
},
created(){
let taskIds = '';
    connectWebsocket(
                // 链接地址
                "ws://192.168.6.215:18058",
                // 传递给后台的数据
                taskIds,
                // 成功拿到后台返回的数据的回调函数
                this.wsMessage,
                // websocket连接失败的回调函数
                this.wsError
            );
}

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-12-15 18:40:09  更:2021-12-15 18:41:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 11:54:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码