小程序藍(lán)牙連接10003問(wèn)題及解決辦法
10003是微信藍(lán)牙連接經(jīng)常碰到的問(wèn)題,微信官方給出的文檔中就簡(jiǎn)單的描述為connection fail,備注為連接失敗。那么具體到底是什么原因。
10003是微信藍(lán)牙連接經(jīng)常碰到的問(wèn)題,微信官方給出的文檔中就簡(jiǎn)單的描述為“connection fail”,備注為“連接失敗”。然而,實(shí)際上出現(xiàn)10003的狀況有很多,比如根據(jù)deviceId連接藍(lán)牙時(shí),藍(lán)牙設(shè)備未開啟或異常導(dǎo)致無(wú)法連接;藍(lán)牙設(shè)備被占用或者上次藍(lán)牙連接未斷開導(dǎo)致無(wú)法連接;出現(xiàn)該錯(cuò)誤后,去微信官方社區(qū)尋求幫助,在社區(qū)發(fā)現(xiàn)了整整4頁(yè)(獎(jiǎng)金40條)都是反饋該問(wèn)題,然而都沒(méi)有得到官方答復(fù),有極個(gè)別解決了的也不適用于我的情況;于是,只有自己分析。
問(wèn)題描述:
1.啟動(dòng)app,搜索并連接藍(lán)牙成功后,第一次采集數(shù)據(jù)正常;
2.下次采集如果手機(jī)藍(lán)牙是打開的,也能正常采集;
3.但如果手機(jī)藍(lán)牙關(guān)閉,點(diǎn)擊采集數(shù)據(jù)試圖連接,提示用戶打開手機(jī)藍(lán)牙;當(dāng)打開手機(jī)藍(lán)牙后再去連接藍(lán)牙,此時(shí)會(huì)連接不上,報(bào)錯(cuò)10003;
4.后續(xù)會(huì)一致連不上藍(lán)牙,不管是重啟小程序還是重新關(guān)閉打開藍(lán)牙,都不能正常連接藍(lán)牙設(shè)備。
問(wèn)題定位
1.復(fù)現(xiàn)問(wèn)題,根據(jù)測(cè)試提供的方法,先測(cè)試iphone正常,三星S7edge,結(jié)果是能正常連接藍(lán)牙,后來(lái)又測(cè)試vivo x7plus和小米MI5,終于成功復(fù)現(xiàn)該問(wèn)題;
2.針對(duì)10003錯(cuò)誤在微信開發(fā)社區(qū)找解決方案,可是面對(duì)著幾十條相似問(wèn)題,幾乎都沒(méi)有得到解決,有幾條說(shuō)在連接前先調(diào)用wx.closeBLEConnection斷開上次連接,嘗試后,不能解決我的問(wèn)題;
3.既然沒(méi)有找到現(xiàn)成的解決方案,就只有跟蹤代碼了,在關(guān)鍵方法中加日志;發(fā)現(xiàn),在頂部欄關(guān)閉手機(jī)藍(lán)牙時(shí),小程序中無(wú)法斷開藍(lán)牙連接,報(bào)錯(cuò)(10001(not available)當(dāng)前藍(lán)牙適配器不可用);
4.后來(lái)又在偶然情況下,清除了藍(lán)牙設(shè)備的綁定關(guān)系,重新進(jìn)入藍(lán)牙搜索頁(yè)面,發(fā)現(xiàn)這樣操作后竟然能成功連接上藍(lán)牙。
問(wèn)題修復(fù)
上述問(wèn)題定位中,(3)可以發(fā)現(xiàn)應(yīng)該是沒(méi)有斷開上次藍(lán)牙連接導(dǎo)致的,(4)又發(fā)現(xiàn),重新搜索藍(lán)牙以后再連接可以解決該問(wèn)題;
于是按照這兩個(gè)方向去找解決方案:
1.既然是因?yàn)闆](méi)有斷開藍(lán)牙連接導(dǎo)致的,那就在關(guān)閉手機(jī)藍(lán)牙時(shí)去斷開藍(lán)牙;然而,在藍(lán)牙狀態(tài)監(jiān)聽(tīng)中調(diào)用斷開連接函數(shù),返回錯(cuò)誤(10001(not available)當(dāng)前藍(lán)牙適配器不可用);
2.于是只能考慮重新搜索藍(lán)牙后再連接的方法,在出現(xiàn)10003錯(cuò)誤后,重新搜索藍(lán)牙,并且在找到對(duì)應(yīng)的設(shè)備后進(jìn)行藍(lán)牙連接;修改代碼反復(fù)測(cè)試,根據(jù)日志顯示,確實(shí)是出現(xiàn)了10003,然后進(jìn)入搜索模塊,搜到指定設(shè)備后進(jìn)行藍(lán)牙連接,之后連接成功,這個(gè)方案解決了該問(wèn)題。
wx.createBLEConnection({
deviceId: deviceId,
success: function (res) { //連接成功
initnotifyCharacteristic(notifyCharacteristic);// 指定特征值,并進(jìn)行數(shù)據(jù)交互
// 已連接
_bthConnectStaus = BTH_STATUS_CONNECTED;
},
fail: function (res) {// 連接藍(lán)牙失敗
_bthConnectStaus = BTH_STATUS_DISCONNECT;
// 回調(diào)上層藍(lán)牙連接失敗
callback(res.errCode, "connect failed")
}
然后根據(jù)fail中的res.errCode判斷是否10003。
if(code == 10003) { // 部分android手機(jī)特殊情況下需要重新搜索才能連接藍(lán)牙,此時(shí)報(bào)錯(cuò)10003,進(jìn)行藍(lán)牙搜索(ps:原因可能是系統(tǒng)中將手機(jī)藍(lán)牙關(guān)閉導(dǎo)致連接狀態(tài)不能改為斷開,導(dǎo)致下次無(wú)法連接同一個(gè)設(shè)備)
var timeId = setTimeout(function () {
stopSearchBluetooth();
callback(false, "timout")
}, 5000); // 最多搜索5s
searchBluetooth(function (res) {
if (res.devices === undefined || res.devices === null) {
return;
}
for (var i = 0; i < res.devices.length; i++) {
if (res.devices[i] && res.devices[i].deviceId == deviceId) { // 搜索到該設(shè)備
console.log("searchDeviceAndReConnect:find device and re connect");
clearTimeout(timeId);
stopSearchBluetooth() // 停止搜索
callback(true, "find device");// 找到設(shè)備,在回調(diào)函數(shù)中連接藍(lán)牙
break;
}
}
}, function (res) {
clearTimeout(timeId);
stopSearchBluetooth() // 停止搜索
callback(false, "searchBluetooth fail")
});
}
上述代碼提供了一個(gè)簡(jiǎn)單的流程,當(dāng)連接出現(xiàn)10003錯(cuò)誤時(shí),搜索藍(lán)牙設(shè)備,找到后,重新連接藍(lán)牙。
考慮到只有部分手機(jī)出現(xiàn)10003錯(cuò)誤,所以會(huì)先連接一次藍(lán)牙,報(bào)錯(cuò)10003才進(jìn)行,以免其他手機(jī)會(huì)因?yàn)樗阉魉{(lán)牙導(dǎo)致連接藍(lán)牙采集數(shù)據(jù)的速度減慢;
當(dāng)然10003,不只是該問(wèn)題才報(bào)的錯(cuò),所有,在設(shè)備沒(méi)有打開藍(lán)牙時(shí)也報(bào)10003,而因?yàn)榧恿怂阉鬟壿?,在設(shè)備沒(méi)有打開藍(lán)牙時(shí)的提醒就會(huì)慢一點(diǎn)(設(shè)備藍(lán)牙沒(méi)打開需要提醒用戶打開設(shè)備藍(lán)牙),不過(guò)好在這一點(diǎn)影響不大,目前沒(méi)有好的思路去解決,后續(xù)再慢慢研究。
該方法僅解決了我這種情況,10003出現(xiàn)的情況很多,不過(guò)基本上可以從上一次藍(lán)牙連接是否結(jié)束來(lái)定位,重新搜索藍(lán)牙后進(jìn)行連接也是基于上次藍(lán)牙連接未斷開這一情況
相關(guān)問(wèn)題
1.微信小程序藍(lán)牙連接僅支持4.0,而BLE低功耗藍(lán)牙設(shè)備是帶有定位功能的,所以,需要有定位權(quán)限,部分手機(jī)(如vivo x7plus)需要打開手機(jī)定位功能才能搜索到藍(lán)牙設(shè)備,詳細(xì)可百度 “Android6.0藍(lán)牙BLE連接,定位動(dòng)態(tài)權(quán)限相關(guān)”
2.根據(jù)services調(diào)用wx.startBluetoothDevicesDiscovery搜索藍(lán)牙時(shí),如果搜索不到,可以去掉services試試,我的一臺(tái)測(cè)試機(jī)(印象中是華為P6)就出現(xiàn)帶services搜索不到設(shè)備,最后只能去掉services, 然后在搜索到的結(jié)果中進(jìn)行過(guò)濾
3.wx.startBluetoothDevicesDiscovery搜索藍(lán)牙時(shí),一般人都知道使用wx.onBluetoothDeviceFound,然后部分手機(jī)在短時(shí)間內(nèi)進(jìn)行第二次搜索onBluetoothDeviceFound回調(diào)中不能得到所有的設(shè)備,此時(shí)可以試試wx.getBluetoothDevices,這個(gè)方法可以獲取到緩存的藍(lán)牙設(shè)備,這一部分緩存的藍(lán)牙設(shè)備在部分手機(jī)中不會(huì)再出現(xiàn)在wx.onBluetoothDeviceFound中
4.連接藍(lán)牙后,在進(jìn)行寫操作時(shí),如果寫失敗,請(qǐng)檢查是否設(shè)置了characteristicId,這個(gè)特征值每次做寫操作時(shí)都要帶上
Android機(jī)型多,BLE低功耗藍(lán)牙也不是很穩(wěn)定,這就導(dǎo)致了在Android上開發(fā)藍(lán)牙會(huì)有很多奇怪的問(wèn)題,而微信小程序基于Android和IOS,相應(yīng)的也會(huì)出現(xiàn)一些問(wèn)題,IOS還好,系統(tǒng)軟硬件都單一,但Android的問(wèn)題就多了,之前開發(fā)還遇到一些需要注意的,暫時(shí)想不起來(lái),后續(xù)再補(bǔ)充
HiShop小程序工具提供多類型商城/門店小程序制作,可視化編輯 1秒生成5步上線。通過(guò)拖拽、拼接模塊布局小程序商城頁(yè)面,所看即所得,只需要美工就能做出精美商城。