破解时常用的汇编命令

概述

基本上多数破解的思路是一样的,就是将本来判断为true的时候干的事情改为逻辑值为false就做,因此常常需要替换一些汇编命令:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
cmp a,b 比较a与b
mov a,b 把b的值送给a
ret 返回主程序
nop 无作用,英文“no operation”的简写,意思是“do nothing”(机器码90)
call 调用子程序
je 或jz 若相等则跳(机器码74 或0F84)
jne或jnz 若不相等则跳(机器码750F85)
jmp 无条件跳(机器码EB)
jb 若小于则跳
ja 若大于则跳
jg 若大于则跳
jge 若大于等于则跳
jl 若小于则跳
jle 若小于等于则跳
pop 出栈
push 压栈

常见修改(机器码)

1
2
74=>75 74=>90 74=>EB
75=>74 75=>90 75=>EB

jnz -> nop

1
75->90(相应的机器码修改)

jnz -> jmp

1
75 -> EB(相应的机器码修改)

jnz -> jz

1
2
75->74 (正常) 
0F 85 -> 0F 84(特殊情况下,有时,相应的机器码修改)

两种不同情况的不同修改方法

修改为jmp

je(jne,jz,jnz) =>jmp相应的机器码EB (出错信息向上找到的第一个跳转)jmp的作用是绝对跳,无条件跳,从而跳过下面的出错信息。

出错信息,例如:注册码不对,sorry,未注册版不能…,“Function Not Avaible in Demo” 或 “Command Not Avaible” 或 "Can’t save in Shareware/Demo"等 (我们希望把它跳过,不让它出现)。

修改为nop

je(jne,jz,jnz) =>nop相应的机器码90 (正确信息向上找到的第一个跳转) nop的作用是抹掉这个跳转,使这个跳转无效,失去作用,从而使程序顺利来到紧跟其后的正确信息处。

正确信息,例如:注册成功,谢谢您的支持等(我们希望它不被跳过,让它出现,程序一定要顺利来到这里)。

出错信息(我们希望不要跳到这里,不让它出现)它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据。

例如使用windbg时候:

1
2
0:000> dd 0c366b28 l4
0c366b28  7e830c74 940f0108 c0b60fc0 01b805eb

执行ed 0c366b28 7e830c75

修改为:

1
2
0:000> dd 0c366b28 l4
0c366b28  7e830c75 940f0108 c0b60fc0 01b805eb



本文链接: http://home.meng.uno/articles/36aa5187/ 欢迎转载!

© 2018.02.08 - 2020.10.14 Mengmeng Kuang  保留所有权利!

UV : | PV :

:D 获取中...

Creative Commons License