<p>如果您使用bluezdbusapi来获取信息,那么就不需要使用sudo。它还避免了您必须使用btmgmt,因为我不确定它是否打算以这种方式编写脚本</p>
<p>DBus API的文档可从以下网址获得:</p>
<p><a href="https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/doc/adapter-api.txt" rel="nofollow noreferrer">https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/doc/adapter-api.txt</a></p>
<p><a href="https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/doc/device-api.txt" rel="nofollow noreferrer">https://git.kernel.org/pub/scm/bluetooth/bluez.git/tree/doc/device-api.txt</a></p>
<p>pydbus库对于访问bluezdbusapi非常有用:<a href="https://pypi.org/project/pydbus/" rel="nofollow noreferrer">https://pypi.org/project/pydbus/</a></p>
<p>要开始学习,需要了解一些有用的事情:</p>
<ol>
<li>bluez的Dbus服务称为“org.bluez”</li>
<li>默认蓝牙适配器通常将“/org/bluez/hci0”作为其DBus对象路径</李>
<li>BlueZ/DBus有一个存储设备信息的对象管理器</li>
</ol>
<p>我编写了以下脚本来测试这个想法:</p>
<pre class="lang-py prettyprint-override"><code>from datetime import datetime
import os
import pydbus
from gi.repository import GLib
discovery_time = 60
log_file = '/home/pi/device.log'
# Create an empty log file
def write_to_log(address, rssi):
if os.path.exists(log_file):
open_mode = 'a'
else:
open_mode = 'w'
with open(log_file, open_mode) as dev_log:
now = datetime.now()
current_time = now.strftime('%H:%M:%S')
dev_log.write(f'Device seen[{current_time}]: {address} @ {rssi} dBm\n')
bus = pydbus.SystemBus()
mainloop = GLib.MainLoop()
class DeviceMonitor:
def __init__(self, path_obj):
self.device = bus.get('org.bluez', path_obj)
self.device.onPropertiesChanged = self.prop_changed
print(f'Device added to monitor {self.device.Address}')
def prop_changed(self, iface, props_changed, props_removed):
rssi = props_changed.get('RSSI', None)
if rssi is not None:
print(f'\tDevice Seen: {self.device.Address} @ {rssi} dBm')
write_to_log(self.device.Address, rssi)
def end_discovery():
"""Handler for end of discovery"""
mainloop.quit()
adapter.StopDiscovery()
def new_iface(path, iface_props):
"""If a new dbus interfaces is a device, add it to be monitored"""
device_addr = iface_props.get('org.bluez.Device1', {}).get('Address')
if device_addr:
DeviceMonitor(path)
# BlueZ object manager
mngr = bus.get('org.bluez', '/')
mngr.onInterfacesAdded = new_iface
# Connect to the DBus api for the Bluetooth adapter
adapter = bus.get('org.bluez', '/org/bluez/hci0')
adapter.DuplicateData = False
# Iterate around already known devices and add to monitor
mng_objs = mngr.GetManagedObjects()
for path in mng_objs:
device = mng_objs[path].get('org.bluez.Device1', {}).get('Address', [])
if device:
DeviceMonitor(path)
# Run discovery for discovery_time
adapter.StartDiscovery()
GLib.timeout_add_seconds(discovery_time, end_discovery)
print('Finding nearby devices...')
try:
mainloop.run()
except KeyboardInterrupt:
end_discovery()
</code></pre>