蓝牙GAP通用访问协议详解:从原理到多平台实战代码

news2026/4/29 18:35:13
在蓝牙开发中很多开发者会困惑“为什么设备能被搜索到”“配对和连接的底层逻辑是什么”“不同设备之间如何实现身份识别”——这些问题的答案都藏在GAPGeneric Access Profile通用访问协议中。GAP是蓝牙协议栈的基础协议之一也是所有蓝牙设备经典蓝牙、低功耗蓝牙BLE必须遵循的“通用规则”。它不负责数据传输本身却掌管着蓝牙设备的“对外交互”从设备广播、被搜索到配对认证、连接管理每一步都离不开GAP的规范。可以说GAP是蓝牙设备的“社交礼仪”没有它不同厂商的蓝牙设备就无法互联互通。本文将从GAP的核心定义、核心功能入手用通俗的语言拆解其工作原理再结合iOSOC、Flutter、AndroidJava三种主流开发语言的实战代码帮你快速掌握GAP协议的开发应用解决蓝牙开发中“设备交互”的核心痛点。注意本文聚焦GAP协议的核心实战场景代码示例均为基础可复用版本适配经典蓝牙和BLE通用场景可直接复制到项目中扩展使用。一、先搞懂GAP协议到底是什么1. 核心定义GAP通用访问协议本质是蓝牙设备之间“建立交互”的通用规范它定义了蓝牙设备的角色、状态、交互流程以及设备如何对外展示自己、与其他设备建立关联。简单来说GAP的作用就是“让两个蓝牙设备认识彼此、建立信任、搭建沟通的基础”。它位于蓝牙协议栈的最上层直接面向应用层所有蓝牙设备的“对外操作”广播、扫描、配对、连接都需要通过GAP协议来实现。2. GAP的核心角色必懂GAP定义了两种核心角色所有蓝牙设备在交互时必然处于其中一种可动态切换这是理解GAP的关键广播者Advertiser主动发送广播包对外“自我介绍”的设备如耳机、智能手表、BLE传感器核心作用是让其他设备发现自己。对应之前提到的“从设备Slave”。扫描者Scanner主动扫描周围的广播包寻找其他设备的设备如手机、平板核心作用是发现广播者进而发起连接。对应之前提到的“主设备Master”。补充同一台设备可以同时扮演两种角色如手机既能扫描耳机也能开启广播让其他设备发现角色切换由应用层根据需求控制。3. GAP的核心功能开发重点GAP的所有功能都围绕“设备交互”展开核心可分为4类也是开发中最常用的场景广播管理广播者发送广播包包含设备名称、MAC地址、服务UUID等信息控制广播间隔、广播功率扫描管理扫描者扫描周围的广播包过滤目标设备获取广播者的基础信息配对管理实现设备间的身份认证协商加密密钥保存配对信息避免重复配对连接管理建立、维持、断开设备间的连接管理连接状态如连接成功、连接失败、断开重连。这里需要注意GAP只负责“建立连接”不负责“数据传输”数据传输由后续的GATT协议负责但GAP是GATT协议的前置基础——没有GAP建立的连接GATT就无法传输数据。二、GAP核心功能实战多平台代码示例下面针对GAP的4个核心功能分别提供iOSOC、Flutter、AndroidJava的实战代码覆盖“广播、扫描、配对、连接”全场景代码可直接复用重点标注GAP相关的核心API。1. 功能1广播管理GAP广播者角色场景让设备开启广播对外发送“自我介绍”供其他设备扫描发现如BLE传感器主动广播自己的存在。1iOSOC—— BLE广播开启GAP广播者// 导入GAP相关头文件CoreBluetooth已封装GAP协议 #import CoreBluetooth/CoreBluetooth.h interface GAPAdvertiserManager () CBPeripheralManagerDelegate property (nonatomic, strong) CBPeripheralManager *peripheralManager; // GAP广播核心管理器 end implementation GAPAdvertiserManager - (instancetype)init { self [super init]; if (self) { // 初始化GAP广播管理器底层已实现GAP协议 self.peripheralManager [[CBPeripheralManager alloc] initWithDelegate:self queue:nil options:nil]; } return self; } // 监听广播管理器状态状态就绪后开启广播GAP核心操作 - (void)peripheralManagerDidUpdateState:(CBPeripheralManager *)peripheral { if (peripheral.state CBManagerStatePoweredOn) { NSLog(GAP广播者就绪开始发送广播GAP协议); // 配置GAP广播包信息符合GAP规范包含设备名称、服务UUID NSDictionary *advertisementData { // 设备名称GAP广播包必填字段供扫描者识别 CBAdvertisementDataLocalNameKey: GAP-Device, // 服务UUIDGAP广播包可选用于过滤目标设备 CBAdvertisementDataServiceUUIDsKey: [[CBUUID UUIDWithString:0000FFE0-0000-1000-8000-00805F9B34FB]] }; // 开启GAP广播底层GAP协议自动处理广播信道、广播间隔 // 广播间隔默认由系统控制可通过options参数自定义如缩短间隔提升被发现速度 [self.peripheralManager startAdvertising:advertisementData]; } } // 监听GAP广播开启结果 - (void)peripheralManagerDidStartAdvertising:(CBPeripheralManager *)peripheral error:(NSError *)error { if (error) { NSLog(GAP广播开启失败%, error.localizedDescription); } else { NSLog(GAP广播开启成功在3个广播信道37、38、39发送广播GAP规范); } } // 停止GAP广播GAP协议操作 - (void)stopGAPAdvertising { if (self.peripheralManager.isAdvertising) { [self.peripheralManager stopAdvertising]; NSLog(GAP广播已停止); } } end2Flutter—— BLE广播开启GAP广播者依赖flutter_blue_plus// 导入依赖pubspec.yaml中添加flutter_blue_plus: ^1.13.3 import package:flutter_blue_plus/flutter_blue_plus.dart; // 开启GAP广播GAP广播者角色 Futurevoid startGAPAdvertising() async { // 检查蓝牙状态开启蓝牙GAP广播前提 if (await FlutterBluePlus.isOn false) { await FlutterBluePlus.turnOn(); } // 配置GAP广播包信息符合GAP协议规范 MapString, dynamic gapAdvertisementData { localName: GAP-Device, // 设备名称GAP必填 serviceUuids: [0000FFE0-0000-1000-8000-00805F9B34FB], // 服务UUIDGAP可选 manufacturerData: [0x00, 0x01] // 厂商数据GAP扩展字段 }; try { // 开启GAP广播插件底层已封装GAP协议自动处理广播逻辑 await FlutterBluePlus.startAdvertising(gapAdvertisementData); print(GAP广播开启成功遵循GAP协议发送广播); } catch (e) { print(GAP广播开启失败$e); } } // 停止GAP广播 Futurevoid stopGAPAdvertising() async { if (await FlutterBluePlus.isAdvertising) { await FlutterBluePlus.stopAdvertising(); print(GAP广播已停止); } }3AndroidJava—— BLE广播开启GAP广播者// 导入GAP相关包Android蓝牙API已封装GAP协议 import android.bluetooth.BluetoothAdapter; import android.bluetooth.le.AdvertiseCallback; import android.bluetooth.le.AdvertiseData; import android.bluetooth.le.AdvertiseSettings; import android.bluetooth.le.BluetoothLeAdvertiser; import android.os.ParcelUuid; import java.util.UUID; // GAP广播者实现类 public class GAPAdvertiser { private BluetoothLeAdvertiser advertiser; // GAP广播核心对象 // 开启GAP广播 public void startGAPAdvertising() { BluetoothAdapter bluetoothAdapter BluetoothAdapter.getDefaultAdapter(); if (bluetoothAdapter null || !bluetoothAdapter.isEnabled()) { System.out.println(蓝牙未开启无法启动GAP广播); return; } // 获取GAP广播对象仅BLE设备支持经典蓝牙广播逻辑略有不同 advertiser bluetoothAdapter.getBluetoothLeAdvertiser(); if (advertiser null) { System.out.println(设备不支持GAP广播); return; } // 配置GAP广播设置符合GAP协议控制广播功率、间隔 AdvertiseSettings gapAdvertiseSettings new AdvertiseSettings.Builder() .setAdvertiseMode(AdvertiseSettings.ADVERTISE_MODE_LOW_LATENCY) // 低延迟优先被发现 .setTxPowerLevel(AdvertiseSettings.ADVERTISE_TX_POWER_HIGH) // 高功率广播 .setConnectable(true) // 可连接GAP广播核心标识说明设备可被连接 .build(); // 配置GAP广播包数据符合GAP规范 AdvertiseData gapAdvertiseData new AdvertiseData.Builder() .setIncludeDeviceName(true) // 包含设备名称GAP必填 .addServiceUuid(new ParcelUuid(UUID.fromString(0000FFE0-0000-1000-8000-00805F9B34FB))) // 服务UUID .build(); // 开启GAP广播底层GAP协议自动处理广播信道、广播逻辑 advertiser.startAdvertising(gapAdvertiseSettings, gapAdvertiseData, new AdvertiseCallback() { Override public void onStartSuccess(AdvertiseSettings settingsInEffect) { super.onStartSuccess(settingsInEffect); System.out.println(GAP广播开启成功遵循GAP协议发送广播); } Override public void onStartFailure(int errorCode) { super.onStartFailure(errorCode); System.out.println(GAP广播开启失败错误码 errorCode); } }); } // 停止GAP广播 public void stopGAPAdvertising() { if (advertiser ! null) { advertiser.stopAdvertising(new AdvertiseCallback() {}); System.out.println(GAP广播已停止); } } }2. 功能2扫描管理GAP扫描者角色场景设备主动扫描周围的GAP广播发现目标设备获取广播包中的设备信息如设备名称、MAC地址为后续配对、连接做准备如手机扫描耳机。1iOSOC—— BLE扫描GAP扫描者// 导入GAP相关头文件 #import CoreBluetooth/CoreBluetooth.h interface GAPScannerManager () CBCentralManagerDelegate property (nonatomic, strong) CBCentralManager *centralManager; // GAP扫描核心管理器 end implementation GAPScannerManager - (instancetype)init { self [super init]; if (self) { // 初始化GAP扫描管理器底层已实现GAP扫描协议 self.centralManager [[CBCentralManager alloc] initWithDelegate:self queue:nil options:{CBCentralManagerOptionShowPowerAlertKey: YES}]; } return self; } // 监听扫描管理器状态就绪后开始扫描GAP核心操作 - (void)centralManagerDidUpdateState:(CBCentralManager *)central { if (central.state CBManagerStatePoweredOn) { NSLog(GAP扫描者就绪开始扫描周围GAP广播GAP协议); // 开始GAP扫描底层自动扫描3个广播信道符合GAP规范 // options参数设置是否允许重复扫描NO表示只扫描一次提升效率 [central scanForPeripheralsWithServices:nil options:{CBCentralManagerScanOptionAllowDuplicatesKey: NO}]; } } // 发现GAP广播设备GAP扫描核心回调获取广播包信息 - (void)centralManager:(CBCentralManager *)central didDiscoverPeripheral:(CBPeripheral *)peripheral advertisementData:(NSDictionaryNSString *,id *)advertisementData RSSI:(NSNumber *)RSSI { // 从GAP广播包中获取设备信息符合GAP协议规范的字段 NSString *deviceName advertisementData[CBAdvertisementDataLocalNameKey] ?: 未知设备; NSString *deviceUUID peripheral.identifier.UUIDString; // 设备唯一标识GAP协议定义 NSNumber *signalStrength RSSI; // 信号强度GAP广播包扩展字段 NSLog(发现GAP广播设备名称%UUID%信号强度% dBm, deviceName, deviceUUID, signalStrength); // 过滤目标设备根据设备名称符合GAP扫描逻辑 if ([deviceName isEqualToString:GAP-Device]) { NSLog(发现目标GAP设备停止扫描); [central stopScan]; // 停止扫描准备发起连接 // 后续可调用GAP连接、配对逻辑 } } // 停止GAP扫描 - (void)stopGAPScanning { if (self.centralManager.isScanning) { [self.centralManager stopScan]; NSLog(GAP扫描已停止); } } end2Flutter—— BLE扫描GAP扫描者依赖flutter_blue_plus// 导入依赖 import package:flutter_blue_plus/flutter_blue_plus.dart; // 开始GAP扫描扫描周围的GAP广播设备 Futurevoid startGAPScanning() async { // 检查蓝牙状态开启蓝牙GAP扫描前提 if (await FlutterBluePlus.isOn false) { await FlutterBluePlus.turnOn(); } // 开始GAP扫描插件底层封装GAP协议自动扫描3个广播信道 // timeout扫描超时时间10秒符合GAP扫描效率规范 FlutterBluePlus.startScan(timeout: const Duration(seconds: 10)); print(GAP扫描已开始正在扫描周围GAP广播设备); // 监听GAP扫描结果获取广播包信息符合GAP协议 FlutterBluePlus.scanResults.listen((ListScanResult results) { for (ScanResult result in results) { // 从GAP广播包中提取设备信息 String deviceName result.device.name ?? 未知设备; String deviceAddress result.device.address; // 设备MAC地址GAP协议定义 int signalStrength result.rssi; // 信号强度 print(发现GAP设备名称$deviceName地址$deviceAddress信号强度$signalStrength dBm); // 过滤目标GAP设备 if (deviceName GAP-Device) { print(发现目标GAP设备停止扫描); FlutterBluePlus.stopScan(); // 后续可发起GAP连接、配对 } } }); } // 停止GAP扫描 Futurevoid stopGAPScanning() async { if (FlutterBluePlus.isScanningNow) { FlutterBluePlus.stopScan(); print(GAP扫描已停止); } }3AndroidJava—— BLE扫描GAP扫描者// 导入GAP相关包 import android.bluetooth.BluetoothAdapter; import android.bluetooth.le.BluetoothLeScanner; import android.bluetooth.le.ScanCallback; import android.bluetooth.le.ScanResult; // GAP扫描者实现类 public class GAPScanner { private BluetoothLeScanner scanner; // GAP扫描核心对象 // 开始GAP扫描 public void startGAPScanning() { BluetoothAdapter bluetoothAdapter BluetoothAdapter.getDefaultAdapter(); if (bluetoothAdapter null || !bluetoothAdapter.isEnabled()) { System.out.println(蓝牙未开启无法启动GAP扫描); return; } // 获取GAP扫描对象底层已实现GAP扫描协议 scanner bluetoothAdapter.getBluetoothLeScanner(); if (scanner null) { System.out.println(设备不支持GAP扫描); return; } // 开始GAP扫描符合GAP规范自动扫描3个广播信道 scanner.startScan(new ScanCallback() { Override public void onScanResult(int callbackType, ScanResult result) { super.onScanResult(callbackType, result); // 从GAP广播包中提取设备信息符合GAP协议 String deviceName result.getDevice().getName() null ? 未知设备 : result.getDevice().getName(); String deviceAddress result.getDevice().getAddress(); // 设备MAC地址GAP定义 int signalStrength result.getRssi(); // 信号强度 System.out.println(发现GAP设备名称 deviceName 地址 deviceAddress 信号强度 signalStrength dBm); // 过滤目标GAP设备 if (GAP-Device.equals(deviceName)) { System.out.println(发现目标GAP设备停止扫描); stopGAPScanning(); // 后续可发起GAP连接、配对 } } }); System.out.println(GAP扫描已开始遵循GAP协议扫描广播设备); } // 停止GAP扫描 public void stopGAPScanning() { if (scanner ! null) { scanner.stopScan(new ScanCallback() {}); System.out.println(GAP扫描已停止); } } }3. 功能3配对管理GAP核心交互场景扫描到目标设备后通过GAP协议完成身份认证配对协商加密密钥确保设备间的通信安全这是GAP协议的核心安全功能。1iOSOC—— GAP配对监听系统自动处理配对流程// 继续使用上面的GAP扫描者管理器连接后监听GAP配对状态 #import CoreBluetooth/CoreBluetooth.h interface GAPPairManager () CBCentralManagerDelegate, CBPeripheralDelegate property (nonatomic, strong) CBCentralManager *centralManager; property (nonatomic, strong) CBPeripheral *targetPeripheral; // 目标GAP设备 end implementation GAPPairManager // 连接目标GAP设备触发GAP配对 - (void)connectToGAPDevice:(CBPeripheral *)peripheral { self.targetPeripheral peripheral; self.targetPeripheral.delegate self; // 发起GAP连接连接成功后系统自动触发GAP配对流程符合GAP协议 [self.centralManager connectPeripheral:peripheral options:nil]; } // GAP连接成功开始监听配对状态GAP配对核心回调 - (void)centralManager:(CBCentralManager *)central didConnectPeripheral:(CBPeripheral *)peripheral { NSLog(GAP设备连接成功触发GAP配对流程); // 发现设备服务间接判断配对状态符合GAP协议逻辑 [peripheral discoverServices:nil]; } // 监听GAP配对状态通过服务发现结果判断配对是否成功 - (void)peripheral:(CBPeripheral *)peripheral didDiscoverServices:(NSError *)error { if (error) { NSLog(GAP配对失败%可能未完成身份认证, error.localizedDescription); return; } // 服务发现成功说明GAP配对已完成iOS系统自动处理配对弹窗无需手动干预 NSLog(GAP配对成功已完成身份认证可进行后续数据传输); } // 辅助方法判断设备是否已完成GAP配对 - (BOOL)isGAPPaired:(CBPeripheral *)peripheral { // GAP配对信息由系统保存通过获取已连接设备列表判断 NSArray *pairedPeripherals [self.centralManager retrieveConnectedPeripheralsWithServices:nil]; for (CBPeripheral *p in pairedPeripherals) { if ([p.identifier isEqualToString:peripheral.identifier]) { return YES; } } return NO; } end2Flutter—— GAP配对监听依赖flutter_blue_plus// 导入依赖 import package:flutter_blue_plus/flutter_blue_plus.dart; // 连接GAP设备并监听配对状态GAP配对流程 Futurevoid connectAndMonitorGAPPairing(BluetoothDevice device) async { try { // 发起GAP连接连接成功后触发GAP配对流程 await device.connect(); print(GAP设备连接成功开始GAP配对); // 监听GAP配对状态通过服务发现结果判断符合GAP协议 device.discoverServices().then((ListBluetoothService services) { if (services.isNotEmpty) { print(GAP配对成功已完成身份认证获取到设备服务); } }).catchError((error) { print(GAP配对失败$error可能未完成身份认证); }); // 监听GAP配对后的连接状态 device.connectionState.listen((BluetoothConnectionState state) { if (state BluetoothConnectionState.connected) { print(GAP配对后设备保持连接状态); } else if (state BluetoothConnectionState.disconnected) { print(GAP配对后连接断开可尝试重新配对连接); } }); } catch (e) { print(GAP设备连接失败无法触发配对$e); } } // 断开GAP配对连接 Futurevoid disconnectGAPPairedDevice(BluetoothDevice device) async { if (device.connectionState BluetoothConnectionState.connected) { await device.disconnect(); print(GAP配对连接已断开); } }3AndroidJava—— GAP配对发起与监听// 导入GAP配对相关包 import android.bluetooth.BluetoothDevice; import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGattCallback; import android.bluetooth.BluetoothProfile; import android.content.Context; import android.content.IntentFilter; import android.content.BroadcastReceiver; import android.content.Intent; // GAP配对管理器发起配对、监听配对状态 public class GAPPairManager { private Context context; public GAPPairManager(Context context) { this.context context; } // 发起GAP配对经典蓝牙符合GAP协议规范 public void startGAPPairing(BluetoothDevice device) { // 注册广播接收器监听GAP配对状态Android系统GAP配对回调 IntentFilter filter new IntentFilter(BluetoothDevice.ACTION_PAIRING_REQUEST); context.registerReceiver(new BroadcastReceiver() { Override public void onReceive(Context context, Intent intent) { String action intent.getAction(); if (BluetoothDevice.ACTION_PAIRING_REQUEST.equals(action)) { // 取消系统默认配对弹窗手动处理GAP配对可选 abortBroadcast(); BluetoothDevice pairedDevice intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); // 发起GAP配对经典蓝牙需输入PIN码符合GAP协议此处以0000为例 pairedDevice.setPin(new byte[]{0x30, 0x30, 0x30, 0x30}); pairedDevice.setPairingConfirmation(true); System.out.println(GAP配对成功 pairedDevice.getName()); } } }, filter); // 发起GAP配对请求通过反射调用符合GAP协议 try { java.lang.reflect.Method method BluetoothDevice.class.getMethod(createBond); method.invoke(device); System.out.println(发起GAP配对请求 device.getName()); } catch (Exception e) { e.printStackTrace(); System.out.println(GAP配对请求失败 e.getMessage()); } } // BLE设备GAP配对连接后自动配对符合GAP协议 public void connectAndPairGAPBLEDevice(BluetoothDevice device) { // 发起GAP连接连接成功后自动触发配对 device.connectGatt(context, false, new BluetoothGattCallback() { Override public void onConnectionStateChange(BluetoothGatt gatt, int status, int newState) { super.onConnectionStateChange(gatt, status, newState); if (newState BluetoothProfile.STATE_CONNECTED) { System.out.println(GAP BLE设备连接成功自动触发GAP配对); gatt.discoverServices(); // 发现服务确认配对成功 } else if (newState BluetoothProfile.STATE_DISCONNECTED) { System.out.println(GAP配对连接断开); } } Override public void onServicesDiscovered(BluetoothGatt gatt, int status) { super.onServicesDiscovered(gatt, status); if (status BluetoothGatt.GATT_SUCCESS) { System.out.println(GAP BLE配对成功已完成身份认证); } else { System.out.println(GAP BLE配对失败服务发现失败); } } }); } }4. 功能4连接管理GAP协议收尾场景GAP配对成功后建立稳定的连接链路管理连接状态连接成功、断开、重连为后续GATT数据传输提供基础。1iOSOC—— GAP连接管理// 继续使用GAPPairManager完善GAP连接管理逻辑 #import CoreBluetooth/CoreBluetooth.h interface GAPConnectionManager () CBCentralManagerDelegate, CBPeripheralDelegate property (nonatomic, strong) CBCentralManager *centralManager; property (nonatomic, strong) CBPeripheral *connectedPeripheral; // 已连接的GAP设备 end implementation GAPConnectionManager // 发起GAP连接配对后建立连接符合GAP协议 - (void)connectGAPDevice:(CBPeripheral *)peripheral { self.centralManager [[CBCentralManager alloc] initWithDelegate:self queue:nil options:nil]; if (self.centralManager.state CBManagerStatePoweredOn) { NSLog(发起GAP连接%, peripheral.name); [self.centralManager connectPeripheral:peripheral options:nil]; } } // GAP连接成功GAP协议核心回调 - (void)centralManager:(CBCentralManager *)central didConnectPeripheral:(CBPeripheral *)peripheral { self.connectedPeripheral peripheral; peripheral.delegate self; NSLog(GAP连接成功%已建立稳定链路GAP协议, peripheral.name); // 发现设备服务准备后续数据传输 [peripheral discoverServices:nil]; } // GAP连接失败GAP协议异常处理 - (void)centralManager:(CBCentralManager *)central didFailToConnectPeripheral:(CBPeripheral *)peripheral error:(NSError *)error { NSLog(GAP连接失败%错误信息%, peripheral.name, error.localizedDescription); // 重试连接符合GAP连接重试规范 [central connectPeripheral:peripheral options:nil]; } // GAP连接断开GAP协议异常处理 - (void)centralManager:(CBCentralManager *)central didDisconnectPeripheral:(CBPeripheral *)peripheral error:(NSError *)error { NSLog(GAP连接断开%错误信息%, peripheral.name, error.localizedDescription); self.connectedPeripheral nil; // 重新扫描并连接符合GAP连接管理逻辑 [central scanForPeripheralsWithServices:nil options:nil]; } // 断开GAP连接 - (void)disconnectGAPDevice { if (self.connectedPeripheral self.centralManager.isConnected(self.connectedPeripheral)) { [self.centralManager cancelPeripheralConnection:self.connectedPeripheral]; NSLog(GAP连接已主动断开); } } end2Flutter—— GAP连接管理依赖flutter_blue_plus// 导入依赖 import package:flutter_blue_plus/flutter_blue_plus.dart; // GAP连接管理类 class GAPConnectionManager { BluetoothDevice? _connectedDevice; // 已连接的GAP设备 // 发起GAP连接 Futurevoid connectGAPDevice(BluetoothDevice device) async { try { if (await FlutterBluePlus.isOn false) { await FlutterBluePlus.turnOn(); } // 发起GAP连接符合GAP协议配对后建立连接 await device.connect(autoConnect: false); _connectedDevice device; print(GAP连接成功${device.name}建立稳定链路); // 监听GAP连接状态变化 device.connectionState.listen((BluetoothConnectionState state) { switch (state) { case BluetoothConnectionState.connected: print(GAP连接保持稳定); break; case BluetoothConnectionState.disconnected: print(GAP连接断开尝试重连); reconnectGAPDevice(device); // 自动重连 break; default: break; } }); } catch (e) { print(GAP连接失败$e); } } // GAP连接重连符合GAP协议异常处理 Futurevoid reconnectGAPDevice(BluetoothDevice device) async { try { await device.connect(autoConnect: true); _connectedDevice device; print(GAP设备重连成功${device.name}); } catch (e) { print(GAP设备重连失败$e); } } // 断开GAP连接 Futurevoid disconnectGAPDevice() async { if (_connectedDevice ! null _connectedDevice!.connectionState BluetoothConnectionState.connected) { await _connectedDevice!.disconnect(); _connectedDevice null; print(GAP连接已主动断开); } } }3AndroidJava—— GAP连接管理// 导入GAP连接相关包 import android.bluetooth.BluetoothDevice; import android.bluetooth.BluetoothGatt; import android.bluetooth.BluetoothGattCallback; import android.bluetooth.BluetoothProfile; import android.content.Context; // GAP连接管理器 public class GAPConnectionManager { private Context context; private BluetoothGatt gatt; // GAP连接核心对象 public GAPConnectionManager(Context context) { this.context context; } // 发起GAP连接BLE设备符合GAP协议 public void connectGAPDevice(BluetoothDevice device) { // 发起GAP连接获取GATT对象GAP连接的核心载体 gatt device.connectGatt(context, false, new BluetoothGattCallback() { Override public void onConnectionStateChange(BluetoothGatt gatt, int status, int newState) { super.onConnectionStateChange(gatt, status, newState); if (newState BluetoothProfile.STATE_CONNECTED) { System.out.println(GAP连接成功 gatt.getDevice().getName()); // 发现服务准备数据传输 gatt.discoverServices(); } else if (newState BluetoothProfile.STATE_DISCONNECTED) { System.out.println(GAP连接断开尝试重连); reconnectGAPDevice(device); // 自动重连 } } }); } // GAP连接重连符合GAP协议异常处理 public void reconnectGAPDevice(BluetoothDevice device) { if (gatt ! null) { gatt.connect(); System.out.println(GAP设备重连中 device.getName()); } else { connectGAPDevice(device); } } // 断开GAP连接 public void disconnectGAPDevice() { if (gatt ! null) { gatt.disconnect(); gatt.close(); gatt null; System.out.println(GAP连接已主动断开); } } }三、GAP开发注意事项避坑重点GAP协议是“通用规范”无论经典蓝牙还是BLE都必须遵循开发时无需区分重点关注角色广播者/扫描者即可广播包大小限制GAP广播包最大31字节BLE经典蓝牙略大开发时避免在广播包中携带过多数据仅传递设备基础信息配对流程iOS/Flutter的GAP配对由系统自动处理开发者仅能监听状态Android可手动处理配对如自定义PIN码但需遵循GAP协议规范连接稳定性GAP连接后需监听连接状态实现重连逻辑避免因设备远离、信号干扰导致连接断开权限问题多平台开发时需申请蓝牙权限如iOS的NSBluetoothAlwaysUsageDescriptionAndroid的BLUETOOTH、BLUETOOTH_ADMIN等否则无法正常使用GAP功能。四、总结GAP协议的核心价值GAP通用访问协议是蓝牙设备“互联互通”的基础——它定义了设备如何“自我介绍”广播、如何“寻找朋友”扫描、如何“建立信任”配对、如何“保持联系”连接。没有GAP不同厂商、不同类型的蓝牙设备就无法相互识别、建立连接。对于开发者而言掌握GAP协议就是掌握了蓝牙开发的“入门钥匙”无论是智能硬件、物联网设备还是手机端蓝牙应用所有涉及“设备交互”的场景都离不开GAP的核心操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2566325.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…