news 2026/6/25 15:11:28

SMC(静态分析)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SMC(静态分析)

SMC简单来说就是自修改的代码段,这类题目一般来说都比较简单,只需要动态调试直接运行绕过加密函数,让程序自行解密,就可以看到被解密后的代码段。但是有些题目加入反调试后,反调试藏的很深,甚至程序会无脑报错,所以我们还有另外的解法,就是找到对加密代码段的加密函数,通过静态分析来解密修改,这种题目的难度就比较高,需要一定的代码审计能力,和使用IDApythond的熟练度,下面就来分析一下

入口分析

以2018年网鼎杯第三场SimpleSMC的题目为例,如何修复被修改的代码段
​编辑
在start函数中,没什么有用的东西,所以去看最后调用的函数sub_4010E0,它有几个参数函数分别是sub_400D45,sub_401930,sub_4019C0,也就是进入主逻辑和一些初始化步骤
进入看sub_400D45,很明显就是主逻辑
​编辑
在if这个语句里面,涉及了loc_400BAC和loc_400AA6,可以判断出这两段应该就是修改过或者经过花指令处理过,导致IDA无法识别为正确的函数,所以我们就去看这两个关键的段

寻找修改代码段的逻辑

进入看loc_400BAC

​编辑
IDA爆红,非常明显的花指令,看到jle near ptr loc_400BC8+1jnz near ptr loc_400BC8+1这两个明显冲突的指令,所以就是NOP掉,具体的NOP方法就是去看整段汇编逻辑
首先两个判断跳跃的指令,想要跳跃到loc_400BC8+1的位置,而call near ptr 1345194h则是因为两个错误的跳跃指令而导致IDA误判,所以我们只需要NOP掉BBC到BB8的位置就行了,不需要NOP掉BB9及其以后的数据,否则IP乱飞
此外,为了实现短跳跃的指令,即从BBC跳跃到BC9,可以把BBC后面的几个字节改为EB 0B,而BBE到BC8之间的直接NOP掉就行
按C重新分析后,f5反汇编看代码就行
`
__int64 __fastcall sub_400BAC(__int64 a1)
{
** int i; // [rsp+Ch] [rbp-Ch]**

** for ( i = 0;((_BYTE)&loc_400AA6 + i) != 0xC3; ++i )
**((_BYTE)&loc_400AA6 + i) ^=(_BYTE)(i % 7 + a1);
** return 1LL;

}
`
可以判断出这一段代码的逻辑就是一个运行时 XOR 解密函数,目标地址就是 loc_400AA6。
该函数的核心就是转为这一句loc_400AA6[i] = loc_400AA6[i] ^ key[i % 7]。意思就是对 loc_400AA6进行一个7字节key的异或。(遇到0xc3时停止异或处理,而0xc3是x86中的ret指令)

去看loc_400AA6

​编辑
从上面的sub_400BAC可以看出是对这一段的加密,但是实际上不止这一段加密。
交叉引用看loc_400AA6的位置
​编辑
发现在sub_400C48也调用了该代码段,粗略的一看这个sub_400C48函数的反汇编,发现有个不合常理的 JUMPOUT(0x400CDALL);所以去看汇编,是一个花指令,修复它。
​编辑
和前面的花指令一模一样的逻辑,patch地址400CCD的前几个为EB 0B ,后面几个nop掉,保留400CDA后面的数据,重新分析再反汇编就行
​编辑
这个sub_400C48的核心逻辑就是下面这个语句
​编辑
用0x41E1B0 处的字节流 XOR 变换 loc_400AA6
所以现在的问题就是sub_400C48和sub_400BAC到底哪个先调用的
不妨去看sub_400C48的交叉引用,发现这个sub_400C48是通过定义一个数组
​编辑,
向上追踪这个funcs_401968调用函数sub_401930,发现是start的sub_400D45函数的参数,所以逻辑很明显了
程序启动

.init_array 执行 sub_400C48

loc_400AA6[i] ^= stream_41E1B0[i]

进入 main/sub_400D45

scanf("%s", v5)

sub_400BAC(v6)

loc_400AA6[i] ^= key[i % 7]

调用 loc_400AA6(v5)
最后的逻辑就是final_code[i] = file_code[i] ^ stream_41E1B0[i] ^ key[i % 7](file_code就是目前的loc_400aa6的内容)
那么我们还有最后一个问题,怎么去找到key

反推key

因为real_code[i] = file_code[i] ^ stream_41E1B0[i] ^ key[i % 7]
所以key[i % 7] = file_code[i] ^ stream_41E1B0[i] ^ real_code[i]
那么我们就需要去想real_code的前7个字的数据
因为 loc_400AA6 解密后是一个正常函数,
而x64 函数开头通常很容易猜,
比如:push rbp mov rbp, rsp sub rsp, xx那么对应的机器码就是55 48 89 E5 48 83 EC ??前7个字节就是55 48 89 E5 48 83 EC
直接带进去,写一个IDApython脚本可以解出来key
​编辑
在IDA里面看到key就是 ** F1@gChe**
​编辑

还原 loc_400AA6

real_code[i] = file_code[i] ^ stream_41E1B0[i] ^ key[i % 7]
写一个IDApython解密脚本完事
​编辑

主逻辑分析loc_400AA6

​编辑
逻辑非常简单了,就是对输入数据a1用sub_4009AE(a1, 32LL, 64LL) 进行处理。然后和v2进行对比校验
​编辑
结果sub_4009AE又是花指令,处理同上
​编辑
外层循环,然后 sub_400A18内层循环
​编辑
后面就是一个解密脚本了。

exp

​编辑

__EOF__

​编辑

  • 本文作者:Aques
  • 本文链接:SMC(静态分析) - Aques - 博客园
  • 关于博主:社会主义朝圣者
  • 版权声明:版权没有,分享自由
  • 声援博主:感谢支持

免责声明:本内容来自平台创作者,博客园系信息发布平台,仅提供信息存储空间服务。

推荐该文 关注博主关注博主 收藏本文 分享微信

​编辑

Aques
粉丝 - 0 关注 - 0

+加关注

0

0

posted @ 2026-04-25 18:27 Aques 阅读(59) 评论(0) 收藏 举报

登录后才能查看或发表评论,立即 登录 或者 逛逛 博客园首页

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

Apache ActiveMQ CVE-2016-3088漏洞复现:从文件上传到RCE的完整攻击链分析

1. 项目概述:一次对经典中间件漏洞的深度剖析在信息安全领域,漏洞复现是安全研究员、渗透测试工程师乃至运维人员必须掌握的核心技能。它不仅是验证漏洞真实性的关键步骤,更是理解漏洞原理、评估风险影响、制定防御策略的基石。今天&#xff…

作者头像 李华
网站建设 2026/6/25 15:07:22

Easy Late-Chunking:RAG中动态语义分块的工程实践

1. 项目概述:为什么“晚分块”正在成为RAG落地的关键破局点最近在给三个不同行业的客户做检索增强生成(RAG)系统优化时,反复被同一个问题卡住:文档切得太细,语义碎片化严重,召回内容支离破碎&am…

作者头像 李华
网站建设 2026/6/25 15:06:59

Kazumi播放器智能预览架构:深度解析缩略图生成机制

Kazumi播放器智能预览架构:深度解析缩略图生成机制 【免费下载链接】Kazumi 基于自定义规则的番剧采集APP,支持流媒体在线观看,支持弹幕,支持实时超分辨率。 项目地址: https://gitcode.com/gh_mirrors/ka/Kazumi Kazumi是…

作者头像 李华
网站建设 2026/6/25 15:06:32

音乐片段二创改编工具

开篇不少短视频二创创作者、独立音乐人想要把手上的音乐片段换曲风做Remix,常会遇到几类难题:一是版权边界模糊,随意上传网络热门歌曲改编容易产生侵权纠纷;二是AI改编后核心旋律丢失,曲风切换生硬割裂,听感…

作者头像 李华
网站建设 2026/6/25 14:58:37

终极指南:免费开源Switch模拟器Ryujinx的完整配置与性能优化方案

终极指南:免费开源Switch模拟器Ryujinx的完整配置与性能优化方案 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 想要在电脑上畅玩Switch游戏却苦于没有合适工具&#xff1…

作者头像 李华