我的设置如下:
- 树莓派 3 中的 BLE 外设
- Android 手机中的 nRF 工具
- 我的应用在同一部 Android 手机中(使用 react-native-ble-manager)
当我使用 nRF 工具连接到 Raspberry Pi 时,它连接成功。但是,当我使用自己的 Android 应用程序连接时,它会失败。
在 Raspberry Pi 中,我运行 sudo btmon 命令来检查失败日志,如下所示:
> HCI Event: Connect Request (0x04) plen 10 [hci0] 143.774717
Address: 88:A3:03:E7:18:EA (OUI 88-A3-03)
Class: 0x5a020c
Major class: Phone (cellular, cordless, payphone, modem)
Minor class: Smart phone
Networking (LAN, Ad hoc)
Capturing (Scanner, Microphone)
Object Transfer (v-Inbox, v-Folder)
Telephony (Cordless telephony, Modem, Headset)
Link type: ACL (0x01)
< HCI Command: Reject Connection Request (0x01|0x000a) plen 7 [hci0] 143.774802
Address: 88:A3:03:E7:18:EA (OUI 88-A3-03)
Reason: Connection Rejected due to Unacceptable BD_ADDR (0x0f)
> HCI Event: Command Status (0x0f) plen 4 [hci0] 143.775814
Reject Connection Request (0x01|0x000a) ncmd 1
Status: Success (0x00)
> HCI Event: Connect Complete (0x03) plen 11 [hci0] 143.897643
Status: Connection Rejected due to Unacceptable BD_ADDR (0x0f)
Handle: 0
Address: 88:A3:03:E7:18:EA (OUI 88-A3-03)
Link type: ACL (0x01)
Encryption: Disabled (0x00)
日志中显示的错误是由于 BD_ADDR。使用 nRF 工具时,bd_addr 为
Peer address type: Random (0x01)
Peer address: 58:B2:55:17:1A:92 (Resolvable)
我无法理解的奇怪事情:一旦我使用 nRF 工具绑定到 Raspberry Pi,然后尝试从我的应用程序连接到 Raspberry Pi,它就会连接。
我该如何解决这个问题?