uni-app WebSocket持久链接状态监听

// 放入methods里面在 onLoad() 调用即可

connectSocketInit(){
    // 创建一个this.socketTask对象(发送、接收、关闭socket都由这个对象操作)
    let ip = uni.getStorageSync('ip'); //读取缓存里面的IP
	let port = uni.getStorageSync('port');//读取缓存里面的端口号
    uni.connectSocket({
        url: 'ws://'+ip+':'+port,,
        success(data){
            console.log("websocket连接成功",data)
        }
    })
    //监听socket打开
    uni.onSocketOpen(()=>{
        this.is_opensocket=true
        console.log('WebSocket连接已打开!')
        this.connectSocketInit()
    })
    //监听socket关闭
    uni.onSocketClose(()=>{
        this.is_opensocket=false;
        this.connectSocketInit()
        console.log('WebSocket连接已关闭!')
    })
    //监听socket错误
    uni.onSocketError(()=>{
        this.is_opensocket=false
        this.connectSocketInit()
        console.log('WebSocket连接打开失败');
    })
    uni.onSocketMessage((res)=>{
        console.log(res)
    })
    //先确保清除了之前的心跳定时器
    clearInterval(this.pingpangTimes)
        // 每过一段时间发送一次心跳,发送Ping,服务器会反馈pong,这样操作以保持socket一直是连接状态,防止断开连接,心跳停止
        this.pingpangTimes=setInterval(()=>{
            // 心跳传参
            let heartData = {
                type:'is ok',
            }
        uni.sendSocketMessage({
            data: JSON.stringify(heartData),
            success:(res)=>{
               console.log('心跳的返回:',res) 其实监听里面有,或者不返回跟后端,用处不大,可以删除
            },
            fail:(res)=>{
                // console.log(res)
                this.is_opensocket=false
            }
        });
    },50000);
}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值