华为手机如何扫描到SLE设备

发布于:2025-07-08 ⋅ 阅读:(16) ⋅ 点赞:(0)

    最近研究星闪通信发现:使用华为Mate 60 Pro扫描不到星闪开发板的SLE广播。这里分析原因并给出解决方案。

 ​​一、华为蓝牙&星闪过滤机制的核心原理​

  1. ​​链路层硬件过滤

    1. 过滤器接受列表:华为设备在蓝牙链路层(Link Layer)维护一个“白名单”,仅响应列表中指定地址的设备广播。非列表内的设备数据包会被直接丢弃,避免唤醒主机处理,显著降低功耗。
    2. ​​广播过滤策略​:根据设备状态(广播/扫描/发起连接)独立启用过滤规则。例如,扫描状态下仅处理白名单设备的广播包,减少无效响应。
  2. ​​动态安全过滤(专利技术)​

    • 密钥+时间戳动态规则​​:华为专利技术通过预协商密钥和同步时间戳生成动态过滤规则,广播包需携带特定加密标签才能被目标设备处理。攻击者无法通过抓包伪造合法广播,提升安全性。
  3. ​​广播包合规性过滤​

    • 强制标准Service UUID​:与苹果类似,华为会过滤未包含标准16位Service UUID(如0x180A)的广播包,非标设备(如某些开发板)可能被忽略。
    • ​​广播间隔限制​:广播间隔超出20ms~10.24s范围的设备可能被判定为异常,不予显示。

 ​​二、过滤设备提升用户体验​

  1. ​设备列表“干净”​​
    普通用户开启蓝牙&星闪扫描时,仅显示配对过的设备或符合华为认证协议的设备,避免列表被大量无关设备淹没。

  2. ​连接稳定性优化​​
    过滤机制减少无效广播干扰,降低多设备竞争导致的断连风险。例如在机场等密集环境,华为手机更易稳定连接目标耳机。

  3. ​​安全隐私保护​​
    动态过滤规则阻挡伪造广播包(如蓝牙定位跟踪器),防止恶意设备通过广播包获取用户位置或设备信息。

三、华为手机扫描星闪开发板解决方案

1. 直接烧录鼠标键盘例程

(过程略)

2. 手动修改广播包

2.1 修改广播数据和广播应答数据

// 鼠标广播数据,可被星闪手机识别
#define SLE_ADV_DATA_LEN 33
#define SLE_ADV_RSP_DATA_LEN 15
static uint8_t g_sle_adv_data[SLE_ADV_DATA_LEN] = {
    // flag
    0x01,
    0x01, 0x01,
    0x05,
    0x04, 0x0B, 0x06, 0x09, 0x06,
    // appearance
    0x03,
    0x16, 0x09, 0x06, 0x07, 0x03, 0x02, 0x05, 0x00,
    0x06, 0x0D,
    's', 'l', 'e', '_', 'a', 'i', 'r', '_', 'm', 'o', 'u', 's', 'e'
};

// 鼠标广播应答数据,可被星闪手机识别
static uint8_t g_sle_adv_rsp_data[SLE_ADV_RSP_DATA_LEN] = {
    0x0B,
    0x0D, 's', 'l', 'e', '_', 'a', 'i', 'r', '_', 'm', 'o', 'u', 's', 'e',
};

 2.2 构造广播数据并广播

/*******************************************************************************
 * @name        sle_set_adv_local_name
 * @brief       构造广播数据中的设备名称字段
 *******************************************************************************/
static int sle_set_default_announce_data(void) {
    errcode_t ret;
    uint8_t announce_data_len = 0;
    uint8_t seek_data_len = 0;

    sle_announce_data_t data = {0};
    uint8_t adv_handle = SLE_ADV_HANDLE_DEFAULT;
    uint8_t announce_data[SLE_ADV_DATA_LEN_MAX] = {0};
    uint8_t seek_rsp_data[SLE_ADV_DATA_LEN_MAX] = {0};
    uint8_t data_index = 0;

    // 生成主广播数据(发现级别+访问模式)
    announce_data_len = sle_set_adv_data(announce_data);
    data.announce_data = announce_data;
    data.announce_data_len = announce_data_len;
    data.announce_data = g_sle_adv_data;
    data.announce_data_len = SLE_ADV_DATA_LEN;

    // 生成扫描响应数据(发射功率+设备名称)
    seek_data_len = sle_set_scan_response_data(seek_rsp_data);
    data.seek_rsp_data = seek_rsp_data;
    data.seek_rsp_data_len = seek_data_len;
    data.seek_rsp_data = g_sle_adv_rsp_data;
    data.seek_rsp_data_len = SLE_ADV_RSP_DATA_LEN;

    // 提交广播数据配置
    sle_set_announce_data(adv_handle, &data);

    return ERRCODE_SLE_SUCCESS;
}

2.3 编译烧录SLE Server固件

    编译烧录后,开启华为手机的SLE,扫描设备列表即可成功扫描到星闪设备。如果扫不到,重点检查广播数据和广播应答数据。