MAUI实现BLE功能需四步到位:权限配置(Android 12+需BLUETOOTH_SCAN/CONNECT,iOS需NSBluetoothAlwaysUsageDescription等)、设备扫描、连接管理、服务读写;推荐使用Plugin.BLE插件,连接后须重新获取服务与特征,调试建议用nRF Connect验证。

MAUI 使用蓝牙 BLE 功能不难,关键是权限配置、设备扫描、连接管理、服务读写四步到位。跨平台统一 API 是优势,但各系统细节差异必须处理好,否则连不上、扫不到、读不出。
权限配置是第一步,不能跳过
Android 和 iOS 的权限要求不同,缺一不可:
-
Android(12+):在
AndroidManifest.xml中添加
如果还要后台扫描,补上BLUETOOTH_ADVERTISE;SupportedOSPlatformVersion建议设为 31.0 或更高 -
iOS:在
Info.plist中加入NSBluetoothAlwaysUsageDescription 需要蓝牙连接外部设备 UIBackgroundModes bluetooth-central
不加这两项,iOS 会直接拒绝扫描或后台断连
用 Plugin.BLE 插件最省事
官方 MAUI 蓝牙 API(如 BluetoothLEDevice)只支持 Windows,跨平台推荐用成熟插件 Plugin.BLE:
- NuGet 安装:
Install-Package Plugin.BLE - 初始化扫描:
var adapter = CrossBluetoothLE.Current.Adapter;adapter.DeviceDiscovered += (s, a) => { /* 处理新设备 */ };await adapter.StartScanningForDevicesAsync(); - 扫描可加过滤,比如按服务 UUID 或设备名,减少干扰
连接后读写服务和特征要重获取
每次连接成功后,不要缓存服务或特征对象,必须重新枚举:
- 连接后调用
device.GetGattServicesAsync() - 再用
service.GetCharacteristicsAsync()获取目标特征 - 读值用
characteristic.ReadValueAsync(),写值用characteristic.WriteValueAsync(data) - 注意某些特征需启用通知(
characteristic.StartNotifications())才能持续收数据,比如心率、传感器流
调试别靠猜,用 nRF Connect 验证设备行为
nRF Connect 是 BLE 开发标配工具,能帮你确认三件事:
- 设备是否真在广播、名字/UUID 是否匹配
- 服务结构是否正确(比如有没有 Heart Rate Service)
- 特征的属性是否支持读/写/通知,MTU 是否合理
- 如果 nRF Connect 能连能读,但你的 MAUI App 连不上,问题一定出在权限、扫描逻辑或连接后服务获取流程上
基本上就这些。权限对了、插件装了、扫描启了、连接后重取服务、调试工具用了——BLE 通信就能跑通。不复杂但容易忽略细节。










