蓝牙学习之unprovision beacon

使用telink的sig mesh tool,点击scan控件后网关会把收到的unprovision beacon上报上来,上报格式为:TSCRIPT_GATEWAY_DIR_RSP+ HCI_GATEWAY_CMD_UPDATE_MAC+mac(6 bytes)+unprovision beacon。即:91+88+mac(6 bytes)+ unprovision beacon。参考SIG Mesh SDK - Telink Documents

sig mesh tool打印的Log如下:

<0001>10:02:21:584 [INFO]:(GATEWAY)HCI_GATEWAY_CMD_UPDATE_MAC : 91 88 20 19 11 22 ff 11 18 2b 00 d8 1e 92 20 c3 d0 f2 3f 9b f2 3c 5c 43 7e 75 cf 00 00 d9 74 78 b3 ee 00 00

<0002>10:02:21:584 [INFO]:(common)the unprovision beacon is : 18 2b 00 d8 1e 92 20 c3 d0 f2 3f 9b f2 3c 5c 43 7e 75 cf 00 00 d9 74 78 b3

Log解析如下:

91 88 → TSCRIPT_GATEWAY_DIR_RSP+ HCI_GATEWAY_CMD_UPDATE_MAC

20 19 11 22 ff 11 → mac(6 bytes)

18 2b 00 d8 1e 92 20 c3 d0 f2 3f 9b f2 3c 5c 43 7e 75 cf 00 00 d9 74 78 b3 → unprovision beacon

mesh标准文档对Unprovisioned Device beacon 的描述如下:

unprovision beacon:

18 2b 00 d8 1e 92 20 c3 d0 f2 3f 9b f2 3c 5c 43 7e 75 cf 00 00 d9 74 78 b3

18 → Len 0x18=24字节

2b → type=<<Mesh Beacon>> #define MESH_ADV_TYPE_BEACON (0x2B)

00 → Beacon Type→ 对应mesh标准文档章节spec 3.9.2 Unprovisioned Device beacon → Unprovisioned Device beacon type (0x00)

d8 1e 92 20 c3 d0 f2 3f 9b f2 3c 5c 43 7e 75 cf → Device UUID

00 00 → OOB Information: 0x00 00 表示 未使用 OOB 认证

d9 74 78 b3 → URI Hash:Hash of the associated URI advertised with the URI AD Type (optional field)

对于Unprovisioned Device beacon解析到此为止,接下来是对URI Data和URI Hash的验证。

telink SDK里的URI Data 和URI Hash例子如下:

URI Data : 172f2f7777772e6578616d706c652e636f6d2f6d6573682f70726f64756374732f6c696768742d7377697463682d7633

URI Hash : d97478b3667f4839487469c72b8e5e9e

接下来用python对上述URI Hash进行验算:

python 复制代码
from cryptography.hazmat.primitives import cmac
from cryptography.hazmat.primitives.ciphers import algorithms

def compute_uri_hash(uri_data: bytes) -> bytes:
    """
    根据 Bluetooth Mesh 规范计算 URI Hash。
    Args:
        uri_data (bytes): URI Data 的原始字节(来自 AD Type 0x24 的 payload)    
    Returns:
        bytes: 4 字节的 URI Hash (s1(uri_data)[0:4])
    """
    # 零密钥:16 字节全 0
    zero_key = bytes(16)
    # 创建 AES-CMAC 实例
    c = cmac.CMAC(algorithms.AES(zero_key))
    # 更新输入数据
    c.update(uri_data)
    # 获取 16 字节 CMAC 结果
    mac = c.finalize()
    # 返回前 4 字节作为 URI Hash
    return mac[:4]
# ----------------------------
# 示例:使用你提供的 URI_DATA
# ----------------------------
if __name__ == "__main__":
    # URI Data as hex string (your input)
    uri_hex = "172f2f7777772e6578616d706c652e636f6d2f6d6573682f70726f64756374732f6c696768742d7377697463682d7633"
    # 转为 bytes
    uri_data = bytes.fromhex(uri_hex)
    # 计算 URI Hash
    uri_hash = compute_uri_hash(uri_data)
    # 输出结果
    print("URI Data (hex):", uri_hex)
    print("URI Hash (hex):", uri_hash.hex().upper())
    print("URI Hash (bytes):", list(uri_hash))

结果如下:

URI Data (hex): 172f2f7777772e6578616d706c652e636f6d2f6d6573682f70726f64756374732f6c696768742d7377697463682d7633

URI Hash (hex): D97478B3

URI Hash (bytes): [217, 116, 120, 179]

URI_DATA的哈希计算,telink的主要实现函数为mesh_sec_func_s1()

cpp 复制代码
int mesh_sec_func_s1 (unsigned char *s1, unsigned char * m, int n);
...
mesh_sec_func_s1 (hash_tmp, uri_dat, sizeof(uri_dat));

结论:关于URI_Hash的计算,telink的实现遵循mesh的标准。

相关推荐
fengci.几秒前
ctfshow(web入门)295-300
java·开发语言·学习
Looooking3 分钟前
Python 之获取安装包所占用磁盘空间大小
python
WenGyyyL11 分钟前
ColBERT论文研读——NLP(IR)里程碑之作
人工智能·python·语言模型·自然语言处理
lxy-up14 分钟前
RAG--切片策略
python
ricky_fan21 分钟前
(OpenAI)Codex 安装、部署使用方式
python·macos·conda·vim
小王不爱笑13223 分钟前
Java 对象拷贝(浅拷贝 / 深拷贝)
java·开发语言·python
Flittly34 分钟前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(9)Agent Teams (智能体团队)
python·agent
DevnullCoffe1 小时前
Open Claw × 跨境电商:5个最有价值的 AI Agent 应用场景深度拆解
python·api
zh路西法1 小时前
【宇树机器人强化学习】(六):TensorBoard图表与手柄遥控go2测试
python·深度学习·机器学习·机器人
szcsun51 小时前
关于在pycharm中新建项目创建虚拟化环境venv
ide·python·pycharm