freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

如何使用SilentMoonwalk实现完整动态调用栈欺骗
2023-06-05 15:47:33
所属地 广西

关于SilentMoonwalk

SilentMoonwalk是一个针对完整动态调用栈欺骗技术的PoC实现,该工具所实现的技术可以帮助广大研究人员从调用栈中移除原始的调用者信息,并使用ROP对控制流执行去同步化解绑操作。

工具运行机制

该工具使用了去同步栈来完全隐藏原始调用栈,同时从中删除了EXE镜像库。随后,该工具还会调用ROP工具来恢复原始堆栈。在代码中,这个过程会在一个循环中重复10次,以证明其稳定性。

工具下载

广大研究人员可以使用下列命令将该项目源码克隆至本地:

git clone https://github.com/klezVirus/SilentMoonwalk.git

工具构建

接下来,使用Visual Studio加载项目并构建项目代码即可。

如需构建PoC项目代码,请确保检查以下几个条件:

1、禁用GS(/GS-);

2、禁用代码优化(/Od);

3、禁用整个程序优化(移除/GL);

4、禁用大小和速度首选项(移除/Os、/Ot);

5、启用intrinsic(/Oi);

工具使用

在代码库中,我们可以找到一些关于运行时函数审计的功能代码,可以帮助广大研究人员分析运行时函数条目:

UnwindInspector.exe -h

 

 Unwind Inspector v0.100000

 

 Mandatory args:

   -m <module>: Target DLL

   -f <function>: Target Function

   -a <function-address>: Target Function Address

样例输出:

UnwindInspector.exe -m kernelbase -a 0x7FFAAE12182C

[*] Using function address 0x7ffaae12182c

 

  Runtime Function (0x000000000000182C, 0x00000000000019ED)

  Unwind Info Address: 0x000000000026AA88

    Version: 0

    Ver + Flags: 00000000

    SizeOfProlog: 0x1f

    CountOfCodes: 0xc

    FrameRegister: 0x0

    FrameOffset: 0x0

    UnwindCodes:

    [00h] Frame: 0x741f - 0x04  - UWOP_SAVE_NONVOL     (RDI, 0x001f)

    [01h] Frame: 0x0015 - 0x00  - UWOP_PUSH_NONVOL     (RAX, 0x0015)

    [02h] Frame: 0x641f - 0x04  - UWOP_SAVE_NONVOL     (RSI, 0x001f)

    [03h] Frame: 0x0014 - 0x00  - UWOP_PUSH_NONVOL     (RAX, 0x0014)

    [04h] Frame: 0x341f - 0x04  - UWOP_SAVE_NONVOL     (RBX, 0x001f)

    [05h] Frame: 0x0012 - 0x00  - UWOP_PUSH_NONVOL     (RAX, 0x0012)

    [06h] Frame: 0xb21f - 0x02  - UWOP_ALLOC_SMALL     (R11, 0x001f)

    [07h] Frame: 0xf018 - 0x00  - UWOP_PUSH_NONVOL     (R15, 0x0018)

    [08h] Frame: 0xe016 - 0x00  - UWOP_PUSH_NONVOL     (R14, 0x0016)

    [09h] Frame: 0xd014 - 0x00  - UWOP_PUSH_NONVOL     (R13, 0x0014)

    [0ah] Frame: 0xc012 - 0x00  - UWOP_PUSH_NONVOL     (R12, 0x0012)

    [0bh] Frame: 0x5010 - 0x00  - UWOP_PUSH_NONVOL     (RBP, 0x0010)

工具运行截图


许可证协议

本项目的开发与发布遵循BSD-3-Clause开源许可证协议。

项目地址

SilentMoonwalk:【GitHub传送门

参考资料

https://www.unknowncheats.me/forum/anti-cheat-bypass/268039-x64-return-address-spoofing-source-explanation.html

https://github.com/waldo-irc/YouMayPasser

https://github.com/WithSecureLabs/CallStackSpoofer/

https://github.com/Kudaes/Unwinder/

# 欺骗技术 # 堆栈保护
本文为 独立观点,未经允许不得转载,授权请联系FreeBuf客服小蜜蜂,微信:freebee2022
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录