|
手把手教你破解软件-8 O5 O1 q: K Z Y
3 y& ]0 G. G( h. z$ C c) b+ l看到这个帖子还不错,转过来给有兴趣的人看看。
1 W5 e% ?5 [: \: ?0 S
& t4 t' F( {2 {6 rQUOTE:# l! {( {" J7 m' L3 k v: u
声明:此贴适合从来没接触过软件破解或编程的同志学习,,,
4 L" X2 _8 k, h. Z$ Y K/ V# b下面开始今天的破解, k; ?9 S" I8 D2 O) |0 D$ R
我要破解的软件:网络填表终结者 R" o% W. r$ s/ L' X, M
破解需要的软件:侦壳 language.exe 脱壳AspackDie.exe
( I; t l/ g4 e, r0 J7 [ Y 反编译 W32Dasm黄金中文版 16进制编辑器 UltraEdit.rar ' f2 Q5 h2 m" S( g
在破解之前先复习一下基础知识: / s" E0 M' |# @' X: [
一.破解的等级 1 t& O% p1 W' T2 ~
初级,修改程序,用ultraedit修改exe文件,称暴力破解,简称爆破 : U m: @6 ~1 q# F
中级,追出软件的注册码
4 p, r/ ^4 k q( O高级,写出注册机 5 o+ B$ p& c2 s+ J5 P5 D. `
二.用w32dasm破解的一般步骤:
6 I( C1 R: m: f" Y# p1.看软件的说明书,软件注册与不注册在功能上有什么区别,如何注册 0 N( E5 x1 l+ f
2.运行此软件,试着输入你的姓名和任意注册码去注册,有什麽错误 % ^" n5 R# v6 c3 p( f
提示信息,将错误提示信息记下来
5 c) }4 S- G7 o3.侦测有无加壳(第一课).若加壳,脱壳(第二课) . @* c# Q- A: ~9 R- Y
4.pw32dasmgold反汇编
$ }- L( ]! K4 i* X: C! J; y& T5.串式参考中找到错误提示信息或可能是正确的提示信息双击鼠标左键 ' O# y; L# b1 } R4 S- a% ?
6.pw32dasmgold主窗口中分析相应汇编,找出关键跳转和关键call 6 w+ `/ w- c! R
7.绿色光条停在关键跳转,在pw32dasmgold主窗口底部找到关键跳转
; m" z% I0 F. `) ^ W+ q( C的偏移地址(实际修改地址) " V. b/ I0 {& s9 i/ y
8.用ultraedit找到偏移地址(实际修改地址)修改机器码,保存 0 D# R9 C \, O7 B
壳的概念:版权信息需要保护起来,不想让别人随便改动,exe可执行文件压缩,最常见的加壳软件ASPACK ,UPX,PEcompact 0 J$ s2 J0 B2 c0 S! V
脱壳:拿到一个软件,侦测它的壳,然后我们要把它的壳脱去,还原它的 3 t' p, D/ C9 J2 M! X2 R4 x0 x
本来面目.若它没有加壳,就省事不用脱壳了.脱壳软件 p. y( t- e. ]9 `5 P
unaspack,caspr,upx,unpecompact,procdump % p0 J/ }* _- ?
实际修改地址(偏移地址)和行地址(虚拟地址)
3 x3 {: G8 A# [" b* o; K" C( }0 Kpw32dasmgold反汇编出来的代码由三列组成 ! x6 s/ V( Z$ W3 G( H; }4 {7 V
第一列 行地址(虚拟地址)
0 B& \0 L/ t$ [' w; v+ u4 Z4 Q第二列 机器码(最终修改时用ultraedit修改) ' @/ [9 c/ G9 X- w6 v/ m" n
第三列 汇编指令 ; _3 o" Q0 d4 [" }. l- R
第一列 第二列 第三列
5 s& }( m) g7 j3 U8 `' W:0041BE38 2B45F0 sub eax, dword ptr [ebp-10] 9 A! n6 z6 \- f6 O, w! j. U
:0041BE3B 6A42 push 00000042
7 V' O* J5 v* a3 b:0041BE3D 50 push eax
/ o" z/ p# M! E. W1 P, M% B, f8 T:0041BE3E FF75F4 push [ebp-0C] 9 F, A% b) i8 ?; @. }
:0041BE41 FF75F0 push [ebp-10]
- u( f) M& X* P. u( l7 I:0041BE44 FF35A8AB4400 push dword ptr [0044ABA8]
! }* N. q6 ~# G; ]4 E# I两种不同情况的不同修改方法
+ k- K/ d; _. I1.修改为jmp
2 l& J) m: S7 B# C4 g, Hje(jne,jz,jnz) =>jmp相应的机器码EB (出错信息向上找到的第一个跳转)jmp的作用是绝对跳,无条件跳,从而跳过下面的出错信息 6 z+ {" @" T7 L$ J- T H1 Y4 V
2.修改为nop 1 S; S i k6 Z6 G
je(jne,jz,jnz) =>nop相应的机器码90 (正确信息向上找到的第一个跳转) nop的作用是抹掉这个跳转,使这个跳转无效,失去作用,从而使程序顺利来到紧跟其后的正确信息处
7 f1 i; X d, p下面是相关软件的下载 下载时如果提示你输入帐号和密码 申请一个,登陆之后,
0 E5 Q$ N( }$ x$ V2 @2 l然后在回这点下载即可!& M5 D: q; J5 {0 b+ ]
附件:$ J" V5 h: H1 n+ g5 n+ {: n
网络填表终结者.zip% \2 _3 X6 n) n& ^
(498.12 K)
" N& B& B R- x: g) k, H" D+ c该附件被下载次数 2758
9 Q3 l/ g: M& _$ Q2 H" ?' L* s附件: Z5 r% H$ g7 N$ G
luangue+W32Dasm黄金中文版.zip& g( u6 b' ~6 w6 Z
(494.13 K) 7 ?: T7 r, T: h$ r5 z
该附件被下载次数 3235
- Y6 X) p9 n9 X. ^; t脱壳软件:::5 |& Q& \ T$ P1 e0 d: {# s9 }/ T/ ?
附件:
* b, A. \: y$ d" n2 yaSPack 的脱壳利器.zip
8 _! w8 v( o5 i3 E% J(27.8 K)
9 u; s( X( D5 w- J/ `该附件被下载次数 2158
# b7 b) A" ]% G. B- [% hUltraEdit到这里下载
9 ^' o8 v' [1 n7 Khttp://77169.org/Soft/Class25/Class26/200501/17900.html
2 U2 W7 L8 O! W- v) }( c8 P或者
n" k; N+ V8 X1 h- i, c% z. Mhttp://phoebusd.mofile.com/10110
4 ?; ?* |' W" B, u; Q ... 3541D/UltraEdit.rar
; G' B- A! ?( J好了,下面开始我们的破解之旅。。。。。。。。。。
. w; w$ q" J; I1,侦壳:先打开侦壳 language.exe,选择打开----找到要破解的网络填表终结者:FormGhost.exe,点确定,如图1。language.exe便显示出软件的壳是:Aspack,如图2。
, N3 ~# U3 H# n* p[ Last edited by hjyzzz8888 on 2005-2-19 at 11:08 ]
, Q9 ?$ J+ g+ Y
H' ?& T* |; [0 [# p$ @本帖包含图片附件:
" |, q* y) ^ e! Z. r. | 4 R. t* W: b( n7 J/ X6 [- X
2,脱壳:双击脱壳AspackDie.exe,出现一个对话框,选择网络填表终结者:FormGhost.exe,打开。如图3。出现图4框,点确定脱壳完成。在网络填表终结者:FormGhost.exe同目录下生成一个unpacked.exe文件,这就是脱壳后的FormGhost.exe。
! M3 C% j4 E5 v4 E5 V* _本帖包含图片附件:
4 _3 r5 Y, h m) `) p ) R2 h9 m+ ?* P0 ~
本帖包含图片附件: - a2 c" Z) }7 N$ n/ X$ H

4 A4 `! j# f5 ~* b" }8 M3,运行脱壳后的unpacked.exe,点帮助----注册,图9。注册名称,注册码随便添。图10。点注册,提示:“注册码错误”图11,好了记住这5个字。关了它。& X, f- U( G. r
本帖包含图片附件:
( W+ X% M' Z$ e2 M 3 g( K2 z* Y4 O3 E' L9 D" s
本帖包含图片附件:
; V, ?9 j9 S2 d) V
' U+ q" Z4 c: V0 e4 k未完
; k. K' E$ o3 O本帖包含图片附件: : O$ ~: B T5 y
8 k! A& b- Q. D+ m0 a' @
4,开始反汇编:打开 反编译 W32Dasm黄金中文版,选择反汇编----打开脱壳后的unpacked.exe,变开始加载。如图5。图6。
: e" \) c3 c* L2 l8 ]+ W0 E本帖包含图片附件: ; y4 G( Z7 q9 L- R/ W7 K- y
, W5 B2 c1 G+ \' P2 v ^7 r
本帖包含图片附件: ' i6 q& C+ Q( j7 j' t6 B
* w3 `' V! B+ N X
返汇编之后如图7。点击上面的参考----串式参考如图8,
% @1 |3 b# Y; `4 a* E本帖包含图片附件:
9 b1 P* t% \0 [! C* o $ i/ e5 {+ S" j- m8 ?" v1 E. U* r
本帖包含图片附件:
P7 Q$ C2 r# L; ?
2 }* y% a+ I8 s出现这个对话框图12。找到
4 W+ ^8 S2 W) E7 N“注册码错误”,双击它,汇编主程序便来到这里:图13。
( A6 a7 G+ ]$ J' e1 T6 ~本帖包含图片附件: + X& ~1 r/ c( ~, b" a

( D g; v+ D9 v7 a" k% ?' ^ |5 n本帖包含图片附件: 2 J% ~9 M) f X: w

4 N$ a$ P$ r% }0 A(注意:正确注册信息在错误信息之上)关闭串式参考框。看主程序:图14。从注册码错误向上找到第一个跳转(关键跳,除了jmp的其它跳:je,jne,jz,jnz),来到这里图15。
- N' v+ W# O" ^4 K本帖包含图片附件: , r& o# `% m3 q3 t' d+ ?

- _) n- n& h: I本帖包含图片附件:
; t0 K" \" P8 c0 s: |4 Y! t% l5 R ' O# x, J( c, g
(它上面的call叫关键call。),双击关键跳,看软件最下面有一行字:Line:379267 Pg 7586 of 7626 Code [email=Data@004ACB4B@Offset]Data@004ACB4B@Offset[/email] 00ACB4BH in File:unpacked.exe.其中@Offset 00ACB4BH就是偏移地址,记住00ACB4B(后面的h代表16进制,不用管他),图16。' h8 A! X9 x4 |' R+ y: f: G
本帖包含图片附件: 6 P9 i: {. S9 \( n
$ G# j* T! ?1 u% J, J" i/ Y
5,开始修改软件:打开16进制编辑器 UltraEdit.rar,(有点慢)图17。打开脱壳后的unpacked.exe,直接按ctrl+g,出现对话框,输入0xacb4b(即偏移地址,不要前面的000)图18。点确定,来到图19
6 F& i7 q* K0 } U本帖包含图片附件:
; @0 S2 K* e* C+ p
5 H5 Z9 L, p& l0 H- U! k! Z, N9 W# Q本帖包含图片附件:
& a) V* R8 F) O1 I8 O
9 T8 \/ Q' ]1 o本帖包含图片附件: 2 t# [) o+ c( Q6 P

7 G6 v( I0 Z# O3 A4 c前面说过正确注册信息在错误信息之上,所以这里将of85改为of84。图20。(如果正确注册信息在错误信息之下,这里改为eb)。将光标移到5上直接输入数字4即可,其他地方不要动。好了,改好只后左上角的文件---另存为unpacked222.exe
# t; q/ d5 \/ H& E/ M[ Last edited by hjyzzz8888 on 2005-2-19 at 11:05 ]
; e8 C$ _' C1 \0 G3 `7 K/ V本帖包含图片附件: 4 [3 y# J8 _ c( s9 ^! `( m F
2 j8 d0 H6 x3 A! E8 u/ y3 @
6,关闭所以软件,运行另存的unpacked222.exe,点帮助---注册,注册名称,注册码随便添,点确定,提示注册完成。图21。回到软件界面看看,帮助,注册一项已经变为灰色了,图22
( z& s' Z( H; r4 C0 v8 |( L! M7,破解全部完成。& ^: `2 ~, Q6 z2 m* U% }+ |4 a
本帖包含图片附件: / |$ O l9 |! C: }' Y% P2 V

0 N, j6 l& P5 S- p5 b2 W本帖包含图片附件: % N2 T# N, N: [! b$ Y$ Q' T
- |+ R6 a6 z6 z' _1 M
|
|