当您信任蓝牙设备时,存储信任的配置文件在哪里?

Yat*_*z1a 2 bluetooth raspberry-pi raspbian raspbian-buster

假设我运行这个命令

pi@raspberrypi:~ $ bluetoothctl
Agent registered
[bluetooth]# paired-devices
[raspberrypi]# paired-devices
Device XX:XX:XX:XX:XX:XX MyDevice
[raspberrypi]# trust XX:XX:XX:XX:XX:XX
[CHG] Device XX:XX:XX:XX:XX:XX Trusted: yes
Changing XX:XX:XX:XX:XX:XX trust succeeded
Run Code Online (Sandbox Code Playgroud)

存储可信设备列表的实际文件在哪里?

ukB*_*Baz 5

如果你这样做,$ sudo grep -Ri trust /var/lib/bluetooth你会看到一些信息。

这确实带来了一个重大警告,即这不是获取信息的预期方式。其目的是通过 BlueZ API 的记录来访问它:

https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/doc

官方示例位于:

https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/test

通常这意味着使用 D-Bus 绑定。从命令行,您可以通过以下方式获取 BlueZ 所了解的所有内容的列表:

busctl call org.bluez / org.freedesktop.DBus.ObjectManager GetManagedObjects
Run Code Online (Sandbox Code Playgroud)

在像 python 这样的语言中,它将是:

import pydbus

bus = pydbus.SystemBus()
mngr = bus.get('org.bluez', '/')

mngd_objs = mngr.GetManagedObjects()

for path in mngd_objs:
    device_info = mngd_objs[path].get('org.bluez.Device1')
    if device_info:
        print(f'Device: {device_info.get("Address")} is Trusted={device_info.get("Trusted")}')
Run Code Online (Sandbox Code Playgroud)

为了扩展此问题以回答以下有关如何删除任何受信任设备的问题......

这是由适配器接口和RemoveDevice方法控制的。我们需要知道适配器对象的 D-Bus 路径。您可以通过多种方式找到此信息,busctl tree org.bluez在命令行上使用可能是最快的。该路径通常/org/bluez/hci0会放在您的所有设备前面。有了这个假设,您可以扩展上面的示例来删除受信任的设备,如下所示:

import pydbus

bus = pydbus.SystemBus()
mngr = bus.get('org.bluez', '/')

mngd_objs = mngr.GetManagedObjects()
dongle = bus.get('org.bluez', '/org/bluez/hci0')

for path in mngd_objs:
    device_info = mngd_objs[path].get('org.bluez.Device1')
    if device_info:
        trusted = device_info.get('Trusted')
        if trusted:
            print(f'Removing Device: {device_info.get("Address")}') 
            dongle.RemoveDevice(path)
Run Code Online (Sandbox Code Playgroud)