吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5626|回复: 12
收起左侧

[转贴] 反-反汇编patch学习(三)

  [复制链接]
默小白 发表于 2019-5-2 10:08

转自:https://xz.aliyun.com/t/4972

前两篇文章介绍了两种加花的方法

  1. call $+5等技巧获得当前EIP,并跳转到指令中间
  2. 子函数劫持父函数流程

本文介绍一些更复杂的jxx,各种迷惑反汇编引擎的花式patch技巧

失败的尝试

先吐槽一下,jz&jnz跳转到同样的地址,形如

img

这个技巧根本就对抗不了IDA的反汇编引擎,线性扫描算法递归下降算法已经有所了解,但是各种资料都会提到这个做法,我这里尝试了根本就没用,不知道是不是我的打开方式不对

除非jz&jnz又跳转到之前提过的EB花指令上,但这也没有什么新意

jmp到jmp+1

首先我们在一堆noppatch EB FF,效果如下

img

jmp的指令位于地址0x140001018,而跳转到的指令是0x140001019,跳转到了jmp指令中间

接下来我们利用FF做一些手脚,比如改成序列EB FF C0

注意到FF C0表示的是inc eax

再在之后添加FF C8,也就是dec eax

IDA中如图

img

这里我手动把0xEB看作了数据,但实际上这样会导致IDA的栈平衡分析失败

动态调试

这样的实际跳转流程是:

  1. jmp => jmp+1

img

  1. inc eax
  2. dec eax

img

可以看到,动态调试时会暴露花指令所有的细节,但是想让IDA F5就不像之前按一下d视作数据一样了

如果把地址jmp+1看作代码,那么一定会破坏原来的jmp指令,似乎陷入了尴尬的境地...

img

不过本程序因为只是单一技巧的示例,我们人工分析后发现这三条指令其实什么也没干

把原先的EB FF C0直接nop三连即可

更复杂的布局

  1. mov ax,05EBH,再XOR eax,eax,一般来说不会有什么影响,只是清零了EAX

    其中有一个EB,是我们布局的关键

  2. patch 74 FA,相当于jz jz-6,跳转到刚才的EB上,如图

img

0x140001005+2看作代码

img

和刚才一样,这里简单的按d识别数据会破坏jmp指令

  1. 0x14000100D的指令再改成迷惑反汇编器的EB

动态调试

patch好之后,用IDA重新打开,画风很诡异

img

在这里下断点后

img

跳转到0x7FF6466B1007

img

再按一下c,识别成代码,跳转到原执行流EB 05也就是跳转到下一条指令地址 + 5的地址

img

去花

因为没有加反调试,动调不难发现花指令的执行逻辑,直接nopN连即可

IDAPythonpatch代码如下

def NopBytes(start, length):   
    for i in range(0, length):     
        PatchByte(start + i, 0x90)   
    MakeCode(start)
NopBytes(addr, n)

补充

一般花指令都是有规律可以找的,找到以后nop即可

写到这里,在想有没有简单nop不能轻松处理的,比如本文提到的会破坏原先的jmp

如果程序中本来就有合适的jmp系列指令,比如EB xxx,跳转到原程序流程上,再根据这段偏移构造我们自己的代码块,可能会稍微复杂一些,因为不能直接把必要的原程序直接nop,不过应该也差别不大

免费评分

参与人数 8吾爱币 +6 热心值 +6 收起 理由
hcz19960414 + 1 + 1 谢谢@Thanks!
l1679668663 + 1 用心讨论,共获提升!
zhongjiezhe + 1 + 1 谢谢@Thanks!
icode2019 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
nj001 + 1 + 1 热心回复!
hahahunqiu + 1 热心回复!
snk8890 + 1 谢谢@Thanks!
xiangxiong + 1 + 1 热心回复!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

c66d88 发表于 2019-5-3 14:11
楼主,你的教程都到3了,你能不能把前1和2的教程链接也贴在3的下面,这样就方面我们直接打开查看了,不然的话,都找不到你前两教程
hahahunqiu 发表于 2019-5-2 17:32
zziapyk123 发表于 2019-5-2 19:41
zhongjiezhe 发表于 2019-5-3 16:38
有心得啊,真好
l1679668663 发表于 2019-5-3 18:51
学习学习   感谢分享
17355849767 发表于 2019-5-4 10:50
这个比较适合新手学习下,很有价值
王宇 发表于 2019-5-4 18:59
感谢分享,支持一下
rickw 发表于 2019-5-4 20:02
谢谢分享。
gujun666 发表于 2019-5-4 20:32
感谢分享!!!
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-1 11:58

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表