用Pin对二进制文件自动脱壳

Intel Pin

Intel Pin在可执行二进制代码中插入一些探测函数,用于观察、记录、分析宿主代码执行过程中的一些与计算机体系结构相关的特性,如访存指令,寄存器内容,寄存器地址等,通过Pin提供的API可以编写各种分析函数,这样程序运行完以后,统计和分析结果也同时产生,分析数据处理结果,获取有价值的学术成果和科研结论,可以将其应用于整个计算机体系结构的技术革新和进步。

壳的作用

加壳的程序需要阻止外部程序或软件对加壳程序本身的反汇编分析或者动态分析,以达到保护壳内原始程序以及软件不被外部程序破坏,保证原始程序正常运行。
但是某些病毒木马程序也利用加壳技术来躲避杀毒软件的查杀。

本篇文章使用upx3.91对linux的/bin/ls程序进行加壳,并使用Pin完成动态脱壳。

实现原理

在这里插入图片描述
对于上述可执行文件加壳器的步骤描述如下:

1)首先使用插桩实现对可执行文件运行过程中全部内存写入指令的跟踪,记录内存访问类型(写入或执行)和写入字节的值。稍后在脱壳过程中,当脱壳器将内存转储到磁盘时,需要合并相邻的内存字节,因此需要记录内存块的基地址、大小及访问权限。
2)使用插桩实现对间接分支指令和call调用指令的跟踪,如果跳转指令的目标地址位于一次性写入的内存区域中,那么它很可能是向OEP的跳转。通过跟踪来检查跳转指令分支的目标地址是否为先前可写的内存区域。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

摔不死的笨鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值