小程序模板網(wǎng)

微信小程序:藍牙BLE連接10003問題分析及解決

發(fā)布時間:2018-04-19 09:47 所屬欄目:小程序開發(fā)教程

10003是微信藍牙連接經(jīng)常碰到的問題,微信官方給出的文檔中就簡單的描述為“connection fail”,備注為“連接失敗”。然而,實際上出現(xiàn)10003的狀況有很多,比如根據(jù)deviceId連接藍牙時,藍牙設備未開啟或異常導致無法連接;藍牙設備被占用或者上次藍牙連接未斷開導致無法連接;出現(xiàn)該錯誤后,去微信官方社區(qū)尋求幫助,在社區(qū)發(fā)現(xiàn)了整整4頁(獎金40條)都是反饋該問題,然而都沒有得到官方答復,有極個別解決了的也不適用于我的情況;于是,只有自己分析。

問題描述:

1.啟動app,搜索并連接藍牙成功后,第一次采集數(shù)據(jù)正常;
2.下次采集如果手機藍牙是打開的,也能正常采集;
3.但如果手機藍牙關閉,點擊采集數(shù)據(jù)試圖連接,提示用戶打開手機藍牙;當打開手機藍牙后再去連接藍牙,此時會連接不上,報錯10003;
4.后續(xù)會一致連不上藍牙,不管是重啟小程序還是重新關閉打開藍牙,都不能正常連接藍牙設備。

問題定位

1.復現(xiàn)問題,根據(jù)測試提供的方法,先測試iphone正常,三星S7edge,結果是能正常連接藍牙,后來又測試vivo x7plus和小米MI5,終于成功復現(xiàn)該問題;
2.針對10003錯誤在微信開發(fā)社區(qū)找解決方案,可是面對著幾十條相似問題,幾乎都沒有得到解決,有幾條說在連接前先調(diào)用wx.closeBLEConnection斷開上次連接,嘗試后,不能解決我的問題;
3.既然沒有找到現(xiàn)成的解決方案,就只有跟蹤代碼了,在關鍵方法中加日志;發(fā)現(xiàn),在頂部欄關閉手機藍牙時,小程序中無法斷開藍牙連接,報錯(10001(not available)當前藍牙適配器不可用);
4.后來又在偶然情況下,清除了藍牙設備的綁定關系,重新進入藍牙搜索頁面,發(fā)現(xiàn)這樣操作后竟然能成功連接上藍牙。

問題修復

上述問題定位中,(3)可以發(fā)現(xiàn)應該是沒有斷開上次藍牙連接導致的,(4)又發(fā)現(xiàn),重新搜索藍牙以后再連接可以解決該問題;
于是按照這兩個方向去找解決方案:
1.既然是因為沒有斷開藍牙連接導致的,那就在關閉手機藍牙時去斷開藍牙;然而,在藍牙狀態(tài)監(jiān)聽中調(diào)用斷開連接函數(shù),返回錯誤(10001(not available)當前藍牙適配器不可用);
2.于是只能考慮重新搜索藍牙后再連接的方法,在出現(xiàn)10003錯誤后,重新搜索藍牙,并且在找到對應的設備后進行藍牙連接;修改代碼反復測試,根據(jù)日志顯示,確實是出現(xiàn)了10003,然后進入搜索模塊,搜到指定設備后進行藍牙連接,之后連接成功,這個方案解決了該問題。

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)中將手機藍牙關閉導致連接狀態(tài)不能改為斷開,導致下次無法連接同一個設備)
    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) { // 搜索到該設備 
          console.log("searchDeviceAndReConnect:find device and re connect");
          clearTimeout(timeId);
          stopSearchBluetooth() // 停止搜索
          callback(true, "find device");// 找到設備,在回調(diào)函數(shù)中連接藍牙
          break;
        }
      }
    }, function (res) {
      clearTimeout(timeId);
      stopSearchBluetooth() // 停止搜索
      callback(false, "searchBluetooth fail")
    });
  }

上述代碼提供了一個簡單的流程,當連接出現(xiàn)10003錯誤時,搜索藍牙設備,找到后,重新連接藍牙。
考慮到只有部分手機出現(xiàn)10003錯誤,所以會先連接一次藍牙,報錯10003才進行,以免其他手機會因為搜索藍牙導致連接藍牙采集數(shù)據(jù)的速度減慢;
當然10003,不只是該問題才報的錯,所有,在設備沒有打開藍牙時也報10003,而因為加了搜索邏輯,在設備沒有打開藍牙時的提醒就會慢一點(設備藍牙沒打開需要提醒用戶打開設備藍牙),不過好在這一點影響不大,目前沒有好的思路去解決,后續(xù)再慢慢研究。

該方法僅解決了我這種情況,10003出現(xiàn)的情況很多,不過基本上可以從上一次藍牙連接是否結束來定位,重新搜索藍牙后進行連接也是基于上次藍牙連接未斷開這一情況

相關問題

1.微信小程序藍牙連接僅支持4.0,而BLE低功耗藍牙設備是帶有定位功能的,所以,需要有定位權限,部分手機(如vivo x7plus)需要打開手機定位功能才能搜索到藍牙設備,詳細可百度 “Android6.0藍牙BLE連接,定位動態(tài)權限相關”
2.根據(jù)services調(diào)用wx.startBluetoothDevicesDiscovery搜索藍牙時,如果搜索不到,可以去掉services試試,我的一臺測試機(印象中是華為P6)就出現(xiàn)帶services搜索不到設備,最后只能去掉services, 然后在搜索到的結果中進行過濾
3.wx.startBluetoothDevicesDiscovery搜索藍牙時,一般人都知道使用wx.onBluetoothDeviceFound,然后部分手機在短時間內(nèi)進行第二次搜索onBluetoothDeviceFound回調(diào)中不能得到所有的設備,此時可以試試wx.getBluetoothDevices,這個方法可以獲取到緩存的藍牙設備,這一部分緩存的藍牙設備在部分手機中不會再出現(xiàn)在wx.onBluetoothDeviceFound中
4.連接藍牙后,在進行寫操作時,如果寫失敗,請檢查是否設置了characteristicId,這個特征值每次做寫操作時都要帶上


Android機型多,BLE低功耗藍牙也不是很穩(wěn)定,這就導致了在Android上開發(fā)藍牙會有很多奇怪的問題,而微信小程序基于Android和IOS,相應的也會出現(xiàn)一些問題,IOS還好,系統(tǒng)軟硬件都單一,但Android的問題就多了,之前開發(fā)還遇到一些需要注意的,暫時想不起來,后續(xù)再補充



易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://22321a.com/wxmini/doc/course/23716.html 復制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點擊咨詢
QQ在線咨詢