微信小程序 蓝牙重连异常 errCode10004,errMsgnotifyBLECharacter

原文地址:

点我查看原文javascript

项目场景:

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

问题描述:

小程序低功耗蓝牙(BLE)断开(主动或自动)链接重连后没法发送内容给蓝牙设备vue

wx.writeBLECharacteristicValue({
    //经常使用参数不展现,这里只展现异常进入回调
    fail(e){
        //这里可能会输出10004 或者 10005
        console.error("error",e);
    }
})

缘由分析:

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

解决:
我的猜想微信会缓存当前设备的全部 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)
});

附送错误码查询地址:微信小程序官方文档api

相关文章
相关标签/搜索