蓝牙学习之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的标准。

相关推荐
小龙在山东1 天前
基于 plumbum 跨平台执行Shell脚本
python
报错小能手1 天前
线程池学习(六)实现工作窃取线程池(WorkStealingThreadPool)
开发语言·学习
CCPC不拿奖不改名1 天前
python基础:python语言中的函数与模块+面试习题
开发语言·python·面试·职场和发展·蓝桥杯
毕设源码-朱学姐1 天前
【开题答辩全过程】以 基于Python语言的疫情数据可视化系统为例,包含答辩的问题和答案
开发语言·python·信息可视化
我送炭你添花1 天前
Pelco KBD300A 模拟器:07+2.Python 专题:线程安全与信号槽机制——项目多线程最佳实践
python·自动化·运维开发
小途软件1 天前
ssm607家政公司服务平台的设计与实现+vue
java·人工智能·pytorch·python·深度学习·语言模型
星火开发设计1 天前
二叉树详解及C++实现
java·数据结构·c++·学习·二叉树·知识·期末考试
laplace01231 天前
Part3 RAG文档切分
笔记·python·中间件·langchain·rag
dhdjjsjs1 天前
Day59 PythonStudy
python