news 2026/2/7 5:35:24

BLE 广播包结构

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
BLE 广播包结构

BLE(Bluetooth Low Energy,低功耗蓝牙)广播包(Advertising Packet)是 BLE 设备在广播信道上发送的数据包,用于向周围设备宣告自身存在、提供服务信息或建立连接。其结构遵循 Bluetooth Core Specification(通常参考 5.x 及以上版本)。


一、BLE 广播包整体结构

BLE 广播包由PDU(Protocol Data Unit)构成,而 PDU 分为两类:

  1. Advertising PDU:用于广播通信。
  2. Data PDU:用于已建立连接后的数据传输(不在本文讨论范围)。

我们关注的是Advertising PDU,其格式如下:

| Preamble (1 octet) | | Access Address (4 octets) | | PDU (可变长度,最多39字节) | | CRC (3 octets) |

注意:Preamble、Access Address 和 CRC 是物理层(PHY)字段,实际广播内容主要在PDU字段中。


二、Advertising PDU 结构

Advertising PDU 由Header(2 字节) + Payload(0~37 字节)组成:

| Header (16 bits) | Payload (0~37 bytes) |

1. Header(2 字节)

Bit 位字段名说明
0~3PDU Type广播包类型(如 ADV_IND、ADV_NONCONN_IND 等)
4RFU保留位(应为 0)
5TxAdd发送方地址类型:0=公共地址,1=随机地址
6 - RxAdd接收方地址类型(仅在定向广播中有效)
7~15 - LengthPayload 长度(单位:字节,最大 37)
常见 PDU Type:
  • 0000:ADV_IND(可连接的无定向广播)
  • 0001:ADV_DIRECT_IND(可连接的定向广播)
  • 0010:ADV_NONCONN_IND(不可连接的无定向广播)
  • 0011:SCAN_REQ(扫描请求,由扫描设备发出)
  • 0100:SCAN_RSP(扫描响应,由广播设备回应)
  • 0101:CONNECT_IND(连接请求)
  • 0110:ADV_SCAN_IND(可扫描的无定向广播)

注意:有些 Type 是由 Central(中心设备)发送的(如 SCAN_REQ),不是广播包,但属于 Advertising Channel PDU。


2. Payload(0~37 字节)

Payload 内容根据 PDU Type 不同而不同:

(1)通用广播类型(如 ADV_IND、ADV_NONCONN_IND、ADV_SCAN_IND)的 Payload:
| AdvA (6 bytes) | AdvData (0~31 bytes) |
  • AdvA:广播设备的蓝牙地址(Public 或 Random,由 TxAdd 指示)
  • AdvData:广播有效载荷,采用AD Structure(Advertising Data Structure)格式
(2)定向广播(ADV_DIRECT_IND)的 Payload:
| AdvA (6 bytes) | TargetA (6 bytes) |
  • TargetA:目标设备的蓝牙地址(由 RxAdd 指示地址类型)
(3)SCAN_RSP(扫描响应)的 Payload:
| AdvA (6 bytes) | ScanRspData (0~31 bytes) |
  • 与 ADV_IND 类似,但用于响应扫描请求

三、广播有效载荷(AdvData / ScanRspData)— AD Structure

广播数据(最多 31 字节)由一个或多个AD Structure组成,每个结构格式如下:

| Length (1 byte) | AD Type (1 byte) | AD Data (Length - 1 bytes) |
  • Length:包括 AD Type + AD Data 的总字节数(最小为 1,即只有 Type)
  • AD Type:定义数据类型(如设备名、服务 UUID、发射功率等)
  • AD Data:具体数据内容

常见 AD Type(来自 Bluetooth SIG Assigned Numbers):

AD Type (Hex)名称说明
0x01Flags标志位(如 LE Limited Discoverable Mode)
0x02, 0x0316-bit Service UUIDs完整/不完整的服务 UUID 列表
0x06, 0x07128-bit Service UUIDs128 位服务 UUID
0x09Complete Local Name完整设备名称
0x08Shortened Local Name缩短的设备名称
0x0ATX Power Level发射功率(dBm)
0x16Service Data - 16-bit UUID附带服务数据
0x21Service Data - 128-bit UUID128 位服务数据
0xFFManufacturer Specific Data厂商自定义数据

示例:设备广播名称 “MyBLE”
AD Structure =06 09 4D 79 42 4C 45

  • Length = 6(1 字节 Type + 5 字节 Name)
  • Type = 0x09(Complete Local Name)
  • Data = ASCII("MyBLE")

四、广播包长度限制

  • 单个广播包(AdvData)最多31 字节
  • 若需更多数据,可配合Scan Response(另外 31 字节)
  • BLE 5.0 引入Extended Advertising,支持更长广播数据(通过 AUX 广播包),但传统广播仍限于 31+31 字节

五、总结图示(传统广播)

[ADV_IND PDU] ├── Header (2B): Type=ADV_IND, TxAdd=1, Length=37 └── Payload (37B) ├── AdvA (6B): 随机地址 └── AdvData (31B): 多个 AD Structure ├── Flags (3 bytes) ├── Complete Local Name (6 bytes) └── Manufacturer Data (22 bytes)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/5 1:00:23

PyTorch通用开发环境真实体验,训练效率提升看得见

PyTorch通用开发环境真实体验,训练效率提升看得见 作为一名长期在深度学习一线“搬砖”的开发者,我深知一个稳定、高效、开箱即用的开发环境对项目推进有多重要。最近试用了基于官方PyTorch构建的 PyTorch-2.x-Universal-Dev-v1.0 镜像,整体…

作者头像 李华
网站建设 2026/2/6 5:03:23

YOLO26模型剪枝优化:减少参数量实战

YOLO26模型剪枝优化:减少参数量实战 在目标检测领域,YOLO系列一直以高效、快速著称。随着YOLO26的发布,其在精度和速度上的进一步提升吸引了大量开发者关注。然而,高性能往往伴随着庞大的模型体积和计算开销,这在边缘…

作者头像 李华
网站建设 2026/2/1 7:00:08

法律访谈记录神器!Seaco ASR模型真实应用分享

法律访谈记录神器!Seaco ASR模型真实应用分享 在法律实务中,访谈、询问、听证等口头交流环节产生的录音资料往往需要转化为文字材料,用于归档、分析或作为证据使用。传统的人工转录方式耗时耗力,且容易出错。有没有一种高效、准确…

作者头像 李华
网站建设 2026/2/5 5:50:08

NewBie-image-Exp0.1模型结构详解:Next-DiT架构优势与改进点分析

NewBie-image-Exp0.1模型结构详解:Next-DiT架构优势与改进点分析 1. 模型概览:NewBie-image-Exp0.1的核心能力 NewBie-image-Exp0.1 是一个专注于高质量动漫图像生成的扩散模型,其核心在于采用了创新的 Next-DiT(Next Denoising…

作者头像 李华
网站建设 2026/2/4 14:47:11

Solon AI Skills 会是 Agent 的未来吗?

在 AI Agent 从“对话玩具”走向“工业级基础设施”的过程中,开发者面临的核心矛盾已不再是模型智力,而是工程约束的缺失。 如果只给模型堆砌散乱的 Tool(函数),它就像一个拿着手术刀却未受过医学训练的孩子。Solon A…

作者头像 李华
网站建设 2026/2/4 16:40:41

【Python多线程性能陷阱】:为何Threading无法加速计算型任务?

第一章:Python多线程为何无法加速计算型任务 Python 的多线程在处理 I/O 密集型任务时表现良好,但在计算密集型场景下却难以发挥预期的性能优势。这一现象的根本原因在于 Python 解释器中的全局解释器锁(Global Interpreter Lock,…

作者头像 李华