upx3.94 x64加壳后dump内存并修复过程记录

最近因为公司的一些事情,要面临重新找工作,希望可以找找逆向相关的工作,但是我以前也只做过反编译的工作,破解之类的工作中完全没有接触过,就想学习学习脱壳。就先从upx下手。

upx壳是种压缩壳,是将原有程序image进行压缩,在生成的可执行程序的entrypoint处代码进行解压,在解压完全后在跳转到原本程序的entrypoint,即OEP(orginal_entry_point)。

要想获取不压缩的原始代码,只需要在解压后将内存拷贝出来,做成可执行程序,oep就是一个比较好的时间点,另外为了让我们生成的可执行程序能从正确的代码开始执行,获得oep的大致位置也是必须的

##找OEP

我看了看段带壳程序ep到oep之间的代码,只看出是将upx1节中的数据进行一些处理后存入upx0节中,实际加密解密算法并有也没打算一定要搞清。上面说ep到oep之间代码,EntryPoint在pe头里有记录,x64dbg之类的调试器运行可执行程序时第一次会停在ntdll的代码中,第二次停在ep处。OEP这个upx有方便的方法可以找到。看网上说upx在ep处pushad,解压后popad,然后一个大跳转到oep,所以搜索popad就好了。但是x64下没有pushad/popad指令了,但是ep处代码是四个push指令 输入图片说明

那我就去找与之匹配的pop指令,果然

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值