微信小程序 蓝牙重连异常 errCode:10004,errMsg:notifyBLECharacteristicValueChange:fail setNot

项目场景:

微信小程序,支付宝小程序,uniapp

问题描述:

小程序低功耗蓝牙(BLE)断开(主动或自动)连接重连后无法发送内容给蓝牙设备
wx.writeBLECharacteristicValue({
	//常用参数不展示,这里只展示异常进入回调
	fail(e){
		//这里可能会输出10004 或者 10005
		console.error("error",e);
	}
})

原因分析:

思考: 我们第一次连接蓝牙的时候都是正常的(已获取到deviceId,serviceId,characteristicId),并且能成功发送数据,为神马断开后就不行了呢?

解决: 个人猜测微信会缓存当前设备的所有 serviceId 和对应的 characteristicId ,当我们调用断开连接(wx.closeBLEConnection)或者异常断开后,会清空缓存列表。而发送数据(wx.writeBLECharacteristicValue)中需要指定 (deviceId,serviceId,characteristicId),则会去缓存中查询,故此查询不到。因此只需要在发送之前,再次调用查询接口即可解决。

解决方案:

重新扫描一次当前设备的 serviceId 和 characteristicId 即可

let deviceId = this.deviceId;
let serviceId = this.serviceId;
let characteristicId = this.characteristicId;

//vue用户,请自行吧fns的方法放入methods
let fns = {
    reconnection(succ,fail){
        wx.openBluetoothAdapter({
          success :(res) => {
            wx.createBLEConnection({
                deviceId : deviceId ,
                success : (res) => {
                    fns.searchServices(() => {
                        fns.serachCharacteristics(succ,fail)
                    },fail)
                },
                fail : fail
            })
          },
          fail : fail
        })
        
    }, 
    searchServices(succ,fail){
        wx.getBLEDeviceServices({
            deviceId : deviceId,
            success : succ,
            fail : fail
        })
    },
    serachCharacteristics(succ,fail){
         wx.getBLEDeviceCharacteristics({
            deviceId : deviceId,
            serviceId : serviceId,
            success : succ,
            fail : fail
        })
    },
    
}
//重连
fns.reconnection((succ) => {
    console.log("重连成功,可以调用 wx.writeBLECharacteristicValue")
},(err) => {
    console.log("err:",err)
});

微信小程序官方文档

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

java小庆

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值