uni-app使用websocket(封装、心跳检测)

文章介绍了一个用于创建和管理WebSocket连接的js类,包括初始化连接、心跳检测、错误处理、消息发送和重连功能。适用于uni-app框架,支持单页面和全局调用。在不同环境(测试或生产)下需注意使用ws或wss协议。
摘要由CSDN通过智能技术生成
封装websocket
  1. 创建一个websocket.js文件

class websocketUtil {
    constructor(url, time) {
        this.is_open_socket = false //避免重复连接
        this.url = url //地址
        this.data = null
        //心跳检测
        this.timeout= time //多少秒执行检测
        this.heartbeatInterval= null //检测服务器端是否还活着
        this.reconnectTimeOut= null //重连之后多久再次重连

        try {
            return this.connectSocketInit()
        } catch (e) {
            console.log('catch');
            this.is_open_socket = false
            this.reconnect();
        }
    }

    // 进入这个页面的时候创建websocket连接【整个页面随时使用】
    connectSocketInit() {
        this.socketTask = uni.connectSocket({
            url: this.url,
            success:()=>{
                console.log("正准备建立websocket中...");
                // 返回实例
                return this.socketTask
            },
        });
        this.socketTask.onOpen((res) => {
            console.log("WebSocket连接正常!");
            clearTimeout(this.reconnectTimeOut)
            clearTimeout(this.heartbeatInterval)
            this.is_open_socket = true;
            this.start();
            // 注:只有连接正常打开中 ,才能正常收到消息
            this.socketTask.onMessage((res) => {
                console.log(res.data)
            });
        })
        // 监听连接失败,这里代码我注释掉的原因是因为如果服务器关闭后,和下面的onclose方法一起发起重连操作,这样会导致重复连接
        // uni.onSocketError((res) => {
        //     console.log('WebSocket连接打开失败,请检查!');
        //     this.is_open_socket = false;
        //     this.reconnect();
        // });
        // 这里仅是事件监听【如果socket关闭了会执行】
        this.socketTask.onClose(() => {
            console.log("已经被关闭了")
            this.is_open_socket = false;
            this.reconnect();
        })
    }
    
    //发送消息
    send(value){
        // 注:只有连接正常打开中 ,才能正常成功发送消息
        this.socketTask.send({
            data: value,
            async success() {
                console.log("消息发送成功");
            },
        });
    }
    //开启心跳检测
    start(){
        this.heartbeatInterval = setTimeout(()=>{
            this.data={value:"传输内容",method:"方法名称"}
            console.log(this.data)
            this.send(JSON.stringify(this.data));
        },this.timeout)
    }
    //重新连接
    reconnect(){
        //停止发送心跳
        clearInterval(this.heartbeatInterval)
        //如果不是人为关闭的话,进行重连
        if(!this.is_open_socket){
            this.reconnectTimeOut = setTimeout(()=>{
                this.connectSocketInit();
            },3000)
        }
    }
}

module.exports = websocketUtil
  1. 调用方式

  • 单页面调用
//引入
import wsRequest from './static/js/websocket.js'
//使用
new wsRequest("ws://xxx:3100/connect/websocket",5000)
  • 全局调用

  1. 在main.js里边

//引入websocket文件
import wsRequest from './static/js/websocket.js'
//开启websocket
let websocket = new wsRequest("ws://xxx:3100/connect/websocket",5000)
//挂载到全局
Vue.prototype.$socket = websocket
  1. 页面中调用

let data={value:"传输内容",method:"方法名称"}
this.$socket.send(JSON.stringify(data));

注意,正式上线时候需要在微信公众号平台添加合法域名

//在测试环境时url可以写成  ws://xxx:3100/connect/websocket
new wsRequest("ws://xxx:3100/connect/websocket",5000)

//发布体验版或正式版,url一定要写成  wss://xxx:3100/connect/websocket
new wsRequest("wss://xxx:3100/connect/websocket",5000)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值