我正在开发一个与BLE设备接口的Android应用程序,最近偶然发现了一些奇怪的行为:当应用程序与设备断开连接时,几秒钟后其他东西似乎建立了连接.
我正在更充分地描述问题,并专注于蓝牙MAP和PBAP配置文件; 它们出现在问题点周围的日志中.但是,我不确定,如果这是根本原因,我也找不到解决方法.
该应用程序支持API 23-25.到目前为止,我只在存在SIM卡的手机中遇到过这个问题,这再次指向PBAP,因为很多手机似乎只支持这种配置文件只能使用SIM卡.我还没有能够在API 23上重现,但是现在这些测试手机没有SIM卡.
BLE设备与汽车应用程序无关,也无法处理联系人或消息传递.我没有故意在应用程序中启用任何此功能.此外,我的应用程序和设备之间没有配对/绑定,设备也不支持配对/绑定.
在大多数情况下,尝试重新连接发生一次,在设备通过应用程序断开连接几秒钟后.应用程序中的后续连接断开序列具有相同的行为.但是,我已经在至少一个实例中看到重新连接(应用程序外部)每隔几秒无限期地继续.
似乎短期内解决问题的唯一方法是在手机上循环蓝牙,或强制停止蓝牙共享过程.我不相信重新连接会自行恢复,但一旦用户连接它们再次出现 - 通过我的应用程序与设备断开连接,这种情况很常见.
我对PBAP/MAP不是很熟悉所以我不知道它们是如何启用的,或者如果可能的话,如何禁用它们.我不确定它们是否是罪魁祸首,但它们在重新连接时出现在日志中.
以下是断开连接和后续重新连接的日志声明.这里的接口名称是"Foo04",MAC = B0:B4:48:E8:FA:04.
03-31 14:27:44.305 D/RxBle#Radio(14105): STARTED RxBleRadioOperationDisconnect(186827491)
03-31 14:27:44.319 D/BluetoothManager(14105): getConnectionState()
03-31 14:27:44.320 D/BluetoothManager(14105): getConnectedDevices
03-31 14:27:44.332 D/BluetoothGatt(14105): cancelOpen() - device: B0:B4:48:E8:FA:04
03-31 14:27:44.334 D/BtGatt.GattService(13168): clientDisconnect() - address=B0:B4:48:E8:FA:04, connId=5
03-31 14:27:44.339 E/bt_btif (13168): bta_gattc_mark_bg_conn unable to find the bg connection mask for: b0:b4:48:e8:fa:04
03-31 14:27:44.340 D/BtGatt.GattService(13168): onDisconnected() - clientIf=5, connId=5, address=B0:B4:48:E8:FA:04
03-31 14:27:44.341 D/BluetoothGatt(14105): onClientConnectionState() - status=0 clientIf=5 device=B0:B4:48:E8:FA:04
03-31 14:27:44.342 D/RxBle#BluetoothGatt(14105): onConnectionStateChange newState=0 status=0
03-31 14:27:44.345 …Run Code Online (Sandbox Code Playgroud)