当前位置: 首页 > news >正文

某当劳请求头 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...

http://www.rkmt.cn/news/120679.html

相关文章:

  • 2025国产网络游戏好玩排行榜 热门作品带你体验多样乐趣 - 品牌排行榜
  • 2025年度生南瓜籽仁供应商推荐:原味生南瓜籽仁源头工厂实力 - mypinpai
  • MediaPipe Selfie Segmentation Web Worker性能优化实战:告别卡顿,实现60FPS流畅体验
  • 福建省厦门市自建房设计公司排行榜出炉!权威评测 + 真实案例,建房选对不踩坑 - 苏木2025
  • C++ map 全面解析:核心特性、用法与实战
  • Windows微信机器人终极指南:免费自动化助手从零到精通
  • AutoScreenshot智能截屏系统:从入门到精通的完整指南
  • 分布式同步技术如何重塑多设备协作体验?
  • 【权威发布】MCP认证有效期将至:如何在72小时内成功锁定考位?
  • 吾爱大神封神!AI 驱动 PDF 预览 + OCR 工具,小白也能秒上手
  • PathOfBuilding终极指南:流放之路离线Build规划神器
  • 基于QT(C++)+MySQL实现(窗体)学生信息管理系统
  • 后台录像神器,息屏也能悄无声息记录(附用法)
  • xshell能连上ubuntu24而vscode连接不上_临时关闭 Windows 防火墙
  • 3、软件开发调试基础设施全解析
  • MCP量子认证备考必看(内部绝密模拟题流出)
  • 英雄联盟皮肤修改神器R3nzSkin:三步解锁全英雄付费皮肤
  • AI Agent文档生成效率翻倍的秘密:5个你不知道的部署优化技巧
  • 超声波分散机知名品牌有哪些,哪个品牌口碑好?2025年度排行榜 - 品牌推荐大师
  • 为什么你的AI Agent扛不住流量洪峰?5个真实压测案例告诉你真相
  • Lenovo Legion Toolkit终极故障排除手册:20个常见问题一步到位解决方案
  • 【MCP Azure量子监控全攻略】:掌握五大核心工具提升系统稳定性
  • 5、Win32调试器深度解析
  • GIF流畅度提升终极指南:Waifu2x完整使用教程
  • Kotaemon中的热点数据预加载机制提升响应
  • 【限时干货】AI Agent文档生成部署实战:从环境搭建到上线监控
  • Flow Launcher文件替换异常终极解决方案:从诊断到加固的完整实战指南
  • 3分钟掌握B站黑名单管理:告别烦人弹幕的终极指南
  • MCP续证在即,最后3个名额锁定权威培训资源
  • Waifu Diffusion v1.4:从零开始掌握AI绘画的7个关键步骤