
本教程旨在指导读者如何解析ibeacon设备的原始十六进制数据。通过详细剖析ibeacon广播包的标准结构,包括广告标志、制造商特定数据、uuid、major、minor以及tx power等关键字段,文章将提供分步解析示例和编程实现思路,帮助您准确提取和理解ibeacon传输的信息。
1. iBeacon广播数据包结构概述
iBeacon设备利用蓝牙低功耗(BLE)技术广播其标识信息。这些信息通常以十六进制字符串的形式封装在诸如rawData的字段中。为了有效解析和利用这些数据,理解iBeacon广播包的底层标准结构至关重要。一个典型的iBeacon广播包由多个AD(Advertisement Data)结构组成,其中包含特定于iBeacon的关键数据。
一个标准的iBeacon广播数据包(特别是在制造商特定数据部分)通常遵循以下结构顺序:
- AD Flags (广告标志): 3字节。标准值为020106,表示设备处于BLE通用可发现模式且不支持BR/EDR。
- Length of AD Structure (AD结构长度): 1字节。此值为1A(十进制26),指示紧随其后的制造商特定数据部分的字节总数。
- AD Type (AD类型): 1字节。对于制造商特定数据,此值固定为FF。
- Company Identifier (公司标识符): 2字节。对于Apple iBeacon,此值为4C00(小端序表示,对应Apple的蓝牙SIG分配ID 004C)。
- iBeacon Type (iBeacon类型): 1字节。固定值为02,用于标识这是iBeacon协议数据。
- iBeacon Length (iBeacon数据长度): 1字节。固定值为15(十进制21),表示UUID、Major、Minor和Tx Power这四个字段的总长度。
- Proximity UUID (近场UUID): 16字节。一个全球唯一的标识符,用于区分不同的iBeacon部署或组织。
- Major (主值): 2字节。通常用于对iBeacon进行大范围分组。
- Minor (次值): 2字节。用于在Major组内进一步区分单个iBeacon设备。
- Measured Power (Tx Power): 1字节。这是一个有符号的8位整数,表示在距离iBeacon 1米处测得的RSSI(接收信号强度指示),常用于估算设备与iBeacon之间的距离。
将上述字段组合起来,一个标准的iBeacon数据前缀(包含AD Flags和制造商特定数据头)通常是0201061AFF4C000215,总计9字节(18个十六进制字符)。
2. 示例数据解析
我们以提供的JSON数据中的第二个rawData为例,详细演示如何根据上述结构进行解析:
0201061AFF4C000215FDA50693A4E24FB1AFCFC6EB0764782527114CB9C5
对照iBeacon数据包结构,我们可以将其分解如下:
-
020106: AD Flags (广告标志)
- 长度: 3字节
- 说明: 标准BLE广告标志。
-
1A: Length of AD Structure (AD结构长度)
- 长度: 1字节
- 说明: 表示后续制造商特定数据部分的长度为26字节。
-
FF: AD Type (AD类型)
- 长度: 1字节
- 说明: 标识为制造商特定数据类型。
-
4C00: Company Identifier (公司标识符)
- 长度: 2字节
- 说明: Apple公司的蓝牙SIG分配ID。
-
02: iBeacon Type (iBeacon类型)
- 长度: 1字节
- 说明: iBeacon协议的类型标识。
-
15: iBeacon Length (iBeacon数据长度)
- 长度: 1字节
- 说明: 表示UUID、Major、Minor和Tx Power这四个字段的总长度为21字节。
-
FDA50693A4E24FB1AFCFC6EB07647825: Proximity UUID (近场UUID)
- 长度: 16字节
- 值: FDA50693-A4E2-4FB1-AFCFC6EB07647825 (通常以连字符分隔显示)
-
2711: Major (主值)
- 长度: 2字节
- 值: 0x2711 (十六进制) = 10001 (十进制)
-
4CB9: Minor (次值)
- 长度: 2字节
- 值: 0x4CB9 (十六进制) = 19641 (十进制)
-
C5: Measured Power (Tx Power)
- 长度: 1字节
- 值: 0xC5 (十六进制)。这是一个有符号的8位整数。在补码表示下,0xC5转换为十进制为-59 dBm。
关于非标准rawData示例的说明: 原始问题中还提供了另一个rawData示例: 0201060303F1FF1716FDA50693A4E24FB1AFCFC6EB0764782527114CB9C564 这个示例在020106之后紧跟着0303F1FF...,与标准的1AFF4C000215前缀不符。这表明它可能不是一个严格遵循Apple iBeacon规范的广播包,或者它包含了额外的AD结构,或者它是一个不同制造商的自定义BLE广告包。在实际应用中,遇到此类数据需要参考具体的设备或协议文档进行解析,不能直接套用iBeacon标准结构。
3. 编程实现思路
在多数编程语言中,解析十六进制字符串通常涉及字符串的切片操作以及十六进制到十进制的类型转换。以下是一个使用Python的简化示例,演示如何从符合iBeacon标准的rawData中提取关键信息:
def parse_ibeacon_raw_data(raw_data_hex: str) -> dict | None:
"""
解析iBeacon的十六进制原始数据字符串。
Args:
raw_data_hex: iBeacon的十六进制字符串。










