问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
使用vmpdump对未完全保护的vmp样本进行处理——以Night Sky为例
技巧性文章,便于处理一些非强加密vmp的样本,便于后续继续分析
查壳可以看到是vmp的壳,根据网上其他的文章可以确定是3.x版本貌似是3.5。根据其他文章介绍虽然加密,但是貌似只对IAT进行了vm,所以可以用该工具模拟出IAT。 data:image/s3,"s3://crabby-images/555eb/555eb3282747fff660a200d195d0f6eaf9860a97" alt="image.png" 使用沙箱定位到代码段调用的API,这里选择MoveFileEx。因为当勒索软件涉及到对文件操作时证明被vmp保护的代码段已经被解密加载到.txt节中,此时是比较好的解密点。 [Automated Malware Analysis Report for update.exe - Generated by Joe Sandbox](https://www.joesandbox.com/analysis/548777/0/html) data:image/s3,"s3://crabby-images/08038/080384b4fb3ff7f2aea7ed132d127b533f41bf63" alt="" 运行到OEP后选择MoveFileExW API data:image/s3,"s3://crabby-images/8bf94/8bf94d9f65b6ba9d25feededc2d081309b350d8a" alt="" 来到API函数入口设置硬件端点,硬件断点是为了防止软件断点会影响壳的执行流程 data:image/s3,"s3://crabby-images/173d2/173d27a6c8582a00b5267239d703125aa9580d46" alt="" 执行后中断在我们设置的硬件端点下。 data:image/s3,"s3://crabby-images/1b445/1b445576fcda391898a73ced613807ce525bcc1b" alt="" 返回到用户态代码,可以看到call xxxxx int3。这是被vmp3.x保护的导入函数虚拟化特征,该函数会进行一系列运算,最后解析出API并调用 data:image/s3,"s3://crabby-images/6ce7a/6ce7aa9c0fe1f8718ca9dc2eb0c3b739278496fa" alt="" 根据其他报告提示该样本的OPE特征为微软VS特征。接下来随意用VS编译一个helloword的64位程序并用IDA观察入口特征 data:image/s3,"s3://crabby-images/d0f01/d0f015c70963fb32c007bb01c88ff3157b9bd2c2" alt="" 首先找到export选项卡,来到OEP处 data:image/s3,"s3://crabby-images/4baee/4baee5a9af64059b49dfe4e4836f879c02652d7c" alt="" 在VS编译器中会生成一段安全cookie的hash,该hash值不变可以作为特征串查找OEP附近的代码 data:image/s3,"s3://crabby-images/350ea/350ea6d482a4503f394ef83d9f218cc55d3ed1a0" alt="" 回到中断的内存中,点击内存布局中查看 data:image/s3,"s3://crabby-images/16489/16489d48750567a4782948d0b5f6354d46dba08a" alt="" 可以看到已经解密代码到.text节中,而不是存在下面的附加节中。 data:image/s3,"s3://crabby-images/e595d/e595de9529533bc5a0c2d355328430db7bbb25d4" alt="" 我们只需要在.text节中搜索cookie特征值即可,邮件内存窗口中转到 data:image/s3,"s3://crabby-images/a6bb8/a6bb85b0c44f456e454f7674e9bdc061caaa2e50" alt="" 右键-->特征搜索 data:image/s3,"s3://crabby-images/b1929/b192974febbf88d7b2dec9bf8d7e44fe5c036792" alt="" 搜索后只有一处特征值,该值就是VS编译器OEP附近的设置安全cookie处。如果有多个该技巧可能并不适用 data:image/s3,"s3://crabby-images/17c8b/17c8bc3120bd3a45bf54e9360d272471a3a8ae70" alt="" 对比后为VS编译器设置安全Cookie的函数 data:image/s3,"s3://crabby-images/95089/95089f53ea6f158497902a680c5504e6a0a1064b" alt="" 删除其他断点,在安全cookie函数入口处设置硬件断点 data:image/s3,"s3://crabby-images/1d2b4/1d2b45ede64db81ea2466009db481a12d7802b4c" alt="" 重新运行程序中断在函数序言中,此时与真正的OEP很接近了 data:image/s3,"s3://crabby-images/afb34/afb34757e8a1c92dd01b465e40b54f5031e16842" alt="" 查看调用栈跟随到调用地址 data:image/s3,"s3://crabby-images/b95d2/b95d2e4716d39725076efda7591bbb6fa8dd5195" alt="" 可以看到来到一块位置代码内容中 data:image/s3,"s3://crabby-images/91f26/91f2627c89874cee77370c84edd2ee90a8be43c7" alt="" 内存布局转到,可以发现已经不在.text中,证明OEP已经被vmp保护了。所以我们不能直接dump出干净的OEP,可能需要后续手动修复 data:image/s3,"s3://crabby-images/c27a7/c27a7c4d3b77b49d651f1a785ad32d7ac4d80c7e" alt="" 使用vmpdump对解密后的程序进行dump `VMPDump.exe 8852 "" -disable-reloc` 注意,dump进程名不能过长,否则会失败 data:image/s3,"s3://crabby-images/e9bce/e9bceb18a26897cf81fd534ef4182e5b8bb59ae9" alt="image.png" 接下来将dump程序拖入IDA,可以看到此时入口点仍为VMP壳节代码中,需要我们自己手动搜索特征修复 data:image/s3,"s3://crabby-images/c0769/c0769e36aa657de31ea39d5a722d5d75c0e172b3" alt="" 搜索cookie的hash值 data:image/s3,"s3://crabby-images/1bcba/1bcba3c6373beecec7c23de2459f8e8a506b01f2" alt="" 选择text代码节,这是我们dump出来的解密代码部分 data:image/s3,"s3://crabby-images/17f8c/17f8cddab6b570a8ed7fc5ed489c69b0ccbd2a99" alt="" 将函数名和函数类型改为初始化cookie data:image/s3,"s3://crabby-images/cd134/cd134958d30ce12b98ce9185bd152916818134a7" alt="" 同理,我们搜索\_\_scrt\_common\_main\_seh函数的特征,由于该函数没有常量,我们只能取函数部分字节码做特征搜索 data:image/s3,"s3://crabby-images/37ede/37edec3b6752fe85afc18db47f087447315c313d" alt="" 同理需要继续向下定位到main函数 data:image/s3,"s3://crabby-images/ad5cb/ad5cbef09b5d485a012b3e4737f1463bac5cbd77" alt="" 在重命名完成后,需要我们手动修改入口点的OEP。对比正常的VS编译程序修改入口点代码 data:image/s3,"s3://crabby-images/1e1c5/1e1c5de539ebbff23abb66730479a31a2198c0f0" alt="" 修改后如下 data:image/s3,"s3://crabby-images/428bc/428bc92ae6fe2655e84889f7c0a578a04452d355" alt="" 接下来需要计算跳转的相对偏移,call指令的下一条指令地址-安全cookie初始化函数的地址。又因为vmp壳的代码节在.text的下方,所以相对跳转的值应该取负值,这样就可以从.2fU1节向上跳转到.text节中 data:image/s3,"s3://crabby-images/a3ce7/a3ce70ff4aae444859d62e02513d2075363fe78c" alt="" 计算出该值还需要加1字节 data:image/s3,"s3://crabby-images/5061d/5061d64cceee8aed06e5428abcacd7f4926b50f4" alt="" 修改相对跳转, data:image/s3,"s3://crabby-images/c6b9c/c6b9c745053ad83c39434d7112ff4d3c07a77459" alt="" 回到入口点可以发现修改成功 data:image/s3,"s3://crabby-images/1a97a/1a97a5de127d687c18cb554bead62e55662c189f" alt="" 同理可以修改main\_seh data:image/s3,"s3://crabby-images/9e90e/9e90ecbf1e021ed04ed960d4f6da33be9392d767" alt="" data:image/s3,"s3://crabby-images/6df32/6df3249c750ce763b509891aa05f28434a4d3590" alt="" 最后patch程序即可 data:image/s3,"s3://crabby-images/3ea8d/3ea8dd8b6c5ad51082571e57470a31114c88f0e6" alt="image.png" 重新调试即可 data:image/s3,"s3://crabby-images/46dba/46dba83cddb559154aac14063e93946dfc72dee3" alt="image.png" 脱壳后的main函数 data:image/s3,"s3://crabby-images/a047c/a047c6de4e6cf0cfd1ec6d5f3ea084ca2f6bf539" alt=""
发表于 2025-01-07 10:00:02
阅读 ( 734 )
分类:
二进制
0 推荐
收藏
0 条评论
请先
登录
后评论
马喽打金服
3 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!