news 2026/6/19 1:34:55

某当劳请求头 x-hmac-digest 签名算法逆向分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
某当劳请求头 x-hmac-digest 签名算法逆向分析

0x0 前言

在之前的研究中,我们分析了该 App 的sign签名。但在进一步抓包过程中,发现 Headers 中的x-hmac-digest同样是请求成功的关键。若不还原此参数,直接重放请求会导致授权失败。本文将记录通过静态分析与动态调试还原该参数的过程。

0x1 静态分析:定位关键函数

通过抓包发现,请求头中包含x-hmac-digest字段。使用 IDA 对 App 进行反编译,全局搜索该字符串,定位到如下关键赋值代码:

通过代码可以看到,v28字典中存储了svx-mcd-gw-vx-hmac-digestauthorization。其中x-hmac-digest对应变量v26,而v26是由convertSignature:path:request:gmtTime:error:函数生成的。

深入追踪,最终定位到核心加密实现函数:

代码逻辑解读:

  • 调用了系统的CCHmac函数。

  • 第一个参数2u代表算法类型,通常对应HMAC-SHA256

  • v8v9分别是传入的KeyMessage

  • 最后将结果通过base64EncodedStringWithOptions:进行 Base64 编码。

0x2 动态调试:Hook 验证

为了验证分析是否正确,我们编写 Frida 脚本对MCDHTTPSignV4:hmacSHA256WithSecr相关方法进行 Hook,打印其入参和返回值。

Hook 输出分析:

  • arg2 (Key):QIpNjLtJALdcAEJPIxBMnLJv1BC2WdlovPHAKFQL

  • arg3 (Message): 这是一个拼接字符串,包含了 Method (GET)、Path (/bff/portal/home/index/user)、Query 参数、Token 以及 GMT 时间戳等。

  • Return Value:y9P3hlKEunuOmNaCWH3pc93UQ2lyxoarZeHGg8UDXUo=

这证实了x-hmac-digest就是由上述 Key 和拼接字符串经过 HMAC-SHA256 加密后再进行 Base64 编码得来的。

0x3 算法还原 (Python 实现)

运行结果显示,生成的digest与抓包数据完全一致。

0x4 深入溯源:固定 Key 的生成机制

在动态调试中,我们发现arg2 (Key)的值为QIpNjLtJALdcAEJPIxBMnLJv1BC2WdlovPHAKFQL且保持固定。为了搞清楚这个 Key 是如何产生的,我们回到 IDA 进一步检索。

1. 定位密钥生成函数

通过交叉引用,我们发现hmacS的密钥参数来自于v4XXX函数的返回值:

2. 揭秘硬编码逻辑

进入v4XXX函数内部,可以看到一段有趣的算法逻辑。它并非简单的字符串赋值,而是通过**循环异或(XOR)**操作生成的

在调试中发现,这个长度为 41 位的 Key 是固定的。为了防止被轻易识别,开发者在代码中对其进行了异或(XOR)混淆

3. 查找 Key 生成源头

代码中存在一个for循环,将字节数组byte_101BXXX的每一位与(i - 29)进行异或运算。

4. 提取内存数据

跳转到byte_101BXXX对应的内存地址,我们拿到了原始字节码:

原始数据流(部分):0xB2, 0xAD, 0x95, 0xA8, 0x8D, 0xA4, 0x9D...

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 20:10:24

DotnetSpider:重新定义.NET数据采集开发体验的智能爬虫框架

在当今数据驱动的时代,高效的数据采集方案已成为企业和开发者不可或缺的核心能力。对于.NET开发者而言,面对复杂的网络环境、反爬机制和多样化存储需求,传统的爬虫开发往往充满挑战。今天,让我们一起探索DotnetSpider——这款专为…

作者头像 李华
网站建设 2026/6/19 0:50:15

C语言大小端格式详解

C语言大小端格式详解 🔥作者简介: 一个平凡而乐于分享的小比特,中南民族大学通信工程专业研究生,研究方向无线联邦学习 🎬擅长领域:驱动开发,嵌入式软件开发,BSP开发 ❄️作者主页&a…

作者头像 李华
网站建设 2026/6/19 0:45:14

BG3ModManager终极指南:快速上手博德之门3模组管理器完整教程

BG3ModManager终极指南:快速上手博德之门3模组管理器完整教程 【免费下载链接】BG3ModManager A mod manager for Baldurs Gate 3. 项目地址: https://gitcode.com/gh_mirrors/bg/BG3ModManager 还在为《博德之门3》模组管理而烦恼吗?BG3ModManag…

作者头像 李华
网站建设 2026/6/18 14:44:45

终极指南:使用Python快速构建RFID读卡器应用

终极指南:使用Python快速构建RFID读卡器应用 【免费下载链接】MFRC522-python A small class to interface with the NFC reader Module MFRC522 项目地址: https://gitcode.com/gh_mirrors/mfr/MFRC522-python MFRC522-python是一个专为树莓派设计的轻量级P…

作者头像 李华
网站建设 2026/6/18 19:40:44

高特异性生物标记试剂ATTO 390 BCN双环(6.1.0)壬炔

【试剂描述】ATTO 390 BCN 是一种高性能紫外-蓝光荧光生物正交标记探针,通过将ATTO 390染料与双环[6.1.0]壬炔(BCN)点击化学基团共价结合而成。该探针可在无金属催化剂的温和生理条件下,与叠氮修饰的目标分子发生快速、高特异性的…

作者头像 李华
网站建设 2026/6/19 20:21:42

LOOT模组排序终极方案:告别天际模组冲突的完整指南

LOOT模组排序终极方案:告别天际模组冲突的完整指南 【免费下载链接】skyrimse The TES V: Skyrim Special Edition masterlist. 项目地址: https://gitcode.com/gh_mirrors/sk/skyrimse 你是否曾经遇到过这样的场景:精心挑选了几十个模组&#xf…

作者头像 李华