news 2026/2/22 7:19:57

CPP sign值逆向

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CPP sign值逆向

0x0 引言

app在请求下单的时候会携带一个sign值,这个sign值是通过特定的签名算法生成的加密字符串,主要用于接口安全验证和防篡改保护。

sign:e24c6676f38d3e97178de0808b931781

初步推测可能采用了MD5加密,这并非主流大厂的产品。

通常的生成流程

  • 参数排序:将所有请求参数(除sign本身外)按照参数名的ASCII码从小到大排序

  • 参数拼接:将排序后的参数以"参数名=参数值"的格式用"&"符号连接起来,例如:amount=100&order_id=123456×tamp=1625097600

  • 添加密钥:在拼接后的字符串末尾加上预先约定的API密钥(secret key),如:amount=100&order_id=123456×tamp=1625097600&key=secret_key

  • 加密计算:对最终字符串进行MD5或SHA1等加密运算,生成sign

直接尝试用 Frida 进行 hook 操作:

0x1 frida hook

md5参数值

PWFSJVAEQYUSNDEFNMHSISJISKHSULDESKM5935JVABS2528909106671L9D2A7M0U5Y2T0C2PPC

请求参数

{ "timeStamp": 1766019098252, "nonce": "SBAVJ", "sign": "903fb31cd87c0990b36728a54e049136", "ticketTypeId": 5395, "count": 1, "purchaserIds": "" }

看到这里,心里突然"咯噔"一下,像是被什么东西猛地揪住了。仔细检查了好几遍,发现确实没有对应的参数可以匹配这个操作。手心开始微微冒汗,脑子里闪过各种可能的解决方案。这时,我深吸一口气告诉自己:"别慌,保持冷静"。

突然想到一个有趣的思路:既然正向查找不行,那为什么不试试反向操作呢?或许将字符串倒序输出就能找到突破口。

CPP2C0T2Y5U0M7A2D9L1766019098252SBAVJ5395MKSEDLUSHKSIJSISHMNFEDNSUYQEAVJSFWP

0x2 参数分析

  • 固定值1: CPP2C0T2Y5U0M7A2D9L
  • timestamp: 1766019098252
  • nonce: SBAVJ
  • ticketTypeId: 5395
  • 固定值2:MKSEDLUSHKSIJSISHMNFEDNSUYQEAVJSFWP

经过多次深入分析(包括日志记录、数据比对和单元测试验证),发现固定值1和固定值2在整个程序运行周期内始终保持不变,由于这两个值表现稳定且不影响核心功能,后续有时间的话再进行深入反编译分析

nonce是一个随机生成的5位字符串,主要用于安全验证和防重放攻击

0x3 sign值构造

拼接规则详细说明:

  1. 前缀部分(reverse(prefix))

  2. 票种ID处理(reverse(ticketTypeId))

  3. 随机数处理(reverse(nonce))

  4. 时间戳处理(reverse(timestamp))

  5. 后缀部分(reverse(suffix))

完整示例: 输入参数:

  • prefix = "CPP2C0T2Y5U0M7A2D9L"
  • ticketTypeId = "5395"
  • nonce = "SBAVJ"
  • timestamp = "1766019098252"
  • suffix = "MKSEDLUSHKSIJSISHMNFEDNSUYQEAVJSFWP"

最终拼接结果: reverse(prefix) + reverse(ticketTypeId) + reverse(nonce) + reverse(timestamp) +reverse(suffix)

将拼接的结果再进行md5得到sign

0x4 sign值还原

def _reverse(self, value) -> str: """ 通用倒序方法,数字先转字符串再倒序 """ return str(value)[::-1] def _generate_nonce(self, length: int = 5) -> str: """ 生成随机字符串,默认长度 5 """ return ''.join(random.choices(string.ascii_uppercase, k=length)) def _md5(self, text: str) -> str: """ 计算字符串的 MD5 值,返回小写十六进制 """ return hashlib.md5(text.encode("utf-8")).hexdigest() def generate_sign(self, ticket_type_id: int, nonce: str, timestamp: int) -> str: """ 生成 sign 拼接规则:prefix + reverse(ticketTypeId) + reverse(nonce) + reverse(timestamp) + suffix """ raw_str = f"{self.prefix}{self._reverse(ticket_type_id)}{self._reverse(nonce)}{self._reverse(timestamp)}{self.suffix}" return self._md5(raw_str)

0x5 结论

由于MD5加密算法具有单向不可逆的特性(无法通过哈希值反推出原始数据),因此在服务器端进行签名校验(sign值验证)时,必须要求客户端在请求中提供用于生成签名的原始参数或相关数据。基于此,我们尝试对字符串进行倒序处理。

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

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

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

作者头像 李华
网站建设 2026/2/18 20:14:51

C语言大小端格式详解

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

作者头像 李华
网站建设 2026/2/21 18:51:09

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

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

作者头像 李华
网站建设 2026/2/19 2:51:01

终极指南:使用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/2/21 6:00:52

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

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

作者头像 李华
网站建设 2026/2/20 14:22:45

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

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

作者头像 李华