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