Sie sind auf Seite 1von 549

pum;rdwfquf

Cracker .._' ._... _..- cracking reverse engineering, .-.-_.


-. .- . ...... .. ...-- _ . _ . - ._ ._.. ._ Reverse engineering
-... -. _.. ... cracking _. ._ - -. _ ._ - - . ...
._-. ..... . ...._..._ ._-. _..- cracking - .- . ..... ... .
. . - ... ._ - ...- .. ......_ ._..._
Cracking _.._ -.-.-.- .-..._. .... -.._-..... __
- .- -. ....._ . -- _.._ - -. . . _ .._-. _.. ._ Cracking ._ -.
....._.. .-.-_...__ -......_. ..-.-..- .._.... ...
... _._.._.._-.-.._-.. -.. . - ... - -.-... ...
-.. ..-..._-_.._-.-.._-.. pirate version .......- ........._. .
-- . . . _ .._-. -. ._-. . cracking _. - . .. _ .. _-._
.. - ..-- _-_ ._ . ... . ... _ - .._-._ - .- .._
- -. . .. . .-. .-. ......._ _ . ....-..... . . . _-_
....._-._ - .- _. .._ -....-.-- -... developer, ... -
- .- ... .... ...._-. _ ..-. . ........ -...... ...... ...._-. _ ..-. .
malicious - ... ....._ . .. ...._-. _ ..-. . ...- - - ... -. ..... . _-_
- . . ...._ ..- _..-... -.-.-.- .....-.......-
. .. .. _ ._.. ._ Warez ......_. -.-.-... ....-. serial - share
....
.-. cracking _. - -.. ........ _ . ._-. cracking
. - .- ... .. ...- .. - - - _.. .. .- _.. .. . . . _ . .. . ...
_ . cracking _. ._ - _. . . -. _ - ._ ...-_ . .-. .
. -. _.. ... - .- . . ._ cracking _.- .--.. .-.-..._
- - .-. - . _ . ............. patch . ...- .-. ..-. .. ..-- ...
....... ..._.. ....._ _..- ...-.-- .-. .._....._- ._-_
._
_..-_.. - _-..-. - _. _-_ _ .. _. ._-_
. .... . . - - ..........-... developer ..._.. ._ .. - ... _
..._ . ....... . . . --.- - .. .- ... ... . ... .._ .- ....
-. ... . ...- . . .. . ... _.. ._ __ - ._.. ... . ...._-. .- _.. -
-..-.. ........_.._._-- .--.....- .._-..-- ._-_
._ __ - ._.. ... . .... - .- _ . ._ ._ . crack _._.-- _..-
......_ _.. .. ......._ _.. .. ... . ... crack _ . .._ .._.. ._ , _.. -
.-_._....... .-.... .......-._ ...-.... . - .- .- ..._.. ._
Cracking - .._._. -..-... -... -.- ._-_._ ...-.
_. malware _.._.. ._ .. . -. ..._ -... -.-._. ....
...- malicious -..._.._._. ..... ...- -. - ._ Cracking _.-
--._..-.. -... - - ..-..-. - - . .. _ . ... . ....
malicious -...-...._._. _.....- .. .__ ._......_ -._..-.
.. -... error -- ._ _.. _.. ._ _- .... ...... . ...- bug ...-
. -- ... .- .._.-- bug ...- exception ... ._ ._. _.. .. offset -.__..
.. cracking _. - . -- ._. .. ._ -- .....- -. . . . . ...-- ......
... . -. - ..... - .._ ....... . -. - crack _._. .... .....
....._.- _-_._._.. ._ __ ..._. . . -. ....._ .. . ._ - .-- ...
cracking - -_...._ ..--.-.. crack _...- .._---.....-
. . ... . - _... ... crack .... -....._._..._
_..- ._._-..._.. cracking -..-- ...-.._ -.-....-..
. - .- _ C ., Assembly - -. .- _ . . -_ ..- - _.. -. -....-.. -.
- -. .- . . -- ._..- _ ._.. ._ C . Assembly -....-..-- _..- -.
-_ . _ . . ._..._ , _. . _ .. . C . Assembly - ._ low-level -. -...
.-....._.. _ . _..-....-...... . high-level ..._.. _-__.. ._
. _ _- _ ._ . . .- ... ...- _-__-..... _-_ Acrobat
reader . .-...- Microsoft Paint . - .- _ . _-_ _.. _. ........- .-.- Acrobat
reader view ., -... ..._. .-_..._ .... ...._ _-_
. ._ . ........._ _- .... . ._ _.. - .- Acrobat reader Version
._ ... 8.0 _..._
_..- -..- Version _. -. .._. . . .._ Version _. .._ . .
. ..... . _ ..._ . .. ._._ . - - ... ._ ...._ . . ..._...._
..._. Version 1.0 - ., ... ... _ . . Version 2.2 - ., .
- . ._ _.. ._ . - _ . .. ._._ . - - ... _....._-- .
- __ _ _ .- .. ._ ... Version 1.2 - ., Packer Protector, ...'
._ Fish Packer ._-..- .._..........._ -.-. cracking -.- ..
_..._.. ...-._.._. cracking - . . . Cracker .._' .....- ......_
- - ... . - ._ version ...- .._.-......_
.. - . cracker ...- _... _-_._ --. -._ ... ...
....- . - .- ... -. ..- .._ .. .- ... .,- - .-
_- .. .- .,- - _-. .. ..- .,- - .._ .. .- ..,
-- .-..--.. .,- -.. .- .,- ..._...
.,- - .- - . - --. cracking . - .- _ ._ ..-
...__..._ ..- -....- . . . .- . . .. _ _.. ._ .. - . cracker
...-- ._.... .-.... _........... Lena151 ........ Reversing Tutorials
(1-40) _..._ _........ -. ... .-..-........_ ..-. cracker ...
-- cracking ._ . .... . ._
_.. ....._ .. - .- _ _ .. ._._ ...-.- .......-
- .-. ........_ - .._ _.. ..... - - - - -..._ ._ . ...
Lena151 . ......- -..._ .- .. ......- ._......._ -.._-.....
Lena151 ._ .....-.. _......._-._..._ - . - - - -..._ ...- . ...
.._ . - ...._-. . .. .. -..._ ._ . ._ .... ..._-.._.
... -.-.-....-..- Google . -. -..._ ....., -..._ - ._ ....- .
-..._ _ . . .. - ... ... .- -..._ _ . . .. -.-.-.-
......._ ._.. ._ .. ._ C -....-.. Olly Debug Script, ._-. ..
......-.-... --....- .- ....-.._.-- __.-.-..... ..
..-........-_. ....-.--- ... _..._ ._..... _.. ._ . .
...._-. _. ............... ._ ._ .. ..-. .- . - .. - .-...._ . . ._-. . _..
. ._._-.. ._
...... .....-.- cracking . - .- .- . .. . -
.-...._.._ _..._ Beginner-to-Beginner Guide ... _..._-... .......-
- .._ - .. ._-. .
_...-..... uPPP patch . frame ...- ........ ZMA Armadillo Developer
.... -.-.' . ARTeam . Nilrem . -.-.' - -..._ .. ... wannar . Myanmar
Cracking Team (http://www.mmcrackingteam.org) . - - . ... - _ .....- ..- ...
mrzingyi007 .--.--_... thandana . Myanmar Cracking Team .-.... ...-
. .-..-._-.. _... ._._-.. ._
s_
rhythm
(Myanmar Cracking Team)

_.._. -...-..._..... -_-._..,...--.. -.-.._



rmwdum
p mr su fESm
p u m; r dw fq u f 3
t c e f; ( 1 ) Cracker r sm; o dx m; o i fha o mt c su fr sm; 7
t c e f; ( 2) t a jc c HC b mo mp u m; 1 0
t c e f; ( 3 ) t a jc c HAssembly b mo mp u m; 28
t c e f; ( 4 ) a q mhz f0 Jv f protection 5 2
t c e f; ( 5 ) Cracker w p fOD; t w Gu fv dkt y fa o m tool r sm; 5 9
t c e f; ( 6 ) Olly Debugger r dw fq u f 6 5
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f 7 3
t c e f; ( 8 ) PE Header 8 8
t c e f; ( 9 ) Teleport Pro 1.61 y &dk* &r fESi fhy x r q Hk; t Mu dr f crack v ky fjc i f; 1 22
t c e f; ( 1 0 ) Patch v ky fjc i f; ( Beginner/Intermediate/Advanced) 1 3 6
t c e f; ( 1 1 ) uPPP jz i fhpatch z dki f z e fw D; jc i f; 1 5 7
t c e f; ( 1 2) Cracker r sm; o w dx m; o i fha o m Windows API r sm; 1 6 2
t c e f; ( 1 3 ) y &dk* &r f\ resource r sm; u dkt o Hk; jy K crack v ky fjc i f; 1 7 4
t c e f; ( 1 4 ) Packer ( Protector) r sm; 1 8 2
t c e f; ( 1 5 ) IAT ESi fhAPI Redirection 20 7
t c e f; ( 1 6 ) Visual Basic jz i fha &; o m; x m; a o m y &dk* &r fr sm; u dkcrack v ky fjc i f; 229
t c e f; ( 1 7 ) Delphi jz i fha &; o m; x m; a o m y &dk* &r fr sm; u dkcrack v ky fjc i f; 25 8
t c e f; ( 1 8 ) Java jz i fha &; o m; x m; a o m y &dk* &r fr sm; u dkcrack v ky fjc i f; 26 6
t c e f; ( 1 9 ) Visual Dot.net jz i fha &; o m; x m; a o m y &dk* &r fr sm; u dkcrack v ky fjc i f; 28 2
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f; 3 1 1
t c e f; ( 21 ) Loader o Dt kd&DESi fhpatch z dki fz e fw D; jc i f; 3 1 7
t c e f; ( 22) Crypto u k' fr sm; u dka v hv mjc i f; 3 25
t c e f; ( 23 ) Polymorphic u k' fr sm; u dka v hv mjc i f; 3 4 8
t c e f; ( 24 ) Registration number u dkt Ge fv dki f; w Gi f p p fa q ; jc i f; t m; z , f&Sm; jc i f; 3 6 5
t c e f; ( 25 ) Themida t m; a v hv mjc i f; 3 8 8
t c e f; ( 26 ) CRC q dko n fr Sm 4 1 5
t c e f; ( 27 ) Thread r sm; p Gm&Sda o m application r sm; u dkcrack v ky fjc i f; 4 1 6
t c e f; ( 28 ) CD-ROM protection t a Mu mi f; o da u mi f; p &mr sm; 4 1 7
t c e f; ( 29 ) Flashy x &dk* se fESi fhWindows Registry 4 1 8
t c e f; ( 3 0 ) Olly Debug Script 4 25
t c e f; ( 3 1 ) Wrapper t o Hk; jy Kx m; o n fha q mhz f0 Jv fr sm; u dkcrack v ky fjc i f; 4 3 7
t c e f; ( 3 2) Armadillo t m; a v hv mjc i f; 4 3 8
t c e f; ( 3 3 ) POPCAP? BigFish? TryMedia? Oberon * dr f; r sm; u dkcrack v ky fjc i f; 4 9 4
t c e f; ( 3 4 ) Virtualization r dw fq u f 4 9 5
t c e f; ( 3 5 ) WinLicense z dki fr sm; u dkcrack v ky fjc i f; 4 9 6
t c e f; ( 3 6 ) Kernel mode w Gi f t v ky fv ky fo n fhy &dk* &r fr sm; u dkcrack v ky fjc i f; 4 9 7


t c e f; ( 3 7 ) Serial fisher u dkb , fv dkz e fw D; r v J 4 9 8
t c e f; ( 3 8 ) u dk, fy dki f loader a &; Mu &a t mi f 4 9 9
t c e f; ( 3 9 ) Obfuscation ESi fhDeobfuscation 5 0 0
t c e f; ( 4 0 ) Inline patch v ky fjc i f; 5 0 1
t c e f; ( 4 1 ) t q i fhjr i fhkeygen r sm; u dkz e fw D; jc i f; 5 0 6
t c e f; ( 4 2) 64-bit y &dk* &r fr sm; u dkcrack v ky fjc i f; 5 0 7
t c e f; ( 4 3 ) Developer r sm; \ anti-cracking v QdKU0 Su fc su f 5 0 8
t c e f; ( 4 4 ) Anti- unpacking e n f; v r f; r sm; 5 0 9
t c e f; ( 4 5 ) Armadillo developer r sm; ESi fht i fw mAsL; 5 27
t c e f; ( 4 6 ) ARTeam w n fa x mi fo l Nilrem ESi fht i fw mAsL; 5 3 2
Cracking q dki f&ma 0 g[ m&r sm; 5 3 5
Cracking q dki f&m t i fw me u f 0 u fb fq dku fr sm; 5 4 5
References 5 4 8

r Sw fc su f/ / t jy ma &mi fjz i hfjy x m; a o mt c e f; r sm; a &; o m; r jy D; a o ; y g/
., Cracker ... . ... ... - ...



tcef;(1) - Cracker rsm; odxm;oifhaom tcsufrsm;
Cracker . ._ ' .. . . - .-. . .. . ._ -.- cracker ._ ..-
-.-.--. -....- -.._-. crack -- -.-.- ._--..- ....
.- _.. -. Cracker .. .. -. ...- .-. .- -.-. -. .- -. .
....... protection ......---..-.-.- ..-._.._. -.-- -....
.-.- ......._.--._..-. --...-. ..__-. crack _--._.._. --
. ..-. ... . .. .- - .. .. crack _--._.. -. ... . _.- ._. -.-.-.
-.-.- crack -. crack ..-_.... -..-- .._-.-. .-._..
_. .- ....-. ..--. _.... . _ .. . ..-. crack _ ....
-..-- ...__.. -... . .. ._-. , ._-. . _- - _.. _.. . .
_.. _.. ... . .- - . . .. -. . .- - .-. trial version .--.. .._
Cracker -....- .-.-.-.-. ._-......-- ...- _.
_... _....-- ....._..-. -.._-. .... .. . -. ..
.- -._ . ....- _.. _--. . -.- . . -. ...- _- ...... - . .-
-. _.- . - ,
Cracker .....--- .--..- cracker .- -.-. . cracker .- ._-
- - _-... . - . . - . - -.. _ . .- ._--. .--. .--.
_.--- .....-- ........ .-. ...-- cracker ...-.
._-.. ....-.- crack .-. cracker ._..-.
Cracker .- developer -. .., .- _-.. - _..- -.-. developer .--. .-
-.-- --... -.._-_. cracker .- . . .- .. - - .._--. -. .
-. . _.. . -. Cracker .--.-. .---. .--. .-.-..- _.
_....-- ...-.. ._._.._. ......_..-- __-_. cracker -. ...- -.
crack .. -- .....-- crack _. .- _.. cracker .-- _-.
.....-.-.. ._--._..-. ._-. cracking ...-. - _-....
-. _ .-. _.. -.
.-.. .... -. ..'.- ....-.-_. _ .. ......-. -.
.....-.-.- -... ...-. -......_.- ...._. -.-.-.-
...- -......_.- .. ...-' -..-..--.. -... ..-._..
-. _ cracker' .- ....- .._..-..--. Windows XP ..
- .- . -. . OS - -.....-- --.-..- hacker .......- -
cracker .._--. ..- . ..-. cracker .-....-. .... protection .--
...._.-.-_. ._..-..- reverse engineer .--.. __.-.,
... . .- - -.._-. crack _-. . -.-.-. crack _ ..._. -. .-
--.-.. .-.. -.... .- . .....- .. .-
- .... - . .-. ._-. .. .. .._-. cracking ..--. ......-.
- . . ..-. . . ..-..- - . .. _-_- .. -._...-. .-_.
... .-_....-. crack -.-. -... - . .-. _. -. . ...
-. -. -. - -. ..... .-.- ...-.-.._.._. crack .._ ....
... . - _. _... . _. _.._ . , ._- .... crack .._ .... ... . - .. .
. .-. .- . .._..- - . . _ . ._ . . - . .-- ......... -...
.-. _...... cracked .....- _._..........--. ._.._. ....-.,
Cracker .-. .-. ...- _.. . - - ..- ._ ._......- .._... -.
, .. ....-.- crack . . .- - - . --.-. .-. -.._-.
..-. .-. ._-. .-- ..- . .. . -. ._.. . - .
, ... . - .- crack -. -. . ..-. ... . - .-. crack .. .
. .._... . ASProtect 1.3 - .-.-.- crack ._...-. _--.
-... ......-_-..-. .. - . .. ...- -.-. . -- crack . .
_--..- -. Word to PDF Converter 3.0 ....-. ASProtect 1.3 protect ..-.
_.. -. ,
., Cracker ... . ... ... - ...
.


, . .- _- -- . -.- - .. --. . . ._..- _ - - ...- .-
... _....-- ._._ --..- ......- crackme .- ..... Cracking
- .- _ . .. ... . ..- .. cracker .-- -_.. .-- . ...- ..
, Cracking - .- - -- .- .......- .. ._ .. . , . . ._.... - .-. - -.
.-.....- .---. ... -.-.- .. - ..- - _... .- - . ._--.
. - .. -..- - - .-. - . ._--. -. ._-. -- . .- - . .- ._- .-
..
, - .- - . . . . . .- -. -. -. -. . . -. . - -.
....-..-.. .- crack . .....
, .... ..._-- tool .-- .... Tool ._. .. .. .-. .-. . ..
shareware .- - ...- -. ...- - . tool - ._.----.- ... Tool -.-
._ . . . -. .-.. .-.- tool -. _.. ..
, Cracking . ._ ..- .- . . ... . . . _.. .. . . . -
-. .--_.._-... .- _....- - - _ ...-. ....... ..-
.....-. ....- protection .- ._-. . .-. ..-. . . . . ..
., _. -. . .. _.. ... - -. .._- .-. . -. ..- . . - tool .--
. ._ . ..- . ...- ._-. . . .... Shareware ... .- .. .- . .... . .
...._. .- .-.. .-.- _._..--.. .-.-- -.
...- ..- . ._.. ..
, -.- ..... .--_-- .....-- - . -.... .. ..
..-....-- ..-... ._.... .....- .- _....-- ._-.....
... -.-.._.-.-. .-....
, ...........- -..-- ...... . - .- -. . - ... . .-
_.. ... .. _. ... - - _- ......-. _... .- ....- crack/ keygen/
serial .- - . .... . -.-. -...-.. ...-.
, - .- ........ .........- Crack ...... -- . ........ Cracker
.-. .-. ...- _.. . . ..
Cracking - .. . .- . ..-. .. . . . -. ....._ . - .- -
.- _- . - . ., ._.. . - . ... . .-. .-. ......- Visual C++ Borland
Delphi Dot.net -. -....-...- .......-. _.. -. -....-...- .....
..-._.. - - - . . -. -....-...- - -. .- -- ._..- .. . -..- -
-., Cracking ... .._.-.-- -_..... -....-....-.-. C
Assembly - C -. Assembly - .. . . - - - - C - ..- ..
_ .. -_ _ . _ .. . - .-. _-. . .. . ._ .. crack . _- .... ..- -.
-.-. Assembly -....-.. Assembly ._. - .-. .-. ......- 16-bits .- - .
- assembler .-- _._..--_--. ..... Assembly -....-..-.-. 32-bits
Assembly -....-.. _.. -.
Cracking ._-.-. compile ..- - -. binary - .- . , machine - .-
- . .. _.. -. -. .- - - -..- .- - _ ..- .- .. _--. - .-
compiler . -. . ...- . -. ..- .. - ...._. .. ......-.
._-. . . - -. ....-..-. - -.-....-.._.. ._. . ... .. compiler -
- _--. .. ..-. -. .- -. compile ..-. ., assemble ..-..- _..
-. -.-- disassembler -...__. binary -. _...... ..--.
.-..
100100100101010010101010010100001100111001
Binary . -. . . .. _.. _ . 0 1 - ._-. ... ..._-.-. .---
-- .._..- hexadecimal ..- _--. Hexadecimal .....-. 0 -. 9
A (10) -. F (15) -. HEX - - ... _ - -.
817D 0C 10010000 (HEX)
10000001011111010000110000010000000000010000000000000000 (BIN)
., Cracker ... . ... ... - ...



HEX - .- -. . .... -. -.._-. . .-. Intel - CPU .- mnemonic
..- opcode .-- HEX - .- ... _
JNZ 00002A; .... JNZ mnemonic -- opcode -. 75h (117d) _..-.
PUSH 0C8; .... PUSH mnemonic -- opcode -. 68h (104d) _..-.
Assembly -....-.. .... - - .-. ._ Assembly -....-..' . .... . .-
. .
..-...-. ...... ....... operating system -.-. Microsoft
Windows platform .- _.. - Windows 98 Windows NT Windows 2003 Windows XP
Windows Vista Windows 7 .-..- _.. -. OS .-...-. ._.._..-. Win32
API (Application Programming Interface) - . .__--. . - -. DOS .- - .-.-.
- -.-. .- .- . . . . interrupt .-- .._-., ..- API function
.--. DLL (Dynamic Link Library) . .- . Windows . . --_ .._--. ..
_ kernel32.dll GDI32.dll . .-..- Cracking ... .dll . .- API function
.- - .._ ....
. -. Unix/ Linux ..-- .-.. .-. executable . .- . . ELF
format -. .- ... . . Windows ...-. PE format - . ._-. PE - .._- .
. .....- -.-. .exe .dll .ocx .sys .cpl .scr ..- _..-. Cracking .. .
. .- ._-. .- - .-- . ....
.. - . cracker .--- cracking - .- _ . . - ..... ._-. ...- -.-.
protect ..- shareware .-_..-. ... ._. cracker .- .-...-.-.-. PE
..-- packed/unpacked _. ..-.. function .-- .._.___. ......-,
. ..- - .- - _ ._ . cracking tool .-- ....._.- _.. -. ._-. .
.. - . cracker .--. shareware .-...- nag .-- .-_. serial ._..--.. .-
... _-_ . ... . .- - register _--. -. ... . protect ..-. -.
protect ..-. . -.- . ._ . registrated version (cracked version) -..._--. .-
--.-. _-...... .._.. .- _..-. ... cracker ...-. protect ..
-....-.,- crack .. _... tool -..-. ..-. tool -.-. debugger
., decompiler ., disassembler .-.
Debugger .-..- .-_.--.-. -. ... .._---....
.._. -.-- _.. _.. -. -.._-...-. -..-- debug . . ...
_.. - - .- - .-. - - .- . .. - .-. - . . .-. ._-.
-.. .-.-..-.... -.. debugger - ..__. _..-. .....-
debugger/ disassmebler .- -.-. Olly IDA Pro W32dasm - _.. -. Olly -. . ...
- ... . _.. _ . . .. . ..._.. -. ._-. . . _. cracker .- . ... -
.-. .-. ......-. Olly - . ..._ . ._-. _.. -.
-. -. - crack . _-.....-.... -. - -. -....-.. .......-.
.-.... ... _-.....-. -- PEiD ., CFF explorer .- tool .-
-. tool .- -. crack -....- -.-....-.. ....-. . -. .
..-. ....- Visual Basic ....-.. .-. Olly ... VB Decompiler -
.._-. ..-.-. ..- Dot.net ....-.. Dot.net reflector - ..-.
_...-..--. -- -.-....-...----.-. Olly debug . -.
--. -. .- - pack .. .-. unpack _ .. crack .._..-.,
-. crack ..-....- .......-. _ .. ..- ..._- . -. ._.. .
_..-. .-_-_..-.-- .-... .._. .. _ .. .- ... -.-.-. cracker .
. . . -_ -.
.- cracker .-..-....-_...---.-. -.- - ...... . ._..
.. -.- -. tool .. .- -- . .. .- download ...- .-..-.......
. . . . .. ... . ..._. . ... . .. . ..- - crack _-_ . .......-
--..-- .._...- Crack .._ ..... .- - . . . . - . - -- .
.- ...... ._.. -.

., ._ C -....-..



tcef;(2) - tajccH C bmompum;
Cracker .-..-....-_...-- -.-....-..-.- -..-..-- --
._..-.... _..--- .. . - .-. . C -. -....-..- _ . . ._. .
_.. -. -.._-. _..-....-..- .. .. . ... . - . -. C++ .
..-...-... Visual C++ . _..__.-... . . .-. . . -.
...- - ._.-.-. C -. -....-..-. ._ -. . . .. . _.. C++ -. C
-....-..- .. . .. ..-. -. ._-.. ...-.-- C
-.. ... ._ ._.. -. Visual C++ -.-. Windows - ._ _ . -_ ...- ..-.
._-. . - .- -. _ ._ . cracking - .-...- .. ..... _..-. C
_.. -. -....-...- . .....--.--.-. operator .- ._. system
-.-- function ._. -.......- .._. -......_.
. . ..- ... _. _ . Visual C++ - ._. .....- - ..- - __ .-
_.. -. . .... ..-. C ..- .. .._-. . _.. ...-- .........--- C
-..-- -........-.-.. ._.._..-. .... C ...- - ... .
.- -. . - .. . -.- .. ... .. ..- - - cracking ... ..--_... C
...- ..--.. ........_..-. ._-. graphics -.--.- .......
- _.- -. . - Graphics .-. DOS - ._ - 16-bits .. _.. - - - .-
.. .- .- . . -. . . . ..__-.-. - ., _ structure .- cracking ... ..
.-- - ..-. .- Structure .- C++ - . _. ...
...-...._ class _. ....-__..-., C - . - ... . . .
.-. Ivor Horton .....- Beginning C - From Novice to Professional' .. - .-
- - - . -. -. -... - . .. . .... - . .-. .. .......-
_- _ -. -.._-. . .-. .......- -. -. ...- -. ...- ._ . .- ..
. .- _ _-
..-..._._-..-.- C -. -....-..-. DOS - .___ . - ..-._.. -
-- C .. - - -. .- -. .- ..- . . .__ ..-. ._-.
Windows 98 ..-.-- Windows .- .-.- ._.. .-. - . ._-. -. .... .
- .-. - . Turbo C 2.0 (DOS version) - ....- Borland C++ 5.02 (Windows
version) - .._.._..-. _- - .- ..-.-.-. Borland C++ 5.02 . . -. .....
.._..--- C++ -. .- ...-. . .. . C -....-.. .- .- .. -. .-
... ._.. -. ._-. Borland C++ 5.02 - install . ... _. Start menu
All Programs Borland C++ 5.02 Borland C++ - . - . -. .- .....
_
, .. . C -.
,.. _..--. C++ compiler .. -.-- -_- -.-.-- source
code ..-.

,
., ._ C -....-..



Ctrl + F9 (Run) - .-.-. compiler - -.-.- ....- source -- exe
- _.. ._. .... . _.. -. --. .-. source -- compiler - assembly - _.. ._. .
.._ . assembly -- assembler - exe -_..._....-. _.. -. ,

,
,-- - run - ,- . _. . . -. ..-. --. .-. -. .
.-. ..-. . . . .- - - . - -.. ..._ . . Welcome to Cracking World' .-..-.-
_... .-.._ -. - ....- _-_-_-..
, ...._-..- include .-.-.-. keyword -._..-. -.-.-.._.. header
..-- C:\BC5\ ..- - include .- ...-.. ....._-.. --.- ._._-..-.
<stdio.h> . -.-.-. include ...-- stdio .-._ header .- .._..
._.-. <stdio.h>... "stdio.h" . .-. C++ compiler .- - _ - . ..- -
stdio .-._ header .- .._.. ._.-., stdio _ .-.- -.-. STandarD
Input/Output _..-. header ..- ._-. ...-. --.-- ..
-...-._-.. --.- compiler - .._-._...-. _..-. -..--
..-...-.-.-. --._._. ....-. conio _ .-.- -.-.
CONsole Input/Output _.. -. conio stdio -. ..-.-.. .- -. conio - ......-
- .. .- _. -... _ ._ .- .-.
, int main() .-.-.-. -.-.- .._.. .-.._.._. ..._--.--
main() function - { } .. ...._..-. printf() . -.-.-. function -._.._.
-...._..- ._-... -- .- - - -.. ..._ . . _...-. printf() -
. ... . stdio.h .- ._-_..... _..-.
, getch() -.-. 'GET CHaracter' - .-.- - -.- .- --. -.....-..-
--. ... -_- ...-.-. . ..._ . . _. ..- --. -.._-. function -
. .-. . -. -. printf() - ... _ . - ._ .. .. ..... -.- ..
. - . .-. - .- - -. . . .- . key -.- .- getch() ...- _......
getch() - ..... conio.h .- ._-_..... _..-.
, return -.-. main() function .- . -. . -. -. - - .._... ....
_ _.. - ._-. . -. . ._-. ._ -.
, - .._..- C -.


,

#include <stdio.h> /* 2nd C Program */
#include <conio.h>
/* print Fahrenheit-Celsius table for fahr = 0, 20, , 300 */
int main()
{
int fahr, celsius;
int lower, upper, step;
lower = 0; /* lower limit of temperature scale */
upper = 300; /* upper limit */
step = 20; /* step size */
fahr = lower;
while (fahr <= upper) {
celsius = 5 * (fahr - 32) / 9;
printf("%d\t%d\n", fahr, celsius);
fahr = fahr + step;
}
getch();
return 0;
}
., ._ C -....-..



,. . _. -.-.-. .. - - . - - - -...-- .._...__. ---..-
-. - - .- ._. -. .- -- . . ..__.,.-- ..---..
.-_.._. _..---.. .._ _. ,.- -.-. . - - - - . ..- _.. -.
-. - .... - _-_ _-..
, /* */ ..---.-. comment .-. --. -. .- . - ._-. ..
.-- .--.. comment . .-. . - - .....-. -. - -.- - ..-.
-. ....-. . -. . -- .._.... _.-.. /* ._. */ . ..-
-. C++ ....-. /* */ ... \\ - ..-.
, int .-.-.-. integer -.__,- .-. -.-. --..._.- ..-. .-
.. int -.._-. fahr celsius lower upper step --.-. identifier ..
-. Identifier .....-- _-_,
, lower = 0; . -.-.-. .. .._. - .. - .. ----. ._ .-.---.
_. . ... - - -.-. _.. -. . - main() function - ..._-. .-. ._-. ._ .
-. semi-colon (;) _. ...-..._, step ..-.-. ..- --.. -.-.-.
-_.... .-.
, while(fahr<=upper){ }-.-. .. - - - . .-. _. . .- . ._.. - - - . ..
- ._.. .. - _ .. - ._.. .. . . - - .- - . .-.
, celsius = 5 * (fahr - 32) / 9; -.-. . - - - - . .- ...- .._ . _.. -.
, printf() function -.-. ..-- .---- -...-- ._.-.... %d -.-.
- .__ .- - .- _ . ._. - - . . . .-. \t (tab) -.-. ._.-. -. _-.. tab
key - ...-. .. - .- , _.... .-. \n (new line) -.-. - -.. ...
_ ..- -. ._-. .- . .. . -.
, .. - - - . .- . .-. _ . while loop ._...-. .----..- ---
_ . ._. - -. .. ---..-. -._-... while loop - ... - -.
- _- .. .. .-. getch() function - .._..-. _..-. -. ...-_...
. ... . _.. -.
, Data type
. .... ..
unsigned char
0 . 255
char
0 . 255
short int
-32,768 . 32,767
unsigned int
0 . 65,535
int
-32,768 . 32,767
unsigned long
0 . 4,294,967,295
enum
-32,768 . 32,767
long
-2,147,483,648 . 2,147,483,647
float
3.4 x 10P
-38
P . 1.7 x 10P
+38
P
double
1.7 x10P
-308
P. 3.4 x10P
+308
P
long double
3.4 x 10P
-4932
P . 1.1 x 10P
+4932
P
Data type .-.-.-. ...._.. identifier (variable) .-- .-...... .-.-
..-. - . ._-_... variable -. ..... ..-... -.__...-. .-...-...
.... .. .. ..- - .- . (string) ......- - .- . char ._-_...
.. - .__ .- . int ._-_.-. ..- ..- - - . float double -
.._-.
Variable -.- char ._-_. - -. . - . . . 1 byte ..... _..-. 1
byte -. 8-bits _ _ . _ . . ... . . .. _ .-. ..- ...- --. .-_...

., ._ C -....-..



1 1 1 1 1 1 1 1
... - - . -. . -. 1 bit - -....__. ... 1 ., 0 .- -....- _
... -. . . .. - . ..._- - - . . ..... ._ . - .- - -. 0 -. 255
256 . . _.. -. 11111111 = 2P
8
P = 256 {0 . 255 } . _- . .- _ - - _ ._.. ._ ,
char -.-- ...-- .._-_..
char variable_name; // character ...-.._... ._
char variable_name [20]; // string ... _. .._
char * variable; // pointer string .. .. - .- . . ._
char - ..-- --.-- ..-... _.._.. database -..--
.... . _.. _.. password .- -..-- ..... _.._.. ....... _..-.
int - ...-. --..-... 2 bytes ... -. ._-. . . . . . .._ .
...- -.-..-.-. 2 bytes = 16 bits = 2P
16
P = 65536 _.. -. int .._.-
-.-.
signed int variable_name; // 2 bytes -32,768 . 32,767
unsigned int variable_name; // 2 bytes 0 . 65,535
short int variable_name; // 2 bytes -32,768 . 32,767
long int variable_name; // 4 bytes -2,147,483,648 . 2,147,483,647
unsigned long int variable_name; // 4 bytes 0 . 4,294,967,295
signed short - _ _ ..._-_... -. --. int variable_name;
._-_... compiler - signed short int variable_name; .._-. C -. .... .
-.._-. signed/ unsigned short/ long .- ._-_....- ._-...-. _..
- DOS .- - .- _- .- -. - .- RAM .- ..-. .-.. 1GB .-
4GB .- .- - - . 64KB 128KB ..- .. -. DOS - .- - - 1MB -
_-.- C -. .- - . ._ ...- . ._-. -. ...- -. . - -. - - -.
.-... ...._... --... _-.__--. ._-. . --...
. - . .-.. . long ... short - ..__--. .-.- -.- ----
._.-. 40000 50000 .-_-.. ... .. variable - -. ._-_.. -.
. unsigned int variable_name; .. long int variable_name; .. ... .- variable
-. - - . . ..._- .... variable .- ... . . . ..... ._ int
variable_name [200] [100]; . .-. . -.- . .. . . Variable .-- 20000 -
--.._.....-. .._-.._ long int ._-_. - -. . - . . . 200 x 100
= 20000 x 4 bytes = 80KB ... . .. . RAM -. 64KB .. . .-. -. -.
stack overflow _.._. .. .---. . - - ..-...-. --..-...
..-. ..- . . . - ... .-. - .,
float -.-. ..- ..- - - - . ._. .... ..__. .-... 4 bytes ...
-. double - ..- ..- - - - . ._. ... . . .__ . . - . . . 8 bytes ...
-. .. ....--.- .. .- - - . .- . . . ....-. long double -.-.
double --. .-... 10 bytes .......-.
, Identifier
. . _- - . . .- . ..- variable .-._- identifier .-. Identifier .- -
._.... ..-._....-- -.-.
, Identifier .._ ... A-Z, a-z, ., underscore .. _..._
, Underscore (_) ..--. -.-.... ...
, Identifier ....--._ .- .
, Keyword ...- identifier _.. .._-_. .. ScaseS SreturnS,
, MY_Variable123 my_Variable123 - ._ .- _ _- .. ._- .... - _... ._
., ._ C -....-..



..- identifier ...-.-. . - - . .- _.. -.
int get_result_from_program;
int x123;
..- identifier ...-.-. . ... .- . .- _.. -.
int 123data;
int while;
int base@location;
int get-result-from-program;
, --.._..- C -.




,

-- .._..- -. -. - . -. ..-..--. -.._-. .... _
. .. . format specifier ._-..- ._ Format specifier - printf() function
-.._. % .. -. . ._ - format specifier ......--.-. flag character
width specifier precision specifier input size modifier conversion type character -
_..-. .....-. .... ....... format specifier .-- ._.. _..-.
%d -.__ (integer) . _. . .-.
%o ... (octal) _. ..-.
%u unsigned integer . _. . .-.
%x .. (hexadecimal)- .. .... _-.
%X .. (hexadecimal)- .. ._- . _-.
%f ..- . ._. - ..-.
%e Exponential ._. - ..-.
%E - . ._. - ..-.
%c Character . ._. - ..-.
%s String . ._. - ..-.
%l long . ._. - ..-.
%lf double . ._. - ..-.
%L long double . ._. - ..-.
#include <stdio.h> /* 3rd C Program */
#include <conio.h>
/* print Fahrenheit-Celsius table for fahr = 0, 20, , 300 */
int main()
{
float fahr, celsius;
float lower, upper, step;
lower = 0; /* lower limit of temperature scale */
upper = 300; /* upper limit */
step = 20; /* step size */
fahr = lower;
while (fahr <= upper) {
celsius = 5.0 * (fahr - 32.0) / 9.0;
printf("%7.0f %10.3f\n", fahr, celsius);
fahr = fahr + step;
}
getch();
return 0;
}
., ._ C -....-..



,- printf("%7.0f %10.3f\n", fahr, celsius); - _-_- %7.0f .. 7 . -.-.-.
-. -. .. . 7 ... ... .. ._.-. f -.-. ..- ..- - ._. - -. %10.3f
...-. 10 - ......-. ......... ._.-._.._. .3 -.-. .. 3 ..
_.. ._._..-. ..--.-.-. escape sequence ._-.._..-. .......
.- -.-. \t \n - _.. -. \t -.-. tab key -. ....... .. ._.-._.. _ . \n -.-.
..- -. ._-. .- . ... ._.-.
, keyword
C -....-.... .._-- keyword .- -.-. ..- - . _.. -.
auto break case char const
default do double else enum
extern far float for goto
huge if int long near
register return short signed sizeof
static struct switch typedef union
unsigned void volatile while
Identifier .--._-_.... keyword .-- variable ._ .. .- . Keyword - ...
....-.... .......- keyword .- ...-.-- .._..
. .. .- .. ... .. . _.. -.
, if statement
if statement - ._.-. -. . .... ..... . ._.- .- . . . ._
-. -- . . else keyword - . .-. -. . _.. .-.-.-.
(1)
if(condition) statement;
(2)
if(condition) statement;
else statement;
(3)
if(condition1) statement;
else if(condition2) statement;

else statement;
(4)
if(condition1) statement;
if(condition2) statement;

, . . - .-. ._.-. -. . .. .._.--.. .._-.
, - . . -.-. ._.. . - -. -. .. - . .. ._.. . . ._-.
, --..-.-. ._....,..-- - -. -. .. - . .. ._.. .
.._-.
, .--.-.-. ._....-. .. ...... _...-._... ..-.
., .--._..- C -.

,
., ._ C -....-..



,- -.-- run - ,- ..- . .

,
-.-. -.---. .-_-- -.-. .... . - .. . _... -.
.. ...... . _.. -. , if statement - .._.....- ..- -... ....
..-..-.-.-. scanf() function .._-..- .... - . .-. scanf ....
mouse cursor -.._. Ctrl+F1 - .- .- -..._..- Help .....
, _.. function .-- Ctrl+F1 . _ . .... - _-_ -.

,
scanf() function - -.---. -_.. -. ......- - .- . . ._-.
. . -. . . - .-. - .- .. .-.-. - .__ - .%d, -. _..-. number_check
... address sign (&) ..-. ...
Function .-._-....-. Help - .......- Help .. .- example .--
. . Example .-- run _-_
, switch statement
if statement ..-.-...-- _..-.-.-. switch statement _..-. .
.._...-.-.
switch(expression){
case constant_expression1: statement;
case constant_expression2: statement;
default: : statement;
}
, ._..- C -.
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
int main() { /* Copyright Myo Myint Htike, 2009 */
int menu;
printf("Choose 1 to print \"Welcome!\" text. \n");
printf("Choose 2 to print \"Sorry!\" text. \n");
printf("Choose any number to exit!\n");
printf("Please enter a number: ");
scanf("%d", &menu);
switch(menu){
case 1: printf("Wecome!."); break;
case 2 : printf("Sorry!"); break;
default: exit(0);
} getch(); return 0; }
., ._ C -....-..



-.-.-. switch statement - -..._..-. _.- ..-. -.
..-.-.-. -.-..._-_ - ... . ._ -.-.-. exit() function
exit() . .. -.-. exit functions' . -.- .. . . function -. - ..
.-. .-......-. stdlib.h <STandarD LIBrary> - ._-_..... switch
statement - .-. . ._ . - - - .. . -.
, while loop
-. .-. loop .-._-.. .._-_.. Cracking ... .......-.-. loop
.- Loop .--. -.- .-.-..- ._.-.-... _-....... ..
-. ....... loop .- -.-. for loop while loop - while loop . ._. . -.-.
..- - . _.. -.
while(condition)
statement;
while loop - .- - . . -. - .-. ..._.-. - . -.._-. . .-. - .
._..- C -. . . while loop - .__ . while loop -. - . .._ . while
loop -- ..- loop -.-.-. do{ } while loop .._.--- .._.-.-.
, for loop
for loop . ._. . -.-. ..- - . _.. -.
for(expression1; condition; expression2)
statement;
for loop -.-. ... expression1 - initialize -. _..-.
condition -. .... ...... ..-. ..-. statement . - . ..-. _ ..-.
expression2 - -. expression2 - ..._.-.. expression1 . _ ..- .-.
_..-. condition - . .. .. -. Condition -. . ... statement - ... - .. .
_.. _ . . ..- -. .. loop -. _ .. .. ._.. -.
, ._..- C -.









.,
.,-.-. ..-. ..-.. _..-. x y z - .... . for loop . ._ . ._. .
..-. -. - ..._-_ .. . -.. ._ ._ .. .. .- ._. .. ..-. .- . . _ .
-. cracking - password .-- ..... .-..-.. . -. -.
- _-_-_-..
, .. . - .-. - . - .. - . .- - .__ .- _.. ._-_.-. . - - ..
- . . .- . ._..- -. _. -. . - .__ _.. .. ..-. .- --. -.__ .. float
._-_.,
#include<stdio.h>
#include<conio.h>
int main()
{ /* Copyright Myo Myint Htike, 2009 */
int x, y, z; /* Declare 3 unknown variables */
for(x=0; x<10; x++) // for(1; 2; 14) After 14, then go to 1
for(y=0; y<10; y++) // for(3; 4; 12) 3=13
for(z=0; z<10; z++) // for(5; 6; 10) 5=11
if(2*x+3*y-4*z == -3) // if 7 = true then do 8, else go to 10
if(4*x-2*y+z == 6) // if 8 = true then do 9
if(x-3*y-2*z == -15) // if 9 = true then print x, y, z
printf(" x= %d\n y= %d\n z= %d",x,y,z);
getch();
return 0;
}
., ._ C -....-..
.


, for loop - .- -. for loop - ....._ .. _-_ .. . x - . .
- ._.-.--. _..-. x -. 10 - ... ..-. . ..- -. ._-. .-
. .. ..-. y - . .- . _ .- . - -. _ ..-. y -. 10 - . .. .. -.
. ..--.._-..- .....-. z -..- ._.-.--. _..-. z -. 10
- . .. .. -. . ..- -. ._-. .- . .. ..-. -. . . x=0, y=0, z=0,-
2x+3y-4z .. ....._. -3 _ ._ .. -. _ ..- -. ._-. .- . .. ... . _.. -.
._ .-. z -.... -..... _..-. -. z=0 -. z=1 _.. .-. z -. 10
- . .. .. -. . ..- -. ._-. .- . .. ..-. -. . . x=0, y=0,
z=1,- 2x+3y-4z .. ....._. -3 _ ._ .. -. _ ..- -. ._-. .- . .. ... .
_.. -. ._ .-. z - . .. . -. . .. . _.. -. x,y,z - . .. .. .- -. . .
. .._ . _ ._ . ._-. .. . _ ._ .. . . _..-. .. .. .- - -.-. -. _- . -. _- . -.
.. - . _.. -. --. _ .-. printf() function - .._. x,y,z --...--
._. - ... . _.. -.
, x++ .-.-.-. x = x+1; --. Operator .....-- _-_,
, operator
Operator .-- ..--. - . . . . -.
-, Arithmetic operator
, Unary operator
-, Relational operator
., Assignement operator
, Logical operator
., Conditional operator
., Bitwise operator
-, Arithmetic operator
Arithmetic operator .--.-. ..--._..-.
+ (addition) Variable ... ...-.._._
- (subtraction) Variable ... .-.-.._._
* (multiplication) Variable ... ._..-.-.._._
/ (division) Variable ... ....-.._._
% (modulus) _-...-..._
, Unary operator
Unary operator .- -.-. ..- - ._.. -.
i++; (postincrement) Variable -.... -......_
i--; (postdecrement) Variable -.... -..-..._
++i; (preincrement) Variable -.... -......_
--i; (predecrement) Variable -.... -..-..._
..._..-. .-- increment operator decrement operator .._--.
.... .-...-.-. i++ ++i - -_...- ..-- .._-_... . .-. . -
. .. - - -.
int i=0, j=0;
i++; ++j;
.... i j --..-. -.._.._. 1 .- ._.-.. ..-.-...- _-_
..
int i=0, j=0, x=0, y=0;
x = x+(i++);
y = y+(++j);
., ._ C -....-..



..-. x - . .- . __.. ._ . y -..-.-. 1 _.. .. . . -.-.-. i++
._-_. i --..- x . .. ._ .. i - . .- -. . .. ._.. -. ._-. i++ -
postincrement .-.
-, Relational operator
Relational operator -.-. if statement for loop while loop .-..- - . ._ . ._.
-.- ...... variable .-- ...... .._-.
== (equal) Variable -....- -.-..-. - -.
!= (not equal) Variable -....- -.-..-. .- -.
> (greater than) Variable -..-. _-.._-...-. _-. -.
< (less than) Variable -..-. .....-. . -.
>= (greater or equal) Variable -..-. _-. ., _ -.
<= (less than or equal) Variable -..-. . ., _ -.

., Assignement operator
Assignment operator .-- -. _..... . .__ . . - .- -.-.
= *= /= %= += -=
<<= >>= &= ^= |=
. ._ .- -.-. ..- - . _.. -.
x = y +10; // x = y + 10;
x *= 10; // x = x * 10;
x /= 10; // x = x / 10;
x << = 3; // x = x << 3;
x ^ = 30; // x = x ^ 30;
, Logical operator
Logical operator .--.-. ..--. _..-.
&& (AND) ._...... -.
|| (OR) ._...- -.. -.
! (NOT) ._.... -.
. ._ .- -.-. ..- - . _.. -.
int x=0;
scanf("%d",&x);
if( x>0 && x<40) printf ("Fail");
if( x>75 || x == 75) printf ("Credit");
if(!x) printf("The value of x is zero.");
., Conditional operator
Conditional operator .-.-. ..--. _..-.
logical-OR-expression ? expression : conditional-expression
.._-.-. ..--. _..-.
z = (a > b) ? a: b; /* z = max (a,b) */
a b - _- .- - . .- . - ....- ..- -. . ._ .... .
if (a>b) z = a;
else z = b;
.... z - . .-. -. _.. _.. .... ._.. .. . _.. -.
., Bitwise operator
Bitwise operator .--.-. ..--. _..-.
., ._ C -....-..



& (Bitwise AND)
| (Bitwise inclusive OR)
^ (Bitwise exclusive OR)(XOR)
~ (Bitwise complement) (NOT)
>> (Bitwise shift right)
<< (Bitwise shift left)
.._-.-. ..--. _..-.
AND OR XOR NOT
Source Bit 001100 1100110 1
Destination Bit 010101 010101X X

000101 1101101 0
>> -.-. assembly -....-.. SHR instruction -_. << -.-. assembly
-....-.. SHR instruction --. SHL SHR -. register.-...- bit .--
-. _.. . .- . - ..- bit .--- .--_. .--._..-. .._-_
int x = 0xBEEF; // x = 1011111011101111 (binaray)
x = x >> 4; // x = 0000101111101110
printf("x = %X", x); // x = BEE
_ ..._ ... ..- . .-. _-_
int x = 0xDEAD; // x = 1101111010101101 (bin)
x = (x >> 5) & ~ (~0 << 3); //
printf("x = %X", x); // x = 5 (101)
-- run - .-. 5 .-._... -...-..-. -.-...-. --_-_
Hexadecimal -. binary binary -. hexadecimal -. ._. .. . -.- .-. calculator
(calc.exe) - - - . -.
, Function
Function .-.-.-. ...-.-- . ._ .....- .-. _.. _ . function -. . .
.. - .- -.-. return type function name parameter list - ....... function
body - _.. -. Compiler .. ..- function ..-.-.-...- function . _.
function ......... _...-. Compiler ...- function .--.-. printf() scanf() .-
function .-_..-. .-- .._.-.... header file .- ._-_...-. ... .
.-. built-in function .-._-..- ._.. .---.
, ._..- C -.


,

-.-.-. 2 -3 - - .- . . .. 2P
0
P, 2P
1
P, 2P
2
P, 2P
3
P, 2P
4
P, ..)- ...-.
int power (int m, int n); . -.-.-. - .-. - . - ...- function - . ._.. ._-_.
-. ._-_...- - - main() function -..._.._.. _ . . _.. _.. _- - - ..-
. power() function - .. . _ -.._-. power() function - _- - - ..-.
.. . -. . .-. . scope ._-. --. .-. main() function _.. int power (int
#include<stdio.h> #include<conio.h>
int power (int m, int n);
int main()
{ int i;
for (i=0; i<10; ++i)
printf("%d %d %d\n", i, power(2,i), power(-3,i));
getch();
return 0; }
int power (int base, int n)
{ int i, p; p = 1;
for (i = 1; i <= n; ++i)
p = p * base;
return p; }
., ._ C -....-..



m, int n); ..-.-. extern int power (int m, int n); ..-. -- .... extern -.
keyword -._.._. .- storage class ..-.
Storage class ..-. auto extern static register - Function -.-...
-......_..- int float char ..-.-. ._-_...- data type .-...-. auto .-
Function .-_--.. -......_..- int float char ..-.-. ._-_...-
data type .-...-. extern _..-. static register --.-. .._.--- .._
.-. - . --. function .-.. return _.. -..-.. void ._-_...
, Array
Array .-.-.-. -_- data type .-- .._...- variable -. --. .- _ -
data type .-- .._..-. struct .- keyword - .._.. One dimensional array
-. - ._-_. -.-. ..- - .
int myanmar[60];
int myanmar[60]; -. .-. .......- ._.- .. _......-- ...._... ._-
_.-. --. array . .. .._-_. - .-. - . int myanmar1, myanmar2,
myanmar3; .._ _. ._-_.. ._.. -. . -.-. _.._. ....-. _.
. ... ..- -. _-_ ..
int exam_result [60] [6];
. -.-. .-. .......- ._.- .. -... ._.- - . . .._ ... ._-
_.-. Two dimensional array -. _.. -. ... . ._ -.-.-. exam_result -.
array .__.._. 60 6 -.-. array element _..-. Array element - -. - array
index ..-. Array element -. _. -. . 0 .._. ..-.-. size-1 _..-.
--. char - array . ._-_... . character ... string _......_-.. Data
type' . .. ..- . . ._-. . - - _-_ ..
char my_string [11] = "I Love You.";
int i;
for(i=0; i<11; i++)
printf("%c", my_string[i]);
-- run - 'I Love You.' . - .....- _. . . --. for(i=0; i<11; i++)
.... for(i=1; i<12; i++) _- ._.-.-. ' Love You. ' _.. . . Full stop (.) ..-..
space ( )- .-.. Array -.-. _.-.. null terminator (\0) . .. -. --. 12
.... 19 _ - random .. ..- - . . ..
., Pointer
Pointer . -. variable -. address -.....- variable -. Pointer - C -...
.-... . .-. .-. .. . .. -..- -. Pointer array -. .-. .-. .. .- . . -.
_ . . ... . .-. - _-_ ..
int x = 1, y = 2, z[10]; // MOV DWORD PTR SS:[EBP-4], 1 (EBP - 12FF8C ....,
int *ip; // ip - pointer .._-_.-.
ip = &x; // LEA EAX, DWORD PTR SS:[EBP-4]
(ip -. x -..- .....- (load effective) address ..-_.. 12FF88 y g/ )
y = *ip; // MOV EDX, DWORD PTR DS:[EAX] (y -..-. 1 _...-.,
*ip = 0; // MOV DWORD PTR DS:[EAX], 0 ( ip -..-. 0 _...-.,
ip = &z[0]; // LEA EAX, DWORD PTR SS:[EBP-2C]
(ip -. z[0] -..- .....- (load effective) address ..-_.. 12FF60 ,
printf("%d %d %X %X", x, y, *ip, ip); // PUSH DWORD PTR SS:[EBP-4], PUSH EDX, PUSH
DWORD PTR DS:[EAX], PUSH EAX (._-. ._.-. 0 1 0 12FF60 _..-.,
Unary operator -._..- & -.-. object address - _-. & operator -.
. - . . . variable array element - point .-. Expression constant .-
register variable .--.-. point ._. .-.
Unary operator (*) -.-. indirection ., dereferencing operator .-. Pointer
_...._.. pointer - point - object - ..-.

., ._ C -....-..



, . ._..- C -.










,






-. -.-. . - _ - - ...... . - .. ..- - - ... __ . .- . - ..
- ..... - - _ ._ .. ..-. -. . . pointer array .-- -..-. .-_...
, String
-. . ..-. string .- ._-. .- _ .. . ._-.. String - .- -
function .-- .._... <string.h> - ._-_..... String function -.-.
..- ... _- ._.. -.
strcpy(str1,str2) str2 .........- str1 . -._.._.
strncpy(str1,str2,length) str2 . .-.-......---. ........- str1 . -._.._.
strcmp(str1,str2) str2 . str1 -- ..._.
strcmpi(str1,str2) str2 . str1 -- ..._. ..._-....- .,
strlen(str) str ....--- __.
strcat(str1,str2) str2 . str1 - ..__. - str1 - ...._
,- -. . strlen() function - ..-... ...-....-. .-.. --.
.-. -. - pointer .- ._-. . ._ strlen() function - -.-...-. .....-.
- .-. - . string -.-- function .-..-.......- -.-.... .-.
<string.h> - ._-_._. .... _. . ... ._..- -.- _-_ strcmpi()
function - --_ . . . ...-. .- . .
#include<stdio.h>
#include<conio.h>
int strlen(char *string);
int strcmp(char *string1, char *string2);
int main()
{ char get_string[100]; int length;
char *comp_str = "My Love";
gets(get_string);
length = strlen(get_string);
printf("String Length = %d", length);
if( (strcmp(get_string, comp_str)) !=0)
printf("\n\"%s\" and \"%s\" are not equal.",
get_string, comp_str);
getch(); return 0; }
/* strlen: return length of string s */
int strlen(char *s)
{
int n;
for (n = 0; *s != '\0'; s++)
n++;
return n;
}
// strcmp: return <0 if s<t, 0 if s==t, >0 if s>t
int strcmp(char *s, char *t)
{
for ( ; *s == *t; s++, t++)
if (*s == '\0') // if null-terminated string
return 0;
return *s - *t;
}
., ._ C -....-..



, ._..- C -.





,

-.-.-. _...-....-..-....... ..._-- password -. -.---
. password -. - - _ .-. Password -. .. - .. ..- password -_
.-. . .-. .- . - ..- function - ..-. -... .._.-...
_-.-. Debugger .- - . .. .. . .-. -. ....-.-. .-. .-. _....
-. ._. -. Function - recursion .._. -.- -.... ..-.
Recursion .-.-.-. function -. - _- . _- . _ .. ._ . . .. -. ,
, File I/O
-. . ..-. . -. -.- - .-- -..-..- .-.-- function
- .._-_.. .-.-- function .-- .._... <stdio.h> - ._-_...
.. File function -.-. ..- ... _- ._.. -.
fopen(filename,mode) .-...,.-._.
fclose(filename) .--_.
feof(filepointer) ......-...-...._.
fscanf(filepointer,format) ..--....-_.
. function .-. .-. ......-. ... input/output - function .-. .-. ......
....--. -_..-...-.- file function .- . . -. . -. - - .- -
. .. ._...-... -.
, ..- . . C -.
-. cracker test -. . . - _....-. - ._. .- -. .. .._-_ ..

,
#include<stdio.h>
#include<conio.h>
#include<string.h>
void Password();
int main()
{
Password();
getch();
return 0;
}
void Password(void)
{ /* Copyright Myo Myint Htike, 2009 */
char password[80];
printf("\nEnter Password:");
gets(password);
if(strcmpi(password,"PASSWORD")==0)
printf("\nYou really did it. Congratulations!");
else{ printf("\nTry again!\n"); Password(); }
}
., ._ C -....-..



043B374 PUSH EBP
0043B375 MOV EBP,ESP
0043B377 ADD ESP,-10
0043B37A PUSH EBX
0043B37B PUSH ESI
0043B37C PUSH EDI
0043B37D XOR ECX,ECX
0043B37F MOV [LOCAL.4],ECX
0043B382 MOV [LOCAL.1],EAX
0043B385 XOR EAX,EAX
0043B387 PUSH EBP
0043B38D PUSH DWORD PTR FS:[EAX]
0043B390 MOV DWORD PTR FS:[EAX],ESP
0043B393 XOR EBX,EBX
0043B395 XOR ESI,ESI
0043B397 MOV [LOCAL.2],10
0043B39E LEA EDX,[LOCAL.4]
0043B3A1 MOV EAX,[LOCAL.1]
0043B3A4 MOV EAX,DWORD PTR DS:[EAX+294]
0043B3AF MOV EAX,[LOCAL.4]
0043B3B7 TEST EAX,EAX
0043B3B9 JLE SHORT Cracker_.0043B3F5
0043B3BB MOV [LOCAL.3],EAX
0043B3BE MOV EDI,1
0043B3C3 LEA EDX,[LOCAL.4]
0043B3C6 MOV EAX,[LOCAL.1]
0043B3C9 MOV EAX,DWORD PTR DS:[EAX+294]
0043B3D4 MOV EAX,[LOCAL.4]
0043B3D7 MOVZX EAX,BYTE PTR DS:[EAX+EDI-1]
0043B3DC LEA EDX,DWORD PTR DS:[EDI+ESI]
0043B3DF ADD EAX,EDX
0043B3E1 MOV ESI,EAX
0043B3E3 ADD EBX,EBX
0043B3E5 XOR EBX,ESI
0043B3E7 MOV EAX,ESI
0043B3E9 CDQ
0043B3EA IDIV EDI
0043B3EC INC EDX
0043B3ED ADD EBX,EDX
0043B3EF INC EDI
0043B3F0 DEC [LOCAL.3]
0043B3F3 JNZ SHORT Cracker_.0043B3C3
0043B3F5 DEC [LOCAL.2]
0043B3F8 JNZ SHORT Cracker_.0043B39E
0043B3FA CMP ESI,3810
0043B400 JNZ SHORT Cracker_.0043B40A
0043B402 CMP EBX,402A4FE7
0043B408 JE SHORT Cracker_.0043B424
0043B40A MOV EAX,Cracker_.0043B4AC ; ASCII "Sorry, not the right
one - try again !"
0043B40F CALL Cracker_.004338AC
0043B414 MOV EAX,[LOCAL.1]
0043B417 MOV EAX,DWORD PTR DS:[EAX+294]
0043B41D MOV EDX,DWORD PTR DS:[EAX]
0043B41F CALL DWORD PTR DS:[EDX+78]
0043B422 JMP SHORT Cracker_.0043B47D
0043B424 MOV EAX,EBX
0043B426 SUB EAX,ESI
0043B428 CMP EAX,402A17D7
0043B42D JE SHORT Cracker_.0043B449
,
., ._ C -....-..



....- -.-. ,. . _..- - . _.. -. .-.. .-. .- . . .-. _..
-. Cracker test -.-. cracker .- _.- ..... ....- -. _.. _ . . .,
.very very easy very easy easy not entirely easy somewhat harder hard very hard very
very hard, -. ._..- .-.-. ., easy level, _..-. -.-
Olly debugger .. - . . .- - - -.-. ,.. _. - - . _.. -. ,. . _.
--- ._....-. .-...- .-. ... - - - . calculator --..-. .
., ._.. . - . ._-. -. .._ . ._. .. _- ....-. C -. ..- ,- .
.- _. -.
#include <conio.h> // Compiled by Borland C++.
#include <stdio.h> // Coded by Myo Myint Htike.
#include <string.h> // Date - 2009 March 13
#include <stdlib.h>
#include <math.h>
int main()
{
FILE *fileread = fopen("english.dic","a+");
char password[50];
int EDI, i, j, EDX=0, EAX=0, ESI=0, EBX=0;
while(!feof(fileread)){
int character_count=0;
div_t div_result;
fscanf(fileread,"%s",password);
printf("%s\n",password);
character_count = strlen(password);
EDX=0;
ESI=0;
EDI=0;
EBX=0;
EDX=1;
for(i=0;i<16;i++){ // for loop 1
EDI=1;
for(j=0; j<character_count; j++){
EAX = password[j];
EDX = ESI+EDI;
EAX = EAX + EDX;
ESI = EAX;
EBX = EBX + EBX;
EBX = EBX ^ ESI;
EAX = ESI;
div_result = div( EAX, EDI );
EDX = div_result.rem ;
EDX++;
EBX= EBX +EDX;
EDI++;
} // end of for loop 2
} // end of for loop 1
if(ESI== 0x3810 && EBX == 0x402A4FE7){
printf("Word is = %s\n", password); // Ans: firmware
getch();
} // end of if statement
} // end of while loop
fclose(fileread);
getch();
return 0;
}
,
., ._ C -....-..



,.. .._..- source - - -.._-....._.._-_ -.
- ... .._-...-. C -....-.. - .- _ . - .-. ._-... .
. .._ . .._ . _-_ - --. ..._....-. ....- _.--.
<stdlib.h> header file - ._-_...-.-.-. div_t --
FILE *fileread = fopen("english.dic","a+"); .-.-.-. english.dic .- .-.. ._.-.
.-.-.-. -.-.-..- password (word) -. english.dic ..._..-.
Dictionary (.dic) ..--. password .- - - - . .. ..... . cracker .- ..__--..-_..
_ . . .- . . - - .. - .-.. .. . . . -. .-.. .. . ._.- ..- .
.. ._.. -. dictionary (.dic) ..-- -.--. download . Cracker -.
...- . ..-. - - .. _ - - _ .. - ..._.-...- -.....
... -.
char password[50]; -.-. .-......- --. . 50 ....... ._-_...-.
. 50 -_- -.-...- ._...... _....-. 50 ... 200 ._. .
- 200 -_- -.-....-. . ..- .-. - . -.
while(!feof(fileread)){ } -.-. english.dic .- .--. ..-...-..._. ...-.
..-.. .-. english.dic .- ...-... - .- .. ._.-.
fscanf(fileread,"%s", password); - ..__. english.dic .- ..-...- .--.
..-...- aaron .._-_-_-.. . password = "aaron" _.. . .._ password
- printf() function .._. ...._.. _..-. printf() function - ...-. ...
.-. - . . . _. . .. ._.. -.
character_count = strlen(password); -.-. password .-.. . .. ..- - - - - -
-. aaron _.. - - - ._.. -.
for(j=0; j<character_count; j++){ } -.-. password .-.. . .. ..- - .. -_ _ .
._. . .. . ... . ._.. - - - for(j=0; j< 5; j++) _....
. EAX = password[j]; - .-_ EAX - -.-.- integer (int) ._-_...-.
password - .-. character string (char [ ]) . ._-_...-. - . . C++ compiler
-.._.-.-.-. password[5] = "aaron"; _.._. EAX = password[0] = 'a' = 0x61; _.. -.
... . . - ... - "a" 'a' -. .--. "a" .. string - _.-._.._. 'a' .. .-.
character - _.-._..-. Character ...-. ...-..-_...._. string ...-.
...-.. ., -..-.-.
EDX = ESI + EDI; -.-. .._.. ESI EDI --...-- ..-.-. ..-.
EDX = ESI + EDI = 0 + 1 = 1 _.. -.
EAX = EAX + EDX; - ._.. EAX = 0x61 + 1 = 0x62 -.
._-. ESI -..-. 0x62 _.. -.
EBX = EBX + EBX; -.-. EBX = 0 + 0 = 0 _..-.
EBX = EBX ^ ESI; -.-. EBX = 0 ^ 0x62 = 0x62 _.. -.
EAX - . .-. ESI -.. _--- 0x62 _.. -.
div_result = div(EAX, EDI); -.-. EAX - EDI ...-. EAX = 0x62 / 1 = 0x62
_.. -.
EDX = div_result.rem; ...-_-.- EDX . . . . .-. ._-. EDX - . .-.
0 _.....-.
EDX++; ....-.._-. EDX -.... -...-. .. EDX - . .-. 1
_ _.. .-.
. EBX = EBX + EDX; -.-. EBX = 0x62 + 1= 0x63 _.. .-.
EDI++; EDI - -...-.._-. EDI -. 2 _.. .-.
_ . for(j=0; j<5; j++) - j++ --.._-. j=0 ... j=1 _.. ._ . ..- -. _- . for loop
- .._ -. for(j=0; j<5; j++)- _-. for(i=0;i<16;i++) - _-. ....
., ._ C -....-..



_- . . loop - _ .- . . .- ._.-.-. ESI = 0x2200 EBX = 0xBFC8757F -
_.. -.
ESI EBX -._.-. 0x3810 0x402A4FE7 - _ ._ .. _ . _ ._.. - - ..
-. . - aaron ... firmware - -.-.-.. for(j=0; j<character_count; j++){ }
- for(j=0; j<8; j++) _...-. for(j=0; j<8; j++)- ._-. for(i=0;i<16;i++) - _-.
. . . . ._- . loop - _ .- . . .- ._.-.-. ESI = 0x3810 EBX = 0x402A4FE7 -
_.. -. ,
.- _.. - - -.-. a = 0x61 b = 0x62 c = 0x63 z = 0x7A ..__._.._. A =
0x41 B = 0x42 C = 0x43 Z = 0x5A .._ _. _.. -.



., ._ Assembly -....-..
.


tcef;(3) - tajccH Assembly bmompum;
, .
--. .-. Assembly -....-... -. - -.- .._ .- ..-.-- .....
.-.-..-. -.- highlevel -....-...- .. . . -. .- - Assembly
.._--. Assembly -.--. .-..... instruction .-- ---..._
..-. .._
ADD EAX, EDX
instruction -. - .- . .. . - . ...-. EAX EDX -.-. register
.-. . - .- . . - . ..- . _ . .-- .-.... .....-. _.. -. - -
.. - hexcode, _..- 66 03 C2 _.. ._..--. .-..-. -.--.-_.
.--_- instruction - -. C highlevel -....-...--. .- -.
-....-...-- Assembly _..._..-. Assembly - - .- - . . - . ._. .-.
_.. -.
C -
>> Compiler > >
Assembly -
>>Assembler>>
Raw output (hex)
a = a + b; ADD EAX, EDX 66 03 C2
.... Assembly - -. . . . ..._.. .-. .- _. . . Output -.-. C - .
. -_ .-.
, -.._-. Assembly - .._-.
Assembly . . -. ..-.-. - -. . C ., _..-.... Assembly -
-. . .__-. ._.-.-. .-. Assembly -. .- -. .... _ . _. .
_.. -. . _ - -. -....-...- . . compiler .- -. - - - .... -
-. Compiler .- -. -. ..- .-. ....-.. _. .. ........._...
Assembly ---.... -. -.-- -. - ...... .. . .-. .... _ ._.
. - - - - ... . . ... . . - highlevel -....-...- - ..
. - -.
highlevel -....-...- . . - - - -.-. . --. ... ...
... - .- - - DLL . .- - . .. -. .._ Visual C++ . . . . .- . - ..
- C function .-- msvcrt.dll .-. -. ........_. .-. . ._.... -
- . ..-. DLL version - .- _ . - ..- -. ._-.. .....--. ..--
--... _.-.. ....-. Visual C++ --.-. -. ._.. .-.
. . .- -. Windows .. --_..-. ...-. Visual Basic -.-. .-....-..-
Assmebly - . .._. . ... - . Version 5 - -.-. _ .. _ ...
... __.-. .---., .--. Visual Basic Virtual Machine _.. - msvbvm50.dll
. - . .-. VB . . ..- - .- -. DLL .- _-...... ...-..--.
._-. VB -. .- -. .. ..-. Assembly -.-. _. . .-....-.. . -. Windows
.. DLL . .- _.. - kernel32.dll user32.dll .-..-- ..
.... - Assembly -....-.. -. ... . ._.. .-. .._.._--.
...-.-.-. - -. . -.- - -. ... ._.. . - .. -.-.-. .- - - . ..--
_-._-.......- Assembly ... . --. - - -. -. .........- ..-. _.. _..
_.. -. -....-...- ....- -. .- -. .. .- _. ... DLL ..-- .....
- . ... Assembly - .._--. ...-. ..- DOS Windows -..-..
_-._-.......-..- -. DOS -..--. function _.. interrupt .-- ..-.
Windows . ..-. Application Programming Interface .- API interface . . -. .-
- - - function .- -. DOS -. .- . ..-. interrupt .-.. interrupt
--. function - -. -. Windows . ..-. API funtion .- . . ._ .- ..
MessageBox, CreateWindowEx, -. . . DLL .-- import ..-. .-
-. Assembly ...-. .--.


., ._ Assembly -....-..



, Assembly ._
, Opcodes
Assembly -..-- opcode .- .-...-. Opcode . -.-.-. .- ..-
.._ . - instruction -. ..
ADD
ADD instruction -. - .- . .. . - . ...-. Opcode .... . . operand .-
-.
ADD EAX, EDX (destination, source)
ADD .. operand .. -. .._.... source -. destination -.
-. . -. source --..- destination -.. .._..-. _. - destination
. . . . .....-. Operand .- -. . .. ._.. . -. .. register .-...
- .- . .,
, Registers
Register ..-.-. 8bit 16bit 32bit - MMX .-...-.. -.
-., _..-. 16bit -..-.. .._.-.-.-. 16bit registers 8bit registers
.- _.. -. 32bit -. .- . ..-. 32bit registers .--_. .._.-.
register .--. _.. register .- . - . _.. -. .. --. EAX
.. EA7823BBh -..- _..... _.. register .-.. .- - . ..- -.-.
EAX EA 78 23 BB
AX EA 78 23 BB
AH EA 78 23 BB
AL EA 78 23 BB
AX, AH AL - -.-. EAX . - ..- EAX -. 32bit register -.
80386 - .-...-.. .._.-., AX . . EAX ..-. 16bit _. AH
...-. AX - ... . -. AL ...-. AX ..- ... . -. ._-.
AX -. 16bit _.._. AL AH -.-. 8bit ..- . ._..- ..-.-. register .-
- . ..-
eax = EA7823BB (32bit)
ax = 23BB (16bit)
ah = 23 (8bit)
al = BB (8bit) 100100011010001010110
Register .- - . ._ -.-.
low-level -....-.. high-level -....-..
mov eax, 12345678h EAX = 12345678h (305419896)
mov cl, ah CL = 56h (86)
sub cl, 10
CL = CL - 10
mov al, cl AL = CL
.......--- _._...- ....._-_-_-.. MOV instruction -.
-..-.- register -. .-. ., -.-..-.-. _.. register -..- ...
. -. ..- AH - . . EAX -. .- . .._..- ,- CL ECX register ..- . .
., -.--. _..-. CL -. 10 .--_. AL EAX ..-...,-
_ _ - -.
Register . ....-.-. ..._- . -.

., ._ Assembly -....-..




, .... register ...
EAX (Accumulator)
....-..... string ...- . . .._ . . .._
EBX (Base)
stack .... -.-.- ..._
ECX (Counter)
- ..... ..- . .._
EDX (Data)
....._. ...... _- .- . . .._ .._
.-.. ._.... ... _--. .._.-.
, Segment register ...
Segment register .-.-.-. .-. segment - .._ .. .-
- Windows ...-. ..... ...---. -.._-...-. Windows .. flat . - . ..
DOS . ..-. . - . - 64KB - segment .- _.. . - -. ._-. . . .
. - . address - .- . - segment offset - ..- - . 0172:0500
segment:offset,, .- . - .. Windows . ..-. segment ....-. 4GB .-.
-. ._-. . Windows .. segment .-- .-. Segment .- -. _. -. . 16bit register
.- _.. -.
.-.. ._.... ... _--. .._.-.
CS (Code segment)
- ...- . . .._ ...... . - . -
DS (Data Segment)
- - ...- . . .._ ...... . - . -
ES (Extra Segment)
-.-....-- ......_
SS (Stack Segment)
Routine .... ..... address ...- . . .._ . . ._... register
FS (286+)
.... segment
GS (386+)
.... segment
, Pointer/Index register ...
--. .-. . . pointer register .-- .-.-..- .._. . .. .-. .
... register .-_.. EIP .-., .._.-. Pointer register .-._-...-
.-. .-.--. ._-... .-. address - ...._.. opcode movb,
scasb,.., .--. .-- ..__--.
esi (source index)
string/array source - .- . - .- . .._
edi (destination index)
string/array destination - .- . - .- . .._
eip
(instruction pointer)
..- instruction address - ........._-. ---
._. . _ . Olly Debugger' .- _-_ ,
, Stack register ...
Stack register .. -. ESP EBP ESP -.-. . - . . . - stack
..- . . ...-. EBP - .-. function .-.. local variable .- .-.- pointer _..
.._-.
esp (stack pointer)
stack. --... ..-.- __._
ebp (base pointer)
stack- . ...... - fstack pointer . -..._
, . - .
....-. Windows .. .-..-- -.--.. .-.._..
, DOS & Win 3.xx
DOS Windows 3.xx .. .-- 16bit -. .- . . . - . - segment .-
_....-. segment .--. ......_. 64KB -. . - . - .. .. segment
pointer offset pointer --. Segment pointer - -. segment - .._...-.
___. offset pointer -.-. segment - ...- __-. ..-- _-_

., ._ Assembly -....-..




. - .
SEGMENT 1
(64kb)
SEGMENT 2
(64kb)
SEGMENT 3
(64kb)
SEGMENT
4(64kb)
.._ _.
. - ... .- - .-. ._.-.-. 16bit -. .- - - _.. -. .-...-
.-. . - . -. .- 64KB . segment .---. ... ...... 65536 segment
-. - segment -.- _-_-_-..
SEGMENT 1(64kb)
Offset 1 Offset 2 Offset 3 Offset 4 Offset 5 and so on
Segment - ..-. - _ . -. . .-. offset - . ._-. Offset . -.
segment - ..-. Segment -... ...... offset 65536 -. . - . -
segment - ..._.-.
SEGMENT:OFFSET
.._
0030:4012
.-.-.-. segment - 0030 _.._. offset - 4012 _..-. address -. -.
. -. . .-. .. . segment 30 . - . ... ._.. _ . segment - offset 4012 - ...
_.. -. . .. ,. .- .- - .-. - segment pointer register ._-. .. . _-
-. Segment register . .....- -.-.
CS (Code segment)
DS (Data Segment)
ES (Extra Segment)
SS (Stack Segment)
FS (286+)
GS (386+)
....- ._ .- -. . - ... - - . . - ... _-. CS . . -
.-- .-. DS -.-. - segment -- --.-- .... _..-.
Stack -.-. SS - _ .-. ES FS GS -.-. .... register .- _.. _ . -. segment
--.. ...-. Pointer register .-...-. ........_..-. offset -.- _...
-. ... .... register .-_..- AX BX CX DX . ._ . - - . ._.
-. IP - CS . , - .- instruction offset - __-.
..-.._..--.-. crack -.. Olly debugger .._.- register .-
.

SP -.-. SS -, - stack .. offset - _..-.
, 32bit Windows
16bit -.- -..- ........ segment .- -. . ._.. -. - .-. ...-
.. . 32bit windows 95 .-, ...-. _..- ._...-. Segment .- ....
., ._ Assembly -....-..



- .-. - . ...... . .-.-. -...-. .-.--. 64KB .--.-.
4GB _.. . --. segment register .---.- ._... _- .... .. . Windows
_.. -- .-. .-- . .. . - . . offset .-_. ...-. .-.--. 32bit .-
_.. -. ._-. . - -.-.-. ._-. 4,294,967,295 _.. .-. . - . -
-. .... offset _ _. -. -. 16bit -.. 32bit .-.... -..-..
.- - -. _.. -. ._-. . . . segment register .-- .. .... ._.
_.. register .-- .-.- __..-.
, Opcodes
Opcode .- -. .- ..- - instruction .-_..-. Opcode .- -. --. .-.
.. - . _-. . .- - .....' . .- - - ._-. assembler -. -. -....-..
.- . . . . .. _...-._.._. assembler ....--.... ..-_.. ---
._. . -. _.. -.
.. ..-. - - - . bitwise ..- opcode - .. ... .. ._.. -. _..
opcode .-_..- jump instruction compare opcode .-..- - .-. ..- .-. .. ... .. .
_.. -.
, ._ opcodes ---.
MOV
instruction -.-. -..-.- -...-. ..--. ..- . . - .. , . ._
-. ..' .- ...... register -. ... _ ..-. . . - . ..-. ... _ ..-. .
- .- . . . - . ., -. ... _ ..-. . _.. . -. mov instruction . -.-.
mov destination, source;
. . register -. - - . .-. - ..- -. . ..-. .- instruction
-. --. .-. . ._ move' ... - . .- ..- -. ... - .... - -.,
mov edx, ecx;
-.._- instruction -. ECX ..--..-- EDX . - ... - -. Source
destination . ...-. - _ .. ..- . .... _..- instruction -.-. .-. .-.
mov al, ecx; // ....
opcode -. DWORD 32bit, ..- -..-.- byte(8bit) ....- .. -
register ..-.- _._- .....-. - .-. mov instruction - ..._. .-.
_.. instruction .--.-. ...-., ... ..-- instruction .--.-. mov
instruction .. .._-. -.._-...-. source destination -. .... -_...
.
mov al, bl;
mov cl, dl;
mov cx, dx;
mov ecx, ebx;
.-.-_.- offset -. _ _-. . - . - -- ..-. -. - . .
-. - . _ . register -... -..- ... -. ..- ...- .._.. .
offset 34 35 36 37 38 39 3A 3B 3C 3D 3E 3F 40 41 42
data 0D 0A 50 32 44 57 25 7A 5E 72 EF 7D FF AD C7
- -. . ._ byte, ...-..- -...._._ ,
.... offset -..-. ...-..- -...._.... .-. 32bit .._..
3A - _-_ . -._ . 32bit 0000003Ah, -.._..-. .... ..._-
.--- -.._. offset .-- .._-. -.....-.-. hexcode .- _.. -.
....- offset 3A ..- _-_- offset ..- .-.-.-. 25 7A 5E 72
EF .._- _..-. Offset 3A .. ...-..- mov instruction register - . ... .
-.-.
., ._ Assembly -....-..



mov eax, dword ptr [0000003Ah];
Instruction mov eax, dword ptr [0000003Ah] .-.-.-. 32bit ....-
DWORD -..-.- EAX register - 3Ah ... . ..-. instruction - _.
..- . ..-. EAX .. 725E7A25h -.. ..-.-. .-... .-. 25 7A 5E 72,
.- -. ._. ._ ... .-. .- _. . . -. -.._-...-. . - . . . . . ...
--...-- endian _ . . .. . -.- _..- -. ... .-. significant _.. . .
.. . .. ..- . - . . -.-. ._. ._ .._ .. ._ .-. .._ . .
DWORD (32bit) -.. 10203040h - . - . . . . . .._ . -.-. 40 30 20 10 - . .-. .
-. .. .-. . (8bit) - -...._-.,
WORD (16bit) - . . 4050h - .-... ...._.-.-. 50 40
..... _-__-..
mov cl, byte ptr [34h] ; cl = 0Dh (....- _-_ )
mov dx, word ptr [3Eh] ; dx = 7DEFh (....- _-_ ._. ._ . -. .- )
. ...-.-. -- . . ..._- . - .
mov eax, [00403045h];
-.._-...-. EAX -. 32bit register -. _.. -. Assembler - . - .
00403045h ..-. 32bit -..- ... .-...-.
Immediate value -.-..,.-- .._.-.
mov edx, 5006;
-.-. EDX . . 5006 .- -..-.- _..-. .... - . . - -
.-. .... - . - . - . -_ .. -..-.- .. .._-.
mov eax, 403045h ; eax = 403045h
mov cx, [eax] ; EAX . - . .. 403045, - ... WORD . ... - . .- register CX
- _ ..._
mov cx, [eax] .. .-..-. EAX . . _ ..- - . . . - . -_ .., -.
..- . -. _-_ -. _ .. .. . - . - ... . - . .-. ..- . . -.
.._.-_. WORD (16bit, -.._-..... CX ._ 16bit register _......_-., - CX
_- -.
ADD, SUB, MUL, DIV
Opcode .-..-.......-. ---..- __--. . . . - ._ .-. .-.
......- ..-. ADD .._., SUB .-_., MUL ._..-_., DIV ..._ .,
.._ _.
ADD opcode .. ..-.-.-.
add destination, source
- - - . _ - destination = destination + source ..- . .- - _
-.
Destination Source Example
Register Register add ecx, edx
Register Memory add ecx, dword ptr [104h] / add ecx, [edx]
Register Immediate value add eax, 102
Memory Immediate value add dword ptr [401231h], 80
Memory Register add dword ptr [401231h], edx
instruction -. . .-. . -. source -..-._. destination - . .. . ..
..-. _. - destination .. ..-. _...... instruction .- -.-.
sub destination, source (destination = destination - source)
mul destination, source (destination = destiantion * source)
div source (eax = eax / source, edx = remainer
., ._ Assembly -....-..



. - _ .-. . ._ . - - ._. .- _ .-.-. dest = dest * source ..._ .-.-.
_._... ._..-. -.._-...-. register .--. -.__-...- _... .
-.- ..- ..- .- - - ., ... - - ... _- .. _ . - -. .._
28/6 ... =4, _-.=4
30/9 ... =3, _-.=3
97/10 ... =9, _-.=7
18/6 ... =3, _-.=0
...-. source ......-__. ...- EAX EAX . - .-. ,. .
..._. _-.- EDX EDX . - .-. ,. . . . .._ .-.
Source t &G, ft pm; pm;jci f; pm;v ' f t <u i f;
BYTE (8-bits) ax / source AL AH
WORD (16-bits) dx:ax* / source AX DX
DWORD (32-bits) edx:eax* / source EAX EDX
* .. -. _ DX = 2030h AX = 0040h DX:AX = 20300040h DX:AX ._ DWORD
-.._.._. DX ._ _. . WORD _.._. AX ._ . . WORD _.. ._ EDX:EAX
-.-. QuadWORD -.. 64bit, _.._. _..-.-. EDX _.._. ..-.-. EAX
_.. -.
DIV opcode source ... . _.. . -.-.-.
8-bit register (AL, AH, CL,...)
16-bit register (AX, DX, ...)
32-bit register (EAX, EDX, ECX, ...)
8-bit .-.-.. (BYTE PTR [xxxx])
16-bit .-.-.. (WORD PTR [xxxx])
32-bit .-.-.. (DWORD PTR [xxxx])
Source -.-. - .- . . ._.. . -. -.._-. . .-. .- ..- source operand
. ...- .. ._.- .
BITWISE OPERATIONS
instruction .- . ..-. 'NOT' instruction .--. source .-. destination -.
Destination ..- bit ....- source ..- bit .- ...-. Instruction .. -_ _ .
destination bit . . 0 ., 1 - ..-.
Instruction AND OR XOR NOT
Source Bit 001100 1100110 1
Destination Bit 010101 010101X X

000101 1101101 0
..
mov ax, 3406;
mov dx, 13EAh;
xor ax, dx;
ax = 3406 (dec) = 0000110101001110 (bin)
dx = 13EA (hex) = 0001001111101010 (bin)
Source 0001001111101010 (dx)
Destination 0000110101001110 (ax)

0001111010100101 (dx)
instruction _ .- ..- . ..-. dx = 0001111010100101 [7845 (dec), 1EA5 (hex)]
..- ..-.
mov ecx, FFFF0000h;
., ._ Assembly -....-..



not ecx;
FFFF0000 = 11111111111111110000000000000000 (bin) (16 1's, 16 0's)
. . bit -.- ._.._ .. .-.-.
00000000000000001111111111111111 (16 0's, 16 1's) = 0000FFFF (hex)
._-.. NOT operation _ .- ..- . . ECX - . .-.-. 0000FFFFh _.. -.
IN/DECREMENTS
.... instruction ..-.-. DEC INC instruction .--. .-.-_.
., register - -. . .... - ..-. . .....
inc reg -> reg = reg + 1
dec reg -> reg = reg - 1
inc dword ptr [103405] -> [103405] ...- -..- -.......
dec dword ptr [103405] -> [103405] ...- -..- -..-....
NOP
instruction -.-. . ._- .- -.. . - . -.. . . . .. - . .-. .
Crack ... .- .....-. ......-.-. -.-- patch - ... .
_.. -.
Bit Rotation and Shifting
. - ..- . .... _..- ...-..-.......-. 8bit -..-- ..-. ... .
.. .- _..
Shift functions
SHL destination, count
SHR destination, count
SHL SHR -. register.-...- bit .-- -._... .--_. .--._..-.
..
; .... al = 01011011 (bin) . ._-_ ..
shr al, 3 ; al = 00001011
.-.-.-. AL register - bit .-- _..- .... .--. ._-. AL -.
00001011 _.. .-. -. .- _. .- bit .- - . _.- ... . - _ . _..- - bit
.--.-. .....--. ...-- ..-.. bit - .-. carryflag . . . . ...-.
Carrybit . -. .- .. Flag register - bit -. . -. - - - - - . . -
. opcode .-..._., EAX ECX register -. .- - - . ... . ._.-.
instruction . . -_ .-. - ..- .. . ._.. . . . - ... .-.
-.-. carry .-. flag register - bit -._.._. .- . -. . -.- bit -.
. .. - - ..- . . bit -_-.
shl - shr - -. ... . - -. .- - . -.
; .... bl = 11100101 (binary) . ._-_ ..
shl bl, 2;
Instruction _.-..-...-. BL -. 10010100 bin, _...-. ..-.. bit . . . .
.-. . _.- _._ - -. Carry bit -.-. 1 _.. -. -.._-. . .-. ..- . .. ..
-- bit - 1 _.. .
..-...-. _.. opcode . . ...-.
SAL destination, count (Shift Arithmetic Left)
SAR destination, count (Shift Arithmetic Right)
., ._ Assembly -....-..



SAL - SHL - -. ... SAR -.-. SHR .- - . SAR - . _.-
...-. .--... MSB most significant bit, - - . -. ..
al = 10100110
sar al, 3
al = 11110100
sar al, 2
al = 11111101
bl = 00100110
sar bl, 3
bl = 00000010
Rotation functions
rol destination, count ; -. . _ ._
ror destination, count ; _.. _ ._
rcl destination, count ; Carry .-. -.. _._
rcr destination, count ; Carry .-. _.. _._
_ -.-. . . - _..-.-.-. ...-- bit .-- _...-- .-
-.
Oyr m/ / ror (rotate right)
Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
._.
1 0 0 1 1 0 1 1
Rotate, count= 3 1 0 0 1 1 0 1 1 (...)

1 1 0 1 0 0 1 1
... _.--. bit .--_--. .-.- -.--- bit - .-.
. _ . _...- - . -. . _ .. . carry bit .- -. ..- . .. .. - bit -
. . ...-. RCL RCR -.-. ROL RCR - -. . -_ . . - ._ .- - .
-- ._._-.-.-. .--. ..-.....-- bit - __.. carry bit - ..__-
-. ROL ROR - --. .-.. -_... ._--.
Exchange
XCHG instruction -.-. .._-.- ..-. .-. register .. ., register
-. . - . ..-. - . ... -.
eax = 237h
ecx = 978h
xchg eax, ecx
eax = 978h
ecx = 237h
, . ..
Assembly source ..-- section .- . ..-. Section .--.-. code data
uninitialized data constants resource relocations - _..-. Resource sections -
resource .- -..-. _..-. ..-.-_-_, Relocation section -.-. -.-.-
-- ..._-.-. ... -.- . - . _..-... . - .- ... PE loader --
- - .- .-. . . .. , .._- .- section .--.-. code data uninitialized data
constants - Code section . .-.-.-. . ..--. -.- Data sections
. ..-. .- .. - .-..- -. Data section -..-. exe ..._. .-.
.- ... -.
Unitialized data - - -.-. . .. . -.. .- . exe . - . - . ..-. .- .
. -.-. Windows -- .......- .-. -. . - -. .... _.. -. section . .
.. .- -. Constants -.-. data section - -. ... .- -.
section - constant -- .._...._. .-. include ... constant .- - ._-_...
.-. . . - _ ._. . .-. ..-.-- -.-.._.. ..


., ._ Assembly -....-..



, Section indicators
. source . .- . . . . section .-- ........
.code ; code section-. ..- .-.
.data ; data section-. ..- .-.
.data? ; unitialized data -. ..- .-.
.const ; constants section-. ..- .-.
- . .- (*.exe, *.dll, ...) -. Win32 ...-. PE portable executable, .
.._-.- ._-...- --..-- .... ....-........ .---. PE
header .- ....- ......._, Section .-- PE header .. ... _--
- . ..-. .- -.-. section name RVA offset raw size virtual size flags -
_.. -. RVA relative virtual address, -.-. section - - .- .... . - . -
.- . . - .. _.. -. ... . relative . - . .. - -. . . . - . . . -
base address .-...-.- ._.-. address -. PEheader . . .... PEloader
- ._.....-. relocationsection - ..__., Offset -.-. exe . - .. .
.-. . raw offset .._.. -. Virtual size -.-. .-..._..... .... _..
-. Flag .- -.-. .- . ... . .-..- - - flag .- _.. -.
, . . -.
-.-. . . -.
.data
Number1 dd 12033h
Number2 dw 100h,200h,300h,400h
Number3 db "blabla",0
.data?
Value dd ?
.code
mov eax, Number1
mov ecx, offset Number2
add ax, word ptr [ecx+4]
mov Value, eax
-. -. .-. ..-. . assemble . ..- - - . ... - . . - . . assembly
-... section . ... - .- .-. -.- .-.-.-.. exe . ..-.....
_.. -. .. ._..- data section .. label -. Number1 Number2 Number3
label .--. -.- .-... offset - .....-. ._-. . . -. . .
..-. - _ _. . -- .._.-. DD -.-. ... . - - - DWORD - . .
-.- ..-. DW -.-. word _.._. DB - byte _..-. DB . . . string
.-- .._.-. ._-.. string .-. byte -...--..- .-. _..-.
... _
33,20,01,00,00,01,00,02,00,03,00,04,62,6c,61,62,6c,61,00 (all hex numbers)
-..-.-. byte -.. _..-.,
- .-. . - . - .. _. ..-. Number1 - byte 33 . . - . ..
- _.-. Number 2 -.-. .. 00 ._.._. Number3 -.-. . . ... 62 ...
_.. -. - . . -. . .. .
mov ecx, Number1
--. . -.-.-.
mov ecx, dword ptr [.-.. dword 12033h -_ ...]
... -.
mov ecx, offset Number1
. -.-.-.
mov ecx, .-.. dword 12033h -_ ...
., ._ Assembly -....-..
.


.... . ECX -. Number1 .-.....- -..-.- ... -.
-. . ..-. ECX -. . - . .. offset, _...... ..--...... -_--...
-.
,
mov ecx, Number1
,
mov ecx, offset Number1
mov ecx, dword ptr [ecx] (..-- mov ecx, [ecx])
..- _ _-_ _-..
.data
Number1 dd 12033h
Number2 dw 100h,200h,300h,400h
Number3 db "blabla",0
.data?
Value dd ?
.code
mov eax, Number1
mov ecx, offset Number2
add ax, word ptr [ecx+4]
mov Value, eax
Label -..- Number1 Number2 Number3 - .._.-. ... .....
.-. . . . . _ . ... -.._-...-. .-. unitialized data section ..
-..-..-.-. data? .. .._-_.-..-...-. executable .. ...---.
. - . . ... . .
.data?
ManyBytes1 db 5000 dup (?)
.data
ManyBytes2 db 5000 dup (0)
(5000 dup = -... 5000. Value db 4,4,4,4,4,4,4 = Value db 7 dup (4).)
ManyBytes1 -. .-.- ... ...---. .-... .... 5000 ..
-. ... ManyBytes2 -.-. executable .._. .- 5000 bytes _-... -.
. . . . . _.- . 5000 .. .. -. . ..- .. - .
Code section -.-. assemble .- .- _.. _ . raw code .._.._., executable
. ...-. . .-. - .- . . . - . . ._.. -. ,
, Conditional Jumps
Code section ...-. label - .._ -.
.code
mov eax, edx
sub eax, ecx
cmp eax, 2
jz loc1
xor eax, eax
jmp loc2
loc1:
xor eax, eax
inc eax
loc2:
(xoreax,eaxr Smeax=0 .-.)
-- .._-_-_-..
mov eax, edx ; EAX .. EDX - ..-.
sub eax, ecx ; EAX - ECX - . - -.
., ._ Assembly -....-..



cmp eax, 2; EAX - 2 . .. -.
Cmp - instruction .. _.. -. Cmp -. 'compare' . .. -. . -. - . .
. . reg, mem, imm,- ..._. .-..-. _ Zflag - .-.--. Zeroflag -.
carry flag register - bit -._..-.
jz loc1;
-. -._ . .. -. _.. -. . -.-. conditional jump Jz = jump if zero
.-.- zero flag - .- . - - . . .-. . ..-. loc1 -.-. . - . - offset - -
label -. .. instructions 'xor eax, eax | inc eax' .-. ._-. . jz loc1 -. --.
zero flag - .- . - - loc1 ..- instruction . .-. . ... .
cmp eax, 2 ; EAX=2 _.. zero flag - .- . - . .
jz loc1 ; zero flag - .-.--f loc1 . .-. . ....
=
EAX -. 2 _ loc1 ..- instruction . .-......
..- -. -.-. jmp loc2 . -._ . jump -. ... .-.-. unconditional
jump . - _. -. ..-. ..-. .-- - C -....-.. - - _ .._
if ((edxecx)==2)
{
eax = 1;
}
else
{
eax = 0;
}
BASIC -. -....-.. .._ .-.
IF (edxecx)=2 THEN
EAX = 1
ELSE
EAX = 0
END IF
, Flag register
Flag register . . - - - . _.._.. - ..... -_ _ . .- . - _ ...- . - _ .
_- flag .- -. - .-. . .- - .- .. ... .. . .- - - . .._- .-.
- .. ... .. . _.. -.
ZF (Zero flag)
---.-. .__.. flag - .- . - -. . .. -. . -. --. .-.
. - _ .-. . ... _.. -. - . . .._ .. . ... flag .--.-. .-.--.,

SF (Sign flag)
--. flag - .. ---.- .- ..- . .- .-. . - _.. -.
CF (Carry flag)
- - - . _ .- ..- . ..-. . . -. .- -. . bit .-.
OF (Overflow flag)
- - - - .-. - - - .-.- ._.-. .-.- -. destination ..
..-. -. .. -.,- ._.-.
_ _.. flags (Parity, Auxiliary, Trap, Interrupt, Direction, IOPL, Nested Task,
Resume & Virtual Mode) .-_. ...-. ... -.-.- .._.. .-----
.-- ._.-... .---.


., ._ Assembly -....-..



, Jump series
..- . .... _..-.-.-. conditional jump -.--. - .-.--. flag
.- ._...-__. jump _--. ... .-. .-. ....... . . . . - - ._
.- -. . . -. jump - .-.-...-..-. ... .-. 'Jump if greater or
equal' (jge) - - .._ 'Sign flag = Overflow flag' _.. -. ..- -. -.-. 'Jump if
zero' .- 'Jump if Zero flag = 1' . ....
....- _ .
'Jump if above' . - -.-.
cmp x, y; // x y - ...-.
// --. x -. y - _- . jump ..
Opcode Meaning Condition
JA Jump if above CF=0 & ZF=0
JAE Jump if above or equal CF=0
JB Jump if below CF=1
JBE Jump if below or equal CF=1 or ZF=1
JC Jump if carry CF=1
JCXZ Jump if CX=0 register CX=0
JE (is the same as JZ) Jump if equal ZF=1
JG Jump if greater (signed) ZF=0 & SF=OF
JGE Jump if greater or equal (signed) SF=OF
JL Jump if less (signed) SF != OF
JLE Jump if less or equal (signed) ZF=1 or SF!=OF
JMP Unconditional Jump -
JNA Jump if not above CF=1 or ZF=1
JNAE Jump if not above or equal CF=1
JNB Jump if not below CF=0
JNBE Jump if not below or equal CF=1 & ZF=0
JNC Jump if not carry CF=0
JNE Jump if not equal ZF=0
JNG Jump if not greater (signed) ZF=1 or SF!=OF
JNGE Jump if not greater or equal (signed) SF!=OF
JNL Jump if not less (signed) SF=OF
JNLE Jump if not less or equal (signed) ZF=0 & SF=OF
JNO Jump if not overflow (signed) OF=0
JNP Jump if no parity PF=0
JNS Jump if not signed (signed) SF=0
JNZ Jump if not zero ZF=0
JO Jump if overflow (signed) OF=1
JP Jump if parity PF=1
JPE Jump if parity even PF=1
JPO Jump if paity odd PF=0
JS Jump if signed (signed) SF=1
JZ Jump if zero ZF=1
Jump instruction ..... operand -. .. -. -.-. jump .. .. offset
...- ..._-_ .. . unconditional jump (JMP) -. - .- . . . -.-. -.
. .. - - . ..- - - . Jump - . . .
., ._ Assembly -....-..



., - ....._-. . -.. -... .
-. -....-.. .-. .-. ....... . -.__ ..-. .._-.-. variable ._-_..
.. -_ -. Assembler ...-. .--. ..-_..-. ..-..- ---.- .
opcode .- _ -. - FPU (floating point unit) .- .-..- _
..-. ..-.-.-- instruction .-._-..- ..-... ........ ..-.
-.__.-._-.. ........ C . . signed unsigned -.._. ....-. Signed
. -.-.-. . .. - ..- -- -..-- .-. Unsigned -.-. _. -. . . .
..--..... -_......- _-_-_-.. ._... . ... . byte .._..
-. _....... --.,
-..
00 01 02 03 ... 7F 80 ... FC FD FE FF
Unsigned 00 01 02 03 ... 7F 80 ... FC FD FE FF
Signed 00 01 02 03 ... 7F -80 ... -04 -03 -02 -01
._-.. signed - .. .. .- .. . . - -. . .- . .- - 0 -.
7F .--..-- 80 -. FF _.. -. - . .- - . _ . - - . . = 0
7FFFFFFFh .- = 80000000 FFFFFFFFh .-_.. .--..-_- significant
bit - .- . - -. -.._-. . .-. . - -. 80000000h -_-. bit - sign bit
.-.
., Signed .. unsigned ..
. .. .- .. - . .-. -. signed .. unsigned .. .. . - . .- ..-. .
-. -.-. . . . - . . - .-. -. signed _.._.. unsigned _.._.. ..._-.-.
-- 4 + 9
FFFFFFFC + 00000009 = 00000005. (. -. )
-- 5 (9)
00000005 FFFFFFF7 = 0000000E (. . -. ) ( 5 9 = 14)
.-...-.-.-. .--. ._..-_. ..._. ..._.-.. ..-. ._-..
signed -..--- . mul div opcode .- -.
imul. idiv
mul - .. imul .. - ....--.-. ... -.-...-- ...-.
imul src
imul src, immed
imul dest,src, 8bit immed
imul dest,src
idiv src
.-.--. mul div --... .-.--. signed - . ..- .. - - - -.
...... unsigned -..- -_...._.... flag .-- .-.--..-. -_..
-. ._-. . signed unsigned -..--- -_..- jump instruction .- .-.
cmp ax, bx
ja offset
JA -. unsigned jump (Jump if above) ax = FFFFh (FFFFh unsigned, 1 signed)
bx = 0005h (5 unsigned, 5 signed) -- ....._-_ FFFFh -. (unsigned) - . ..._. 0005
- _. -.._-. JA instruction -. .-. ... . ... JG instruction -.-. signed jump
_.. . .-.
cmp ax, bx
jg somewhere
JG instruction -.-. jump _.... .---. -.._-...-. 1 -. 5 - ._- .
. - ... .-.-.
-.-.-. signed/ unsigned _..-..-.-.-. .. -.- --...
. -_ -.
., ._ Assembly -....-..



, ..- opcode ...
-.-. ..- opcode _..-.
TEST
TEST -. logical AND ...-- ...-_. dest src .- .._. .
.-__. flag register - .- . - -. - .-. - . - .. . .- . TEST - .._-..
-.-. .._..- - . register -.- bit -.- ....._..-.
test eax, 100b ; (b - .... -.-.- )
jnz bitset
--. EAX - -- .._..- bit _..-.._,- .-.-...- JNZ -.
jump _.. . .. TEST .... .. ._. -.-. register -.-. .__..._.. ....-
. . _.. -.
test ecx, ecx
jz somewhere
ECX -. . __.. JZ -. jump _.. . ..
STACK OPCODES
Stack opcode.- ._-...._._.. stack .-.-..-. ._.. Stack .-.
. - . - ..-. _.. _ . stack pointer register _..- ESP _ _-. Stack -. ...
- . ..- ... ..-. _.. -. . . . - . ..- - ... _ . . PUSH POP .-
instruction . . -. PUSH -.-. stack - -..-..__. POP -.-. . . -
-. Stack - ..-..._-.- -.-. -..-.- stack . . ...
stack pointer -. .._..-. .......-. stack pointer -..-.
..-_-_
(1) mov ecx, 100
(2) mov eax, 200
(3) push ecx ; ECX - . . .-.
(4) push eax
(5) xor ecx, eax
(6) add ecx, 400
(7) mov edx, ecx
(8) pop ebx
(9) pop ecx
..-
1: ECX - 100 - ...._
2: EAX - 200 - ...._
3: push ecx (=100) (stack . . .. ....-.)
4: push eax (=200) (stack .. ..-.....-.)
5/6/7: ECX - .- - ... - .- -. ECX -...- ._...-.
8: pop ebx: EBX -. 200 _.. .-. (..- . .... . . - . -. )
9: pop ecx: ECX -. 100 _.. .-. (.. .... ..- . . - . -. )
PUSH/POP _._. .-.. . -..-_..-..-._-_. ..-...- _-_

Offset 1203 1204 1205 1206 1207 1208 1209 120A 120B
Value 00 00 00 00 00 00 00 00 00
ESP
.... stack -. ... ._.- _._...-. ... --.--....-.
.- - - . ESP -. ESP __- offset - _ . -. ,
mov ax, 4560h
push ax

., ._ Assembly -....-..



Offset 1203 1204 1205 1206 1207 1208 1209 120A 120B
Value 00 00 60 45 00 00 00 00 00
ESP
mov cx, FFFFh
push cx
Offset 1203 1204 1205 1206 1207 1208 1209 120A 120B
Value FF FF 60 45 00 00 00 00 00
ESP
pop edx
Offset 1203 1204 1205 1206 1207 1208 1209 120A 120B
Value FF FF 60 45 00 00 00 00 00
ESP
.. EDX -. 4560FFFFh _.. ._
CALL & RET
Call -.-. -.-. .-...._. RETinstruction - .- - - . _ ..-
.-. . . . - .- - _.. -. -....-...- . . function .-_.. subroutine
.-_.. .-.-. ..
; ..code..
call 0455659
; ..more code..
; Code at 455659:
add eax, 500
mul eax, edx
ret
CALL instruction -.. .-..-. 455659 . . - - . .-. . .._ . RET
...-. instruction .-- -. _..-. CALL _.- instruction .-. __
-. CALL - jump _.....---.-. procedure .-. CALL -. EIP ..- _
_-..-- ..._ pointer,- stack . push -. _ ..-. RETinstruction - pop
_ ..-. . . CALL -- argument .- .- . - -. - PUSH _
. -.
push something
push something2
call procedure
CALL -....-. argument .-- stack -.- _ .. ._. -. Local variables
.-.- procedure - .. ... - .-...., .- - stack . .... -. - .-.
. .-- ....-........ .---. -...-. .-- masm Macro Assembler,
tasm Turbo Assembler, .. .--. .. procedure .-- _.-.
. -. . - .- -. parameter .- - . .-. . - .-. _ .._- .-.-. - -.-.
Procedure -. return value - _... EAX - _.-.... .._-.
.--. windows function .--- .--. ....-. .-.
procedure ...-. _..-. register - .. . ._. -. ... EAX -.-. .-._..
-. .-.... instruction -. ....- ._-.
lea edi, namebuffer ; EDI -. ..-_-- ._.... address _..-.
mov eax, dword ptr ds:[edi] ; EAX - ...... .....-. -.._-...-. DWORD
(4 bytes) -. .. . .. . _
, Windows . - .- ... Assmebly -....-.. ._
, API
Windows . . -. ....._ . ._ -. .- -.-. Windows API Application
Programming Interface, .- .. -_ .-. API . -. OS -_._......- function .--
. ._ .....-. Windows -.-.-. function .-- .._-. function .- -.
., ._ Assembly -....-..



Windows .. dll ..-_..- kernel user gdi shell advapi .- . .- . . -. Function
.........-. ANSI Unicode .- -.-. string .-- ...._.--.... .._
- _ .. .. . _.. -. ANSI . .-. .. .- .- ..- -ASCII - ,. ... __ .
string ..-..._. \0 (nullterminated)- .._-. Unicode -.-. widechar .-
..__. ..---..-- ........_-. . -.-. - - _. ..-....-...-
.....- -....-...- . .. ._-. Widechar string .--. \20 ...-.
-. Windows -.-. ANSI function _.._.. Unicode function _.._.. --. ..
_
MessageBoxA (ANSI)
MessageBoxW (W = widechar (unicode))
- .-. - -.-. ANSI - .._.. _..-.
, DLL ....- ...._.
Windows API function .-- .._. DLL ..-- import . -. .- -
import libraries (.lib) .- _.-. lib .--. .._..-. -.._-...-.
.--. Windows ..- DLL .- ... - .. . .. . _ . -.- . - . - dynamic
base addresse .., - includelib .._. library -.- _...-.
includelib C:\masm32\lib\kernel32.lib ..--,
includelib \masm32\lib\kernel32.lib ..--,
includelib kernel32.lib
. kernel32.lib - _...._.-... .... include library -. -_ .-..
.._-.-. .---. include file (.inc) - -. .--.-. l2inc -..._. library
.- -. ..- - ...-. include file -.- .._....-.
include \masm32\include\kernel32.inc
include file . . DLL - function .- - - prototype .-- ......_._..-.
._-. . . invoke - ..__. ..._
kernel32.inc:
...
MessageBoxA proto stdcall :DWORD, :DWORD, :DWORD, :DWORD
MessageBox textequ <MessageBoxA>
...
include file .. ANSI function .- --. function ._ - -_ .-.. ..
- 'A' .- function .- - . .. . ..-. _. . . . . MessageBoxA ...
MessageBox - ...-. ..... function .--- include library include file .--
._-_..- . - _ .. .. .-. function .-- .._ _
invoke MessageBox, NULL, ADDR MsgText, ADDR MsgTitle, NULL
, Windows include file
Windows . . . include file -._..- windows.inc .-. ... Windows
API - - - constant structure .. . -. .._ message box .. .....
-. Function .. ._..- parameter -.-. .- NULL - MB_OK - . _ . . -.
OK button _.. -. Windows include file . . .- . ..- - - . .. . . - .-
-.
MB_OK = 0
MB_OKCANCEL = ...
MB_YESNO = ...
...... ._ .- - . . constant . ...-.
invoke MessageBox, NULL, ADDR MsgText, ADDR MsgTitle, MB_YESNO
..-- include file - ._-_... . .-. ._-_...
include \masm32\include\windows.inc
, Frame
., ._ Assembly -....-..



. . frame -. - _-_ _-_ ..
.486
.model flat, stdcall
option casemap:none
includelib \masm32\lib\kernel32.lib
includelib \masm32\lib\user32.lib
includelib \masm32\lib\gdi32.lib
include \masm32\include\kernel32.inc
include \masm32\include\user32.inc
include \masm32\include\gdi32.inc
include \masm32\include\windows.inc
.data
blahblah
.code
start:
blahblah
end start
-.-. windows assembly source file (.asm) -- ._ frame -.
.486
Assembler - .- .. . .- - _. ,- - .- - ... ._.
-. . . .386 - .._.... .486 -.-. ...... .._.
.-. ..-. . . -.
.model flat, stdcall
Flat .-.- .._-. stdcall - .._-. .-.-
function .--- parameter .- - _..- -. -. .- - push
-. ..- . .- .. . push -., _.......-.
function -. stack - _ __ .... -. Windows API
function DLL .- .. . ..- - .
option casemap:none
Label --....--. _-.... _.... ...-.
windows.inc . .-...-.. . . . - 'none' ....
includelib
.. . .. ... ._ ._.. -.
include
.. . .. ... ._ ._.. -.
.data
data section .
.code
code section .
start:
end start
Label -. -. .- _ _-. 'start' .-. ...-.
. . _- - - .._ ... -. . .- .-. 'end' statement -
. .. .-. -.
.-.._ -.-.- ... -. -. - .._-_ .. ... . assemble .
- .-. - . ... ... . . . -.-. WinAsm Studio 5.1.5 Macro Assembler 3.2.7 -
_.. -.
.486
.model flat, stdcall
option casemap:none
includelib \masm32\lib\kernel32.lib
includelib \masm32\lib\user32.lib
include \masm32\include\kernel32.inc
include \masm32\include\user32.inc
include \masm32\include\windows.inc
.data
MsgText db "Hello world!", 0
MsgTitle db "This is a messagebox", 0
.code
start:
invoke MessageBox, NULL, ADDR MsgText, ADDR MsgTitle, MB_OKCANCEL or MB_ICONQUESTION
invoke ExitProcess, NULL
., ._ Assembly -....-..



end start
-.-- assemble (Go All) - .- . ..-. ,- . _.. -.

,
-. - . .-.
MessageBox . ._ -.-. (Win32.hlp - _-_ ,
int MessageBox(
HWND hWnd, // handle of owner window
LPCTSTR lpText, // address of text in message box
LPCTSTR lpCaption, // address of title of message box
UINT uType // style of message box
);
hWnd
. - ... message box owner window - .- . - -. --.
parameter -. NULL _.. message box . . owner window . ..- - - .
lpText
Message . _.. \0 . .- string - _.-.
lpCaption
. .. - - - \0 ..- string - _ .-. --. ... .
NULL . . default ...- .._.. _..-.
uType
Dialog box .- ..._.._.._. .....- flag .-..-.
2/
hWnd -.-. NULL _.. .. . -.._-. . .-. - .-. - -. . . window .
lpText -.-. -.-.-..... pointer . -.- parameter -. - .-. - .- . -
-...... .-. offset -. _.. -.
lpCaption -.-. . .. ..... . offset _.. -.
uType -.-. MB_OK MB_OKCANCEL MB_ICONERROR - - . ..- . .. ..-.
_.. -.

MessageBox -- string . . - _- - .- . - -.
.data
MsgText db "Hello world!",0
MsgTitle db "This is a messagebox",0
.data -.-. data section .- _ _-. db -.-. byte _.._. \0 . ..- ..
0 - _ ..-._.. -. ..- -. ._-. .-. ... .-. (13 = Carriage
Return, 10= Line Feed)
.data
MsgText db "Hello world!",13,10
db "I'm a messagebox",13,10
db "Hello again!",0
MsgText -.-. . string offset - ...-. MsgTitle -.-. - . string -
...-. ...-. .. MessageBox function - .._
invoke MessageBox, NULL, offset MsgText, offset MsgTitle, NULL
invoke - .._..-.._-. .. ..-.., offset ... ADDR -
. ._. -.
invoke MessageBox, NULL, ADDR MsgText, ADDR MsgTitle, NULL
., ._ Assembly -....-..



-.-.-. ..-.. parameter - -....-.-... .-...-.._-.
-. -.._-...-. MB_OK (OK button message box) - 0 (NULL) _
... .. _..-..-.. .._-.
,

uType ...-.-. , , -. _..-.

,
, Win32 API
Windows API . . Windows --- -..-.-... data type .- constant
.- function .- structure .--. -.-.-.._- ExitProcess API
function .-..-.......- .- DLL . _.. - kernel32.dll gdi32.dll user32.dll -.. ..
-.
KERNEL32.DLL Low level kernel services
GDI32.DLL Graphics Device Interface: ._.. ._.
USER32.DLL User Interface controls windows . messaging services
BOOL SetWindowText(
HWND hWnd, // handle of window or control
LPCTSTR lpString // address of string);
-.-. C . ....-. . . _ .._
PUSH lpString;
PUSH hWnd;
CALL SetWindowText;
, . .... Dialog Box -. ....._ .
-. . ..-. Windows . ._ .-_ ...- - .-. - _ . - .- -. .._-_ ..
..-. ._.., WinAsm Studio File menu - New Project - ..-
Project - Add new Rc - ..- _. Add New Dialog -.. ..-...-. caption
-. button . . editbox -. - . - . - _ . screen ..-._..- Resources tab -
. . Caption box - ..-._. 'Simple Dialog Box Program' - _ . toolbox - edit
button -.._. ,-. .
., ._ Assembly -....-..
.



,
_ . button ..- .-._. button .-.. 'Say Hello' 'Exit' _- ,

,
. F12 -._. -.-.-.-...- dialog box - -. _-_-_-..
;This Resource Script was generated by WinAsm Studio.
#define IDD_DLG1001 1001
#define IDC_EDIT1002 1002
#define IDC_BUTTON1003 1003
#define IDC_BUTTON1004 1004
IDD_DLG1001 DIALOGEX 0,0,170,72
CAPTION "Simple Dialog Box Program"
FONT 8,"MS Sans Serif"
STYLE 0x10cc0000
EXSTYLE 0x00000000
BEGIN
CONTROL "",IDC_EDIT1002,"Edit",0x50010080,10,9,121,19,0x00000200
CONTROL "Say Hello",IDC_BUTTON1003,"Button",0x50010000,17,46,51,16,0x00000000
CONTROL "Exit",IDC_BUTTON1004,"Button",0x50010000,102,46,50,16,0x00000000
END
- .-. - . Dialog Box template -.---.-- ..... dialogbox
editbox button --.-- ._.- control ID .-- .... -. - resource
script ... . ._-. .. . .- . -. _ . dialogbox.asm -.._. ..--.--
- _ -
option casemap:none
include WINDOWS.INC
include user32.inc
include kernel32.inc
includelib USER32.LIB
includelib KERNEL32.LIB
DlgProc proto :DWORD,:DWORD,:DWORD,:DWORD
.data
Message db "Hello World", 0
.data?
hInstance HINSTANCE ?
.code
start:
invoke GetModuleHandle, NULL
mov hInstance, eax
invoke DialogBoxParam, hInstance, 1001, NULL, addr DlgProc, NULL
invoke ExitProcess, eax
DlgProc proc hWnd: HWND, uMsg: UINT, wParam: WPARAM, lParam: LPARAM
.if uMsg = = WM_COMMAND
mov eax, wParam
.if eax = = 1003
invoke SetDlgItemText, hWnd, 1002, ADDR Message
., ._ Assembly -....-..



.elseif eax = = 1004
invoke SendMessage, hWnd, WM_CLOSE, 0, 0
.endif
.elseif uMsg = = WM_CLOSE
invoke EndDialog, hWnd, 0
.endif
xor eax, eax
Ret
DlgProc EndP
end start
,
-.-- exe ._..._..- ,-. .-..
,
, Keygen -. ....._ .
. ...-.-. cracker .--- .._-.-. -.._-...-. cracker .-
-- keygen -. .._.. .. Keygen ... .....-. ....._.-.-
registration -- -... .. keygen - _-_ .,

.,
.-.._ keygen - ..._-_-_-.. WinAsm Studio -.-_. ..--.
_. .. - , Edit control .. static text .. button .. ..

,
., ._ Assembly -....-..



Static text ..- SS_CENTERIMAGE ._...._. Serial editbox -
ES_READONLY ._.. Dialogbox -.-. DS_CENTER ._. ._ . keygen.rc - . . .
._ . _ . .-. keygen.asm .. - .-- ..--. -_ Main body .. -_..
-.-. 0001
0001 .386
0002 .model flat, stdcall
0003 option casemap:none
0004 include windows.inc
0005 include kernel32.inc
0006 include user32.inc
0007 includelib kernel32.lib
0008 includelib user32.lib
0009
0010 DlgProc proto :DWORD,:DWORD,:DWORD,:DWORD
0011
0012 .data?
0013 hInstance HINSTANCE ?
0014 NameBuffer db 32 dup(?)
0015 SerialBuffer db 32 dup(?)
0016
0017 .const
0018 IDD_KEYGEN equ 1001
0019 IDC_NAME equ 1002
0020 IDC_SERIAL equ 1003
0021 IDC_GENERATE equ 1004
0022 IDC_COPY equ 1005
0023 IDC_EXIT equ 1006
0024 ARIcon equ 2001
0025
0026 .code
0027 start:
0028 invoke GetModuleHandle, NULL
0029 mov hInstance, eax
0030 invoke DialogBoxParam, hInstance, IDD_KEYGEN, NULL, addr DlgProc, NULL
0031 invoke ExitProcess, eax
,
..- --...-.-. Dialog procedure _.. -.
0033 DlgProc proc hWnd:HWND, uMsg:UINT, wParam:WPARAM, lParam:LPARAM
0034 .if uMsg == WM_INITDIALOG
0035 invoke LoadIcon, hInstance, ARIcon
0036 invoke SendMessage, hWnd, WM_SETICON, 1, eax
0037 invoke GetDlgItem, hWnd, IDC_NAME
0038 invoke SetFocus, eax
00399 .elseif uMsg == WM_COMMAND
0040 mov eax, wParam
0041 .if eax == IDC_GENERATE
0042 invoke GetDlgItemText, hWnd, IDC_NAME, addr NameBuffer, 32
0043 call Generate
0044 invoke SetDlgItemText, hWnd, IDC_SERIAL, addr SerialBuffer
0045 .elseif eax == IDC_COPY
0046 invoke SendDlgItemMessage, hWnd, IDC_SERIAL, EM_SETSEL, 0, 1
0047 invoke SendDlgItemMessage, hWnd, IDC_SERIAL, WM_COPY, 0, 0
0048 .elseif eax == IDC_EXIT
0049 invoke SendMessage, hWnd, WM_CLOSE, 0, 0
0050 .endif
0051 .elseif uMsg == WM_CLOSE
0052 invoke EndDialog, hWnd, 0
0053 .endif
0054 xor eax, eax
0055 Ret
0056 DlgProc EndP
,

_ . .-. serial number - -.... Generate procedure - ....
0058 Generate proc
0059 invoke lstrlen, addr NameBuffer
0060 test eax, eax
., ._ Assembly -....-..



0061 jle NOINPUT
0062 mov ecx, eax
0063 mov esi, offset NameBuffer
0064 mov edi, offset SerialBuffer
00655 @@:
0066 dec ecx
0067 mov dl, BYTE ptr [esi+ecx]
0068 mov BYTE ptr[edi], dl
0069 inc edi
0070 or ecx, ecx
0071 ja @b
0072 NOINPUT:
0073 Ret
0074 Generate EndP
0075 end start
,
-._. ,.. _..--.-- .._-_..
..._-. .. . ..- -.-.-. uninitialized string .-_.._. -.....- -_-
._ - - - ... serial - .... _..-.
Generate function -.-. ... _..- routine -. Name editbox .. -_--
.....- ._..__...-. lstrlen -.-. Name editbox .. ...-....-_..-.
.. -. - _ - - ......- - NameBuffer ...._. ....---.-. EAX . ._
-. --. -... .. . - _ .-. NOINPUT ...-.....
--. -_--....---. ._-_-..-. EAX -.. ..- - -
mov instruction .._. ECX _ . . _.. -. ECX -. ....-- .--... ..-.
NameBuffer SerialBuffer - .-. address .--.-. ESI EDI . . . . . .-.
register ..-.-. string .- - - - . - source destination - _..-- .._
-.
@@ -.-. ._. label - ._-_... .. .-. Routine _ _- ..- . ..-. . . .- . label
. .. .- . .__-... jump .........- loop .........- - - - .-. label ._
. .- _-- . --. label .... @f - .. . .. label ...-.._.._. @b
..-. .... label ...-_.-.. _..-.
String - ._.._..- routine .. -.-. .. . counter _..- ECX
- -..---. ._-. ..-.._-. loop .. -.... ._...--. .-.
- --. Name string ....---. ._.-.... ECX -.- . 5 _.. . .._ .
5 -. ._ routine -. ._.-_-.-- .-, ....., ESI ...-. NameBuffer
... . address ..._.._. ECX=0 _.....-. ESI+ECX -. ....-_.._.._.
ECX=5 _.. . ..-. ESI+ECX -. ..- . ... .- _ . . . mov instruction -.-.
NameBuffer ..-..-.....- EDX register ..-._..- DL - - ._ - -.
- . mov instruction -.-. .- ...- SerialBuffer ... ... - - ._
-. EDI .. ...-., ....-- ._..___. _.... ECX -. . _...-
logical OR - ... - _ . zero flag - .- . - -. Zero flag ._...-. @@ - ..-
..._. routine - .._..-.
-.-. ..- .._. .. API function .--.._. _.__.- routine .- ..
....-.
_..-. -.-.- keygen -. - ..- .- . .- _ _-_ . -.

., ... . protection



tcef;(4) - aqmhzf0Jvf protection
(_....- ......- -...-....- _. _. ......._ ... _.. ._ -. .....
- .- ... . - ._ ._ _ ...._. protect ..._- ......_._..._ ._.
crack ._- _.- ........_ .--)
-. . ...-.-. crack .. . ._.. .._- .-.. .... protection ._-..
_.. -. . .._ ... .- .. ...-......_...- protection .-. ....-..-
-- .-.. -. - . - .... . .. ._ . ... . . . -. . . _. .. -.
..-. ...- - . - ... . - -. . crack ..-._-.. ._. .-. -. . .-.
.. cracker -.._..- Lena151 -.-. -. . crack .._...- ....-.- .....
._-.. ... .-.- __. crack .._-.. ..-.,
... ...... protection .-. pack _. protect -.- ._.-. .---.
pack _ . protect -_.-.-. Packer (Protector) ...' ...- . .. ... .. . _.. -. ,
-....-- --... .-. .-. ......-. . - ... . .- - protection
.... . .._ .. . .- ...- _--. Protection - .-.. ....._. ._.
. - -. .- . . _..... . ._-.- - - - protection .- --.. ..._--.
.. My Driver 3.11 . registration -- .-.. -_... registration ...
- -. .. .. _. -. . . .. - . - _- . _- . register .-., ._-..
. - -. .- - . - . . protect .._. . protection . .....- -.
_....- .....-... protect ..-. -..---.,
Protection . .....- ._-. . . . .. crack -. . - .. _. . . . --.. .
-. ...- . -. ._._-- ... . protection ..... ..-. .--.-.
, Registration number .....__.
, _- . - .- - .._ .
, Key . ... . .__ .
, Hardware key Dongle, .....__. -_..-.
, Registration number .... .__ .
Registration number .....__. -.-_. ,. . _ . _... -.
, Registration number .. . ...._ .
, Registration number ._ _ . .....-... -_ _ ._. . _ .
, Registration number ._ . .. . - -... -_ _ ._. . _ .
, Registration number - Visual Basic ..-- Delphi -...._. __-_.
, Registration number - .- .. ..._ .- _.. -.
, Registration number .. . ...._ .
_.-.._..- -.. ....-..-. registration number - - _ .
-. Registration number - . ....-.._-. cracking - . -. ...- -. registration
number - debug _. .-- ....-.-. ,

,
., ... . protection



_.-..__. -..-..-.-.-. _.._..-- .._-.-.. _-
-.-..-- memory . . .. . .._ .- _.._ ..- XOR _ . . .- - , _ _ - - -
_ . _ . .. . - - registration number - _ _ - - - _ . .- .- -
_ _ . .. . .. --. .-. registration number .- .--. __. -
.. _ _ ._. . . cracker .- .._ . . . - - . .- ---..-- ._
..
, Registration number ._ _ . .....-... -_ _ ._. . _ .
_ .-.-. ._-. . ._. _-- _ . _ .. ..-. registration number - .-
_ ._ ., -.._ ., _..-- .- - _._ . . _._ . . - - .-.
.- .. -_ _ . registration number -._..... ,

,
-...-. .-_- _.. cracker .--- protection - .-...
. - .. . . -. _.. _.. -...- ---._....-.... cracker .-
. -.-. . - - registration number - . -. - .- - ..- ... _- .. .
, Registration number ._ . .. . - -... -_ _ ._.. _ .
_ .-.-. cracker .--- ...._....- ..... -...- cracker .
._-..-.._-.......--. -.. .-. . - -. . - - -.. . -. register
. -.._-...-. registration number -. .. hard drive serial
number ..-__., ._... , .._-...- registration number - .....-
routine - .-.._. ...-... --. routine - .-... .-- ...-
._.._. -.- -..-.... -_- registration number register . ,

,
, Registration number - Visual basic ..-- Delphi -. ..._. _ _-_ .
Visual Basic VB, ......- registration number - crack -.-. ..--.
-. . .-. -. -....-..- . - - - high level _.. . - .-. - . crack
. - - debugger disassembler, .- - . .-._.. - - - high level _.....
debugger - assembly -_..._....-. -.. ._-. VB ....- -. .-
., ... . protection



- debugger .- - -..._ .._ . - .- assembly - -. .. - . cracker .- .._.
- -.
VB -. .- - . ,. _... -.
, VB4
, VB5 . -
, VB5 .- packed code (p-code) _.. compile .....,
, VB4
. .. . .-. .-. ......- - .. .. ... VB4 -. -. .- . ..-. . - .
_.-. .-_-- cracker .-.-. registration number - . . - . ..-
.-. , -.._-...-. VB4 -. .- -. ........_. -..-- registration
number _- - .- . - ..- registration number - .... vb40016.dll ., vb40032dll
.- .._

,
, VB5 .-
VB5 -.-...- -.- crack -.-. VB4 . .. .-. .. - .
-. Cracker .-. .-. ......-. VB5 - debugger .- debug . . _ .. - ._-- .
-...-. -.--. .-. .._.. - _ ..-. ._..-.- . _ . -
-. .- - crack . .-_....--.-. ....-..-_....- registration number
- .. - .._ . keygen ... ......_ .- . ._ , - .. . . . .- . registration
number - _..... -.-- __ . . .. _ .- .. _ _-._ .-. . . cracker
.- -.. keygen .-- ....._--. Cracker .-_-.....-. VB5 -. .- -. ..-. _-..
-. -...-. keygen .-... -
. .--.- -....--. .- -..-- VB -. ..._-.
- .-. . . .- _ -.- VB -..-- debugger .- -_...-_. Debugger .-
- _ ... -.-. - - - - _...-- ._.... .-...._..-- cracker
.- - ... .- ._--. _ .-.-. Smart Check VB Decompiler tool .- -_
- .- - _ ... _-.-. . . _ ...---. -...- .-. . - .. .
.-. compile . .. soucre -..---- .. _.....-. tool
.--.-. debugger ...- decompiler .. .._--. tool .--. VB6
.-. ..-. . decompile . -. tool .- .-._. VB ......_-- -. ...-
-..--_-_. Microsoft - VB -....-..- .--._...._. ..-.-.
._-.. VB -. version 6 .. -.-. .- ...- Visual C++ -.-.
-.. version 9 -._. ....... _...--.
VB -. .- - -. . . ..._-.-. - -.._-. ._.-. . . .-. .
.... .--... VB -. .- -. . . ....- . . - . . .. ... _. ...
. ..-. - . . ... . .- ....-.- VB ......_-- .- --.
__-._..-..-- .. . .. .. _.. -.
, Registration number - .- .. ..._ .
-. .- -. registration number - .-.-_.-.. .._... ..- . .. _ .
_..-- .._._--. Registration number - - . . - -. - - .. ....
- - -.- --. - -. ..-.- - . .. - .. .. _ . ._-. ._ -.
-. -.-. . - . . register .._. . .....-. , . .....- -.- .
_ .-. . - . - - - .- _- - cracker .--.-. .-- ......-.
., ... . protection





,
, _-. - .- - .._ .
-.--- -..--. .... _..- -..-. _ . . .. ...
-. _ . -.- . -.-. . _ ..-. ..- . . - . -. . .-. cracker -. ...-
-. - .- - - .. .. - -.- -...._. , Unregistered
version .-.. .........- -.-_.- _. .._... -. .......
-.- ....-. registered version - ...._. ....- ........

,
-.--- _.... ...... _--. _.. . -..- -.-.
, .-... registration number __._. -.--- ...._.
, Registration .__._. -.--- ...._.
, -.--- ...._._. full version - ....._. ..... __ ....
_.,
, -.--- Visual Basic _......_.
, ....-.--- ... ._ _- . .- - . .. .- . - _ .
, . - ... registration number _ _ ._. - .- - - .. .._ .
_ .-. registration number _. -- .-- registration number - _ ..
- -.--- ......... , -_..-.-.-.-. .-- registration
number ._ . .. _..- -..-. . ..- -. - .... ... _
--.
.- _. .-.-. -. - ....... . .. . -. - .- . .. - .- registry
..--, .-.... ....-... ..--.-. ....- .--. -.-
..-.-- -.--- .-.........
., ... . protection




,
, Registration . _ _ ._. - .- - - .. .._ .
_ .-.-. . . .. . .. - ... .._ . . ..... - - -.-. registrati-
on . - -.- -. . . . Cracker .--. -.--- ....- routine - .
-........ ._-. . -. --.- . . .. routine - _ . .. ... -
.. Cracker -. ...- -. . - - registration .- .-.-. ., -. . .-.
. .-. ..- . - - . -.- -. . .- - .- - routine -
.. .._ . _.. -.
<IDA Pro key file v5.1>
rhythm, 1 user, professional edition, 3/2009
#d@*^aRAj-ky0-
.,
-. .....- . . registration . - -. directory ..- . . . . . .
.-- .-..- . .....- function .- ......
, - .- -- .. .. _. full version - .. .. . _ . . .. .. __
...._.,
Demo version -. .- -.-. _ .- . ....-. -. .- . .. registration
number - _ .- . .- -. .- . .. -. - .. .. ..-. - . . ..
-. - ._.. .. . .-. .. .. POPCAP - . .... ,

,
Cracker .- -.-. - .- - routine - ._ . -. - - - - - .-. -
-. ._-. -. -. .- -. .- .- .. ......-. . _. - .-. -.
, - .- - - Visual Basic _. ....._ .
_ .- .- . . -. _.. ...__-.-.-.
, ....-.--- ....__-..--... .-.-_.
_.-. _..-.--_..- ._.._. -- ... .- ...-
.- .---... ...-_-.-.. .--_. .--_.- cracker .-- ...
., ... . protection



.- .-..-...-. -...-. -.-. - . - . .. .... ..-.- ...-_-.
.---.. registry ., .-... ...._.
, Key . ... . .__ .
_ .-.-. ........_. key .- ....- install ..- directory ..- . .
.. -. -. -. . . .- ._-. ...- - .- .. ...-. --. .. key
.-. .-... -.-. registered version _.. ...--. --... key
. -. ..- - . ... .... . -. -. unregistered version -....-_. ., .
. - . . .. key ... .... -.-- - - .- - ...- .-. .
. . ..
.....- , . _ .. .. -.
, .-....- ..._- ...-...- ..._... -.._...._.
, .-....- ..._- -.- -.-- .._.
, .-....- ..._- ...- ...- ..._... -.._...._.
_ .-.-. .-. .- _ . Cracker .--.-. _.- ._--_--. ...
_.._..- _.-. .....-. _....-. .-- key .- ..._
- .- - . .._. .. -.._....-. ..-.- _... -.-. key .- -._.
. - . . - .. -. _.. -. , ._-. cracker -. routine - - . - _ . -.
-_..._. ., registration . -_...-- routine . . .. - -.

,
--. .-. _.- .._... registration .- encode .-. ...
cracker -. registration .- .-- ..-.... _..-.
, .-....- ..._- -.- -.-- .._.
Antivirus -.....-.-. _.- ..__--. .-- registration .- ..
._ -.-. unregistered _.._. -.-- .._..-.
, Hardware key Dongle, .....__.
Hardware key .- -.- . _ .-. _.._ .. .-. _.._. .._.-. .-.
-.- -.-.-._._..- dongle - --. I/O .-.. -._. .._.. -.-
run ....
. . ..-. -.- . _ . ,. . -.
, Hardware key .- -.- ..-._.
, -. ...-- hardware key . . ._ ..._ .
HASP Sentinel -.-. ....... hardware key .- .-. .. ..- ._.
-.
., ... . protection
.


, Hardware key .- -. - ..- . _ .
hardware key .- -.-. .-. .-. . .-. -. - .-.- hardware key
-..- port . --. _..-. ._-.._-.- ...-. --. -...-_-.
..-. error message .. . .. ,
_.._.- hardware key .--.-. -- .-.- encode - -.
. .- - hardware key .- . . EPROM .- .. -. _ . hardware key .- . . -.
-. . - -. ..- _ . ... -. . cracker .- . . -. .-. hardware
key . protection - .........- ..

,
, -. ... - - hardware key . . ._ ..._ .
_.-.-. ..-. hardware key - .. . . -. - _. .-
.... -. .....- .-. -...-. -. ...
...-.-- hardware key .. --_. _.... _.-.-. .-...
-. Key .--... .-. function .-- decode . - .- .-. -- -.
Encoding -.. .-. .. .. . protection - key .- ......-. ._...-.
HASP key
HASP key - Aladdin Knowledge Systems - - -. HASP -. ... . -
install .. hardware key -.-.. .-. driver .-- install -.

,
Sentinel key
Rainbow Technology (www.rainbow.com) . - -. Sentinel -. HASP
--. ,

,
., Cracker -..-- ... tool ...



tcef;(5) - Cracker wpfOD;twGuf vdktyfaom tool rsm;


Cracking ... .--..- tool .- -. tool .--. .....
_..-. --......-..-....... .. .-. . . . .- - - . ... . ...... .- .-.
-. . . . . . _.. -. , tool .-- ...-.. ...-.-. ......
.._. ....-., tool .- ...-..... .- cracker .-..-....-
_..... _..-. Tool .-- ..--. ..._.._. ........ _..-. . - -
... _ tool ......._ Windows .. . . OS ...- - .. _.. ._ - OS ...- - tool
...- ..._ ,
-, Disassemblers
, Decompilers
-, Debuggers
., Hex Editors
, _.. tool ...
-, Disassemblers
, Disassemblers . -.-.
Disassmebler .-. assembler . - .- _.. -. Assembler - assembly -...
.-.. ....- - .- - . . .. . . machine -_..._.... disassembler -.-. . .
-.-- assembly opcode - _.. _ . - .. _- .. .-.
Assembly -....-...- . ..-. . ._- .- .... -_ _ . .- _ - instruction -
.- -. Disassembly .. -.-. . . -. Hex -.---.-_. .--_-
opcode - _.. -..._ ..-. .. 55 1010101, . PUSH EBP .- instruction ..
disassembler -. -.
Disassmebler .-..-.......-.-. assembly instruction --..... Intel ., AT &
T ., HLA . - ... -.
, Professional tool ...
IDA Pro 5.6
IDA Pro -.-. ..._-.- tool -. _.. -. Cracker .---.-...- tool
-._.._. - feature .- - ..._.. -. IDA Pro Professional edition - -
$1059 --. Download .- link -.-. ..--._..-.
http://www.datarescue.com/idabase/
PE Explorer
PE Explorer -.-. .._-. ...-. .-.- .-..-. IDA Pro -
feature .-__..... $75 . - .... .-.-. . - -.
http://www.heaventools.com
W32DASM
W32DASM -.-. Windows - - .-. .. . 16/32 bit disassembler _.. -.
http://members.cox.net/w32dasm/
, Freeware tool ...
IDA 3.7
IDA 3.7 -.-. DOS GUI tool _.._. IDA Pro .-.---.-. Z80 6502
Intel 8051 Intel i860 PDP-11 x86 intsruction -..-....-. 486 .- ..
-.
http://www.simtel.net
IDA Pro Freeware 4.9
., Cracker -..-- ... tool ...



IDA Pro . ..-. . . .... ..-. ... Intel --- x86 .- ...- - -
assembly - - ... _ . Windows . ... -. Disassemble instruction .--.-.
.- . - - .- ...- - - .. _.. -.
http://www.themel.com
IDA Pro Freeware 4.3
-_.... version .--.-. GUI .-. ..-.
http://www.datarescue.be
BORG Disassembler
BORG -.-. GUI _.. _ . .-. .. . Win32 disassembler _.. -.
http://www.caesum.com
HT Editor
HT Editor -.-. Intel x86 instruction .-- analyze - disassembler _.. -.
..-..- version -.-. Windows .. .- console GUI -. _.. -.
http://the.sourceforge.net
diStorm64
disStorm -.-. open-source _.._. 80x86 AMD64 .- ...- - - _.. -.
http://ragestorm.net
, Disassembler .-.-._ ..-......
- . .-.- . ._.._.. .._ .
.-. -,.--. exe ... binary .-.. . . .._ ...-.._-. ... .
....-. _...-. Disassembler -. - .. .-... -. ._... .---
...-..-. variable -. .. . .- - instruction -. .-._.....
--. .. .-..- - exe . .data section .... -.-- .code section . .
.. _... - . .-..- - .code section ---_.... .. jump address
tables constant strings, exe -.-- .data section .. ...._....-. ....
.-...-. -.- _..._-.._- -... .. _- .....-. ,
Disassembler .-. .-. ......-.-. . .. . .- - - _.. .. .-._.. .. - segment
.- - ._. . . . . .. ....-. ... disassembler .- -.-. . ._.._.. ...
..- _ . ..
exe -. -. - .-..- - _.._ . ..- ._..-.-. -. - . _..
... . - -. - ..- . -.-. disassembler -. -....-- - .-.
.- - . - . . _.......-. ._...-. Rice . . -. .- - .- - .-
_. .-......-..- .......-. .._.-....... cracking _. -.
. .. . - .- - .- __ . - .-.
- - ... . . ._ .
-.- compile . . - - .-. .-. ...... ..- . .- -. . .._. C
- - - . local variable ._.--. .-..... ..-..--. Compilation -
debug option - _ . .. . function .-._.- variable .- ._.--. image
-. . . .-. . . -. ... ..- -....- - stripping .- process -.-
. .- -. . -. .-. .... compiler .- -.-. _ ... ... .-. . .. . .. - .-
- comment ...-.-. compiler - . -. ... . .. . ....- - .-
inline function -. _.. ....- - .- C-preprocessor macro _......--.-_-..-
-_.._.....-.-. .._.-.... ._.. . - . - . .-. .-. ....... ..-. function . ,
variable .- lexicographical scope - . ._.- . . -. ._.. . - . --. .. file1.c file2.c
.-...- - compile link ... source ..-_-..- delineation -. linking
... ..--......

., Cracker -..-- ... tool ...



, Decompilers
Disassembler ..-- decompiler .--.-. exe -.-- high-level -....-..
- . _ - ..-._.. -. ._-.. . high-level -....-..-. C _.. .-.
-.._-. . .-. C -. decompilation ... .-....... .-. .-. .. . ._ . . .-
.-. Decompilation ... ..._.-. _..-. -.._-...-. compila-
tion --_.-- --.-..-.......-. ..-..... _..-. .-- decompi-
lation - _ _ .... ... . . .- - - . Decompilation _ ._.-. .. _. ....- . ...
-.-. .-. ..-. ._.. .
Decompilation ...
Compiler .-......- ..-.-.. decompilation . _........' ...
.-.-. . .- - - . ._.-.-. ........_. -. ._.. ._.. -. -.
._.._. ....- .-.... decompiler -.-. .. .-. .....- . ._.. ._.. -.
- decompiler .--.-. cracker .- - - - _ .- .- ..- .. ...-.
Decompiler ...
DCC Decompiler
DCC -.-. decompilation .. . .-. .. ._.. ... - . ..-. . .........-
- - -.
http://www.itee.uq.edu.au/~cristina/dcc.html
Boomerang Decompiler Project
Boomerang decompiler -.-. ...-- decompiler _...._._. ..-. C
- . decompile . ...-.
http://boomerang.sourceforge.net
Reverse Engineering Compiler
REC -.-. . . .- - decompiler _.._. assembly -.-- C . . - .
decompile ..-. -.---. C assembly ...._..._. assembly .- .- -
.. .-. _ ..- -. . ._-.
http://www.backerstreet.com/rec/rec.htm
ExeToC
ExeToC -.- . .-. ..- - decompiler -. _.. -.
http://sourceforge.net/projects/exetoc
code-dump
code-dump -.-. PowerPC (PPC) Objective-C decompiler _.. -.
http://sourceforge.net/projects/code-dump
-, Debuggers
Debugger .--.-. cracker .- .-. .. .. - .. _.. _ . .....--. -.-.--
-... ... _-. _ ..-. - . .. ... ... - . .. .- - .. ...
. -.
._. debugger .-...-. ._-... ._ disassembler -. HEX - .-
-_ ._.- . assemble _ . - .- _ .. . . -. Debugger .--. ....
.-- instruction function call .-....-.. breakpoint .- . - .. ..-.
Windows Debugger ...
OllyDbg
OllyDbg -.-. ...-- Windows debugger _.._. ... disassembly assembly
engine --_ . -. ..._..- feature .-_. -..-.-. ._..-.
Patching disassembling debugging . - - . . -.
http://www.ollydbg.de/
., Cracker -..-- ... tool ...



SoftICE
SoftICE - local kernel debugging -- .._.-. -. ...- feature
-. _.. _ . - . . -. SoftICE -. s_ . ..-. ...--.. .--.
WinDBG
WinDBG -.-. MicroSoft - ...- ..... - .-. _.. _ . user-mode
debugging . remote kernel-mode debugging -- .._.-. WinDBG -. .._ _- .
Visual Studio Debugger .-... GUI .-. ..-. . .-. 32-bit 64-bit version
.- . - -. Windows . .. .- - signature . .. download .-.
http://www.microsoft.com/whdc/devtools/debugging/installx86.mspx
IDA Pro
DataRescue - - _ . .- ... .. OS . .. . . . -.
http://www.datarescue.com
., Hex Editors
Hex editor .--.-. cracking ... ..__-.- tool .-.--... binary source file
.- - _-_ .. . - - - -_._.- .. ..-. . . -. Hex editor .--. debugger
decompiler disassembler .-._-_.- png jpg .......-- _-_....-.
. . -. Hex editor .-..._-.... ....... tool .-- ..._--.
Windows Hex Editor ...
Cygnus Hex Editor FREE EDITION
_._. ...-- tool _..-.
http://www.softcircuits.com/cygnus/fe/
WinHex
. disk .--_._.-. -..- tool _.._. --..... --_
_.....-- ._.- ......_....-. ...... -..-.--
_. .._._,
http://www.x-ways.net/index-m.html
HexEdit
. . .- _ . binary . .- disk .-- -_._.-.-. Free version ...-. source
-- .._. shareware version -.
http://www.hexedit.com/
FlexHex
FAT32 ..-- ..- NTFS . .- - - __ . ._. -. FlexHex
-. sparse ..- -. NTFS volume . .- - .- - alternate data stream - _ . -
-. OLE compound ..- flash card .- _.. physical drive . .....- - - _.
. ._. -.
http://www.heaventools.com/flexhex-hex-editor.htm
, _.. tool ...
.....-...-. tool -..._-..- ....- .. ... ..-. . . .- - - .
SysInternals Tools
SysInternals --- tool .-.. .-.... utility .- _ . . - -.... -.
_ ... .-. .- . .- network administrator .- cracker .- - - . .
-. .. ._. - utility .--.-. Process Monitor FileMon TCPView RegMon
Process Explorer - _..-.
API Monitors
API monitor tool .--.-. process ., -.-.-. Win32 API -. function
.- - .. ..-. . -.- ... _-_ ..-. .- -. cracker .- - - .. -.
., Cracker -..-- ... tool ...



Rohitab API Monitor Vitaly Evseenko API Spy32 www.nektra.com Spy Studio --
. ._. -.
PE Tools
PE scanner -.-. -. debug - exe -.- -.-.-....-.. ....
-. -. protector .- -.- . ..-. . -. .. .....-. _ tool .--. PE
header -_.-_._.-....-. PE tool .- -.-. Lord PE PE Browse PE Detective PE
Disassembler PE Explorer PE Insight PE Optimizer PE Rebuilder PE Tools PE Viewer
PEditor PEiD Stud PE WPE CFF Explorer -_..-. .......-.-. Lord PE PEiD
CFF Explorer -_..-.

, PEiD _. .. .....
Keygenning Tools
-.- patch .- keygen ..... ..-.....-....-. -.- ...
....-. ...._.... template .... ..-- __. keygen -. - . --
...... -.
NFO Editors
NFO editor .- -.-. patch ., serial . .- - .._ ... .nfo . . - ... .
.._-. .nfo ..-.. ......-.-.-. cracker ._ serial .- cracking team
._ crack . . ....- _.. -.
Patch File Maker
Crack ..-- .....-....... ......-- cracker .--. patch . .-
- -.-......-. Patch file maker .- -. .- . - ..- -. offset ..-
_ . _ . Windows registry .- . - ..- key - __.-- _-. .......
patch making tool .--.-. uPPP Diablo Universal Patcher (dUP) -_..-. tool .-
.-.- template .--.-. www.tuts4you.com .. . download . -.

, . . patch .
., Cracker -..-- ... tool ...



Resource Editors
Resource editor -.-. ......- .-- _.. resource ...-- _...
.-.._-. ....... resource editor .- -.-. Exe Scope Resource Editor
Resource Hacker Restorator Window Hack XN Resource Editor - _..-.

, System properties - resource editor _. _ _ ..

Compilers
Compiler .--.-. cracking .._...-._..... .._. _..-. ....-.
-. -....-.... -_ _ . compiler .....-_........
Dictionary Files
Dictionary . .- -.-. password .-- _...... .._. _..-. .....
password _.... .._..-.
Password Recovery Tools
Password revovery tool .-- password _...... ..-. ..__-. tool
.- -.-. Elcomsoft Password Recovery Passware Kit Enterprise - _.. -. tool .--
..__. e-mail internet MS Word MS Excel MS Access MS Powerpoint Windows
password .-..-- __.....-.
.. ... Tool ...
--. .-. .... - . ._ ..- tool .- ..._- . -. .- -.-. Visual
Basic -..-- decompile -.._- tool .-_..- SmartCheck VB Decompiler
Delphi -..--- DeDe Foxpro -..--- UnFox All Java -..--- Java
Decompiler DJ Java Decompiler Flash (SWF) ..--- Sothink SWF Decompiler MSI
. .- - - MSI Unpacker Dot.Net -. .- - - Crack.NET DisSharp RedGate
DotNet Reflector - _.. -. Packer/unpacker .- ._-. .- .-. Packer (protector) ...'
. .. ..- . . .. ... .. . _.. -.




., Olly Debugger .-.-



tcef;(6) - Olly Debugger rdwfquf


.. . - .-. - . ._-. .- cracking tool -._..- OllyDbg ._-. .
Cracker .----.-. Oleh Yuschuk .....- OllyDbg -. .-. .. . usermode debugger
... ...-- disassembler .-. ... beginner .--. cracking
.- ... . _- .. ._-- Numega SoftICE ..- tools .- .-_--.
.- -. .._- .- kernelmode -.-- crack -..- - .-. OllyDbg
..- ._ OllyDbg _- ..... .. . ...-.-. - .- - _...-_...- .-.-
..._. procedure parameters .- loops .- - . .. _ . constant array string
.-...._.-- .-.......-. ..-_. plugin ._..- _.... .- . . -.
feature .-- ...--_.. debugger .-.. ..-.-. debugger -. 80x86 . .
.- .... . . - _ .-. .-. ......- _ . . - . .-..._ . -. --.
.-. Olly -. debugger ... .-.... disassembly ......_.- ...-. IDA
Pro . , ._... . .. . - .
Debugger Window
OllyDbg .--.. main window - ,. . _..-. _ main menu
toolbar -. Main window .. informational pane -. .- -.-.
disassembler window .-. , data window ..--., registers window ._.,
stack window ..-_., _ _.. window .- _ . ...-. . ._. - windows
...-.-. View menu . . _-_ . -. windows .- - - . .... _. ._.. _ .
---..--.._. ..-... -.- .._-_

,
Disassembler Window
Disassembler window .. Address Hex dump Disassembly Comment ._. .-.
-. ,

,
Address address .-. .. memory .- .- .. command virtual address -.
Column - . . - . - .-. address .-... - address -. .-.-- .... offset
.-_.. ._... ... . _.. -. ($, $2, $+4, ,
Hex dump -.-... -.-- operand - . .. .- _. . .. _ .-. -.
.. -.- .._.... ..--... .- _._.....-. ...-..
_. ..- -.- -. command .- - -. ..- jump (>) .. _..-. ...- ,
jump .. . -. .- . - -. .-. - . . - . .. . ..-. . . - address -.
., Olly Debugger .-.-



.. highlight _... . -.- . . command address, ..- breakpoint
_.. .- . - - -. ....- -. -. .. . - -.
Disassembly .-....-. command - - Assembly mnemonics .-.. _..
-. Command - . . - . .. . Assembly command - -_._.-.. window -.
... ._.. -. ... . . . command - _--. _..-. _._....
command - .-. ._-.. debug ... .._... _ __ ..- -. ..... - ,
.-- executable module _.. ._. . ... -. -. cracker --.-. _-......
..-. _.. -.
Comment .-....-. command -.-- _..-- .- -. ... .
-.-. API functions library functions .- ._.-- ...-. .-.- ..-.
.. . . . Assembly - .......- comment .- . . . _- - -.- . -
... .-.
The Data Window
window ...-. Address Hex dump ASCII Unicode, ._. .-. -.
- . -- ..-. .- -.-. interpret - ._......-. .-.- cell ..-
......- - Unicode _.. ._. . - Hex dump .-. ... . ASCII .-...-._.
Hex dump .-. ..-....._..-. ,

,
The Registers Window
Registers window ...-. .... registers & FPU registers .... registers &
MMX registers .... registers & 3DNow registers ._. registers . ..-.
..-.....-. EIP ., .-.. register .-- -_._.- -. _....- (<)
.. registers window ._..... _..-. ,

,
The Stack Window
Stack window -.-. stack ..-..-- _-. ..-. Address, -.-.
stack ..- cell address - _-. - ..-. Value, -.-. cell ..-..-- _
-. -- ..-. Comment, ...-. cell -..-.-- _...- comment .-
-. , VB -..- Delphi -..-- crack ... ..-.

,
., Olly Debugger .-.-



_.. Windows ...
OllyDbg .- - .-. .. . . - ...... -.-.-.
-, -. window .... right click .... .-.. window menu .. . ..
menu -. window .. -_ _ . - _...-. menu .- - .... .. _- _
-.
, Window . .- ..- -. -. - -. . .- _.-. .._ register .--
_-_- .... register --.- right click . _-_ - data area follow in
dump, stack area follow in stack, . . - address .- ...-..-- interpret
-.
Debug Execution
Debugging .-. -.-.- mode ...... .._. _...-_.. ...-.
.... execution mode .- ._-. . ._ -. Execute ..-- debugger . .
_...._._ .-.- Disassembler window -. Assembly - - _.-. -.
- execute ... .--.. mode .--.-.
-, Procedure -.-....-..- procedure - subroutine ., function - ..
._, -...- .-......- Step-by-step execution - step over, .-. F8 -
..... - Assembly command - ..-. Command .- - . . --
execute _ ._. _.. window Register Data Stack, -. ._.......-. _..
-. mode -----.-. --. ..- command -. call procedure CALL,
-.. ... procedure . .-...- command .. .-. instruction -. -_ .
... ..- execute .._..-. .-.- call procedure CALL, . . -
-.-- -.._-... ...-... .---.
, Procedure .- ..-.- Step-by-step execution - step into, .-.
mode .. execute ....-. F7 - ..... _.- mode - ._..- -.-. CALL
command - .. . ._ .. . instruction .. .-. . . -- execute .. _..-.
-._. - _ .. ..- (step over & step into) ... animation - ..__. .....
-. mode ....-- <Ctrl>+<F8> <Ctrl>+<F7> - . ._. -. keyboard
shortcuts ....- ._....-. step over & step into command .--. instruction
-. _ .-. - _ .. ... . ._ . . .. Instruction ....- execute _...
.-. debugger window -. refresh ...._..--- .. ._. . . ..-..- -
._. . . . _.. -.
-. . ... <Esc> key - .... execute -.- ... . ..-
breakpoint - .- .-. . ... . _ ..-. debug .- -.- exception
-.- -.... _..-.
Step-by-step program execution _.._.-.-.-. trace mode - Trace mode -.
animation - -. ... . . debugger window -. .-....-. refresh . .
.- - - . step over step into -.- tracing -- _... -.-. <Ctrl>+<F12>
and <Ctrl>+<F11> key .- . _ . . ._. -. Tracing . ._ . .-. animation
....- _....-..__. -.-. command ....- execute _....-. .
execution .- .-.-- .- - . --- tracing buffer - - .- - -.
- View menu - Run trace command - ..__. _-_.-. ...-. tracing
buffer . . - -..- - ...... . . . .._ .... -. ..- -. . . tracing
- -. . . .-. condition .- .......-. (set trace condition) - <Ctrl>+
<T> , Trace - -.-. serial fishing ...-. ....-. Serial -.-
-. - - - . ..-. . -. Run Trace window . ._. . Condition -. ..-.-
...-. - EIP -. .- . - ..- breakpoint .. trace - .. ._.. -.
- .- ..._- .- trace .-...-. .-_...
., Olly Debugger .-.-
.



,
Trace mode - - ..- condition .-- .-.-.-.
-, Break - ... .. address .- range
, ._..- . - - ... EAX>100000 -...., --. EAX>100000 ._....
. - .. . trace - -. . ... ._.. -.
-, Trace - . . . - .. command .- .- -
Procedure - return - ..-.. -- execute ... debugger - .... _...
-. (execute till return) ..--...._. - procedure -...-.. execute
.. _..-. <Ctrl>+<F9> key - .._-.
..-... --. tracing - . . . -. .....- .. .-..._
_ . _ - .-. (execute till user code) command . ._ . - -. . .- -
<Alt>+<F9> key - .._.-.
Breakpoints
Breakpoint . -.-.-. --. . . .- - debugging tool -. Breakpoint .--.
.- -.- .... .._...-. .-.-..- ..- registers
stack data .- ...- . - .....-.
Ordinary Breakpoints
Ordinary breakpoint .- - .-. . .. ..- command .- .- . - -. <F2> key
- ._._...._..-.. (Hex dump) window .. . . . - . _ ._. ... _ ..-. . . ._
. -. . -.-. ..-. . . - address -. .. ._. .. ..-. _
register variable stack .- ._.- _ . .. .... -. <F2> key - ..- -. _- . .
.-. breakpoint - ...._.... _.... breakpoint - -... ........-.
Windows API function .- - ... _-_ - . . _.. -.
Conditional Breakpoints
Conditional breakpoint .- - .-. <Shift>+<F2> key ._. .._.-. <Shift>+
<F2> key --.- ,.. _..--. combo box ... . combo box .. -...
.- . condition -.- _.....-. --. condition -. .-...
.-. command .-- execute -. ..... Debugger -. condition .- ..._- .-
. . - ... _- .- - .-. .._ -. -..- -.-. ...-
., Olly Debugger .-.-




,
-, EAX = = 1 -.-. EAX register -. -. _.. debugger - execute -. ...
...-.
, EAX = 0 and ECX > 10 -.-. EAX register -. .__.._. ECX register -.
-. .. - _- . debugger .-.... ...-.
-, [STRING 427010] == 'Error' -.-. virtual address (VA) 427010h .. 'Error' .-
.....- .- debugger - execute -. ... . ..-. .. -. EAX =
= 'Error' . EAX ..-....- pointer -. ....._.. ._. . ... .
., [427070] = 1231 -.-. VA 427070h . . - .-. 1231h _ .. . breakpoint
- .-.-..
, [[427070]] = 1231 -.-. address - ..- ..__. ._.... VA 427070h
.. _.. VA -. _ . VA . . - .-. 1231h _ ._ .. _ . breakpoint - .- . -
-.
Conditional Breakpoints with a Log
.-.-. conditional breakpoints .. extension -... _..-.
Conditional logging breakpoint - .-.-. <Shift>+<F4> key - ..-. -.....
breakpoint - .._... _...- log . . . - -. .- ..-. Log
..- ..-- __-_-.. <Alt>+<L> key - . _ .... _ ..-. . View menu .
Log command - . _ .... _ ..-. . _-_.-. .,

.,
Breakpoint to Windows Messages
Window function . - -._. window class function ., messages .- ..- .
-.._-. windows message .. breakpoint - .-.-.. application window -.
.. -. -_ .._. windowing application .--. execution . - - .-
-. . . . - ... . . - application -.- window -.- debugger -
..--. application - .-.-- <Ctrl>+<F8> - . application window -.
-. .- ..- _-._ .- . . .- -. -. -. . - -. ..- .- - - execute
. . ..-. .- .... Window function . ..- . application - ...._. .-...-
windows ...- ...-. - View menu - Windows - .._.-. ,
., Olly Debugger .-.-




,
,.._..- window -. investigator - window descriptor .._ . identifier
.._-..._..- window procedure address ClsProc, .- ... ... -. Window
procedure address -.-- --.-- investigator - window function .- ..
..- _ ... breakpoint .. conditional breakpoint .-.-.-. -._.._.. window
functions .- - window message .--.... breakpoint .- .- . - -.
.-.... ._-. ,.._..- window -.-_. context menu - Message
breakpoint on ClassProc - . . - ..- window -. ... ._.. _ . . . ..-
breakpoint parameter .-- .-.-..._..-. ,
-, Dropdown list . message - .. ..--- .-...
, Message ... event - ..._. -. event .--. window . ,
keyboard event .-- .-..-.._.-.... message . ..... ._.. . -.
, ..-... ...-.-.- message .- - _ . . .. . -.
, -. message .- -. . - - -. . . -. ..- .. . -.- . ._.- . ... trace
-.. window .- - .. ._. ....- window ....- title window ... .,
window .. . -.
-, Breakpoint -. . . _- . .- -. . -. . ... counter - .- . - ..
., Breakpoint .- . . -. -.- . . . . -. .- . -
, Breakpoint .- . . record - log -. ... . -. .- . - ..

,
Breakpoints to the Import Functions
Debug . module - import - ._...- .-. <Ctrl>+<N> -
. , ..-.. window - right click ._. ..---_. _.-.
-, Import ..- function - ...._.. breakpoint - .-.-.-. (Toggle
breakpoint on import)
, Import ..- function - ...._.. conditional breakpoint - .- . - .
-. (Conditional breakpoint on import)
., Olly Debugger .-.-



-, Import ..- function - ...._.. conditional breakpoint - log _.
.- . - . -. (Conditional log breakpoint on import)
., .-.-..- ._.- -.--... breakpoint - .-.-.-. (Set
breakpoint on every reference) { command - Find references to import (Enter key) -
-. _....-- Find references to import - breakpoint - -.. ....-.}
, ....- ._.-...- reference -... log _. breakpoint - .-.-.-.
Set log breakpoint on every reference)
., Breakpoint ...- ....-. (Remove all breakpoints)

,
Breakpoints at the Memory Area
OllyDbg debugger - memory area .. breakpoint -. -_ .- .- . - . - -.
. disassembler window . , data window - ... ..- context menu .
Breakpoint | Memory on access ., Breakpoint | Memory on write command .- -
. .. . -. _ . .-. ._-. -.- . - - - breakpoint - .._. ._.....
Breakpoint .-. . .-.-. (on access) - .-..--- _.. . ... - . breakpoint
-...-.-. (on write) -.---.. _...-. Breakpoint .-- context menu .
Breakpoint | Remove memory breakpoint - ..._._. .....-. ,

,
Breakpoints in the Memory Window
Memory window (Alt + M) -.-. debug ..- -.-- ., .-... ._.
. - debug ..- -..-- .....- memory block .-- _.-.
window .. breakpoint -. - .- . - . .. _.. . -. . rightclick . Set memory
breakpoint on access - ., Set memory breakpoint on write - ... Breakpoint -
.. .. .-. Remove memory breakpoint - . .. -.
Hardware Breakpoints
... breakpoint .--.-. INT 3 interrupt vector -- .._-. breakpoint
.- - . .__ .- -. - ... . .. .. ....-. -. . .. Intel Pentium
microprocessor .--.-. debug registers (DR0DR3) - _._ . . .....-. register
.- . . breakpoint - -. virtual address - .-. Command -. -
.._..- address -. register -.-...-- address _... processor -.
debugger .. ..- exception -.- ---. Hardware breakpoint .--.-. debug
..- -. - .-. .. ..- .... ..- - - . -. _.. _.. . - - ... _..
-. Hardware breakpoint -.- .-.-....-. disassembler window - ... _.
context menu - Breakpoint | Hardware on execution command- . . . .- - main
menu - Breakpoint | Hardware on access ., Breakpoint | Hardware on write command
., Olly Debugger .-.-



- .._.-. Hardware breakpoint .-- .-.-. context menu - Breakpoint |
Remove hardware breakpoints command - .._ ,

,
_... . .... . . ...
Watch expressions Window
OllyDbg - expression .-- ..._-_. special window -. - ....-.
Conditional breakpoint .-._-.. ._-.- expression .-._-...-.- .-
Memory cell .- register .-- ..- expression .-- .._..-. _...-.
expression .-- . .... -. Watch expressions window - ..-.-.
View | Watches command - .._ Watch expressions window ....-. right click
._. Add Watches command - ... _..-. debugger - ..._-_.... expression
-.- .-.-.-. ..--...._..-. . HEX - . .- _.-. ,. .
expression - Watch expressions window - _...-._.. _ . -. processor
command - .. execute _ ._. - . ..- - ... _-_ ._ ._.-.

,
- - ...- ... _ .
OllyDbg .. _---.-.-- ASCII UNICODE HEX ,.- - <Ctrl>+<B>
key ._. ....-. , Command -. .- ... . <Ctrl>+<F> key command
.-....-.- .... <Ctrl>+<S> key - .._.-. <Ctrl>+<L> key (Next)
-.-. ..- . . . - -.- ...-.
,
Executable Module - _....._._.
OllyDbg .. -.-.- _--.-- ...._._. executable -..._.. ...
._ .. -. Copy to execution | Selection ., Copy to execution | All
modifications command - . . - _ . - . .. - ... . - . _- - - . ._ ..
.._ . . . .._ . -
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 3 -


tcef;(7) - IDA Pro Advanced 5.2 rdwfquf
IDA Pro u a w mh exe u k' fa w Gu dk p p fa q ; & mr Sm t a u mi f; q Hk; tool w p fc kjz p fy gw , f/ jy D; c Jhw Jht c e f; r Sm
a v hv mc Jhw Jh Olly debugger u a w mh o Hk; p GJo la w Gt w Gu f v G, fu lp Gm t o Hk; jy KE dki fa y r , fhv J o lU& JUu e fUo w fc su f
u a w mh PE u k' fa w Gu dko m p p fa q ; a y ; E dki fy gw , f/ IDA Pro u a w mh DOS^ Windows^ Unix^ Macintosh^
Java^ .Net^ Console y & dk* & r fa w Gt jy i f t jc m; OS r Sma & ; x m; w Jh y & dk* & r fa w Gu dky g p p fa q ; a y ; E dki fy gw , f/ ' Dht
jy i f Palm OS e JU mobile OS r Sma & ; o m; x m; w Jh y & dk* & r fa w Gu dky g p p fa q ; a y ; E dki fy gw , f/ IDA [ m Olly
v dka w mhu k' fe JUy w fo u fw Jha u mu fc su fc sw ma w G? , lq c su fa w Gjy Kv ky fr Smr [ kw fy gb l; / ' ga Mu mi fho i fu dk, fw dki f
q & mr u lb J u k' fa w Gu dk a v hv m& r Smjz p fy gw , f/ v dkt y fw Jh parameter a w Gu dk u dk, fw dki fjy Kjy i f& r Smjz p fy gw , f/
IDA r Sm w p fc gw n f; y gv mw Jh y & dk* & r fb mo mp u m; [ m C e JUz GJUp n f; w n fa q mu fy Hk o a b mw & m; c si f; w lw Jh
t w Gu f o i fht w Gu f t a x mu ft u ljz p fa p r Smy g/
IDA u a w mh Interactive DisAssembler & JUt w dka u mu fjz p fy gw , f/ IDA & JU About window u dk
Mu n fhv dku fr , fq dk& i f y x r q Hk; t r sdK; o r D; y & dk* & r fr mjz p fw Jh Augusta Ada Byron & JU & ky fy Hka v ; u dk a w GU& r Smy g/
y x r q Hk; o dx m; z dkUv dkw mu a w mh IDA package r Sm idaw.exe (console) e JU idag.exe (GUI) q dkjy D; y & dk* & r f
E Sp fr sdK; y g& Sdy gw , f/ ' Da e & mr Sm t " du x m; jy D; & Si f; jy r Smu a w mhidag.exe (GUI) t r sdK; t p m; u dkjz p fy gw , f/
( 1 ) Virtual memory t a Mu mi f;
w u , fv dkU o i fht a e e JU exe module w p fc ku dk IDA r Smz Gi fhr , fq dk& i f t J' Dz dki f& Sdw Jhdirectory a t mu fr Sm
z dki fE Sp fc ku dk z e fw D; r Smjz p fy gw , f/ ' Dz dki fE Sp fc ku a w mh ID0 e JU ID1 q dkw Jh extension a w Gy gw Jh t & e f virtual
memory z dki fa w Gjz p fy gw , f/ ' Dz dki fa w Gu dk intermediate data a w Go dr f; q n f; z dkU IDA Pro u t o Hk; jy Kw my g/
w u , fv dkU o i fht a e e JU v u f& Sdexe z dki fu dk y dw fv dku f& i fy Jjz p fjz p f? a e mu fw p fz dki fu dk z Gi fh& i fy Jjz p fjz p f ' Dz dki fE Sp fz dki f[ m
a y smu fo Gm; r Smjz p fy gw , f/ ' Dz dki fa w Gu a w mh exe module e JU t r n fw lr Smjz p fjy D; .ID1 extension e JUz dki fu a w mh
exe module & JU image u dku l; w i fz dkUt w Gu f t o Hk; jy Kw mjz p fy gw , f/ ' Dimage [ m Windows OS & JU 32-bit
flat memory model x Ju dk u l; w i fw Jh image e JU w p fx y fw n f; jz p fy gw , f/ ' ga Mu mi fhv J OS u execute
v ky fw Jhmodule e JUp p fa q ; w Jht y dki f; r Sm w p fx y fw n f; u sa p z dkU jz p fE dki fw my g/ ' Dt c su fu y J IDA u dk w r lx l; a p w Jh
debugger jz p fa p w my g/ Address t o D; o D; t w Gu f z dki f[ m 32-bit w p fc ku dk o dr f; q n f; x m; w mjz p fjy D; 8-bit
cell w p fc ku a w mh o w fr Sw fx m; w Jh address e JUw ln Djy D; ? 24-bit attribute w p fc ku a w mh ' Dcell e JUy w fo u fw Jh
t * Fg& y fa w Gu dk t " dy m, fz Gi fhq dkw mjz p fy gw , f/ t x l; o jz i fh ' D attribute [ m instruction w p fc ke JUy w fo u fw Jh
o w fr Sw fx m; w Jh memory cell u dka & m? a ' w mu dky g o w fr Sw fE dki fy gw , f/ ' Dt jy i f ' D attribute [ m string
x Jr Sm& Sdw Jhcomment? cross-reference? label w dkUv dkt jc m; object a w Gu dka & m o w fr Sw fE dki fy gw , f/
IDA Pro u t o Hk; jy Kw Jhvirtual memory e JUw GJv ky fw Jhmechanism u a w mhWindows OS u t o Hk;
jy Kw Jh mechanism e JUw ln Dy gw , f/ o D; o e fU cell w p fc ku dk& , lc sde fr Sm ' Dcell y g0 i fw Jh page w p fc kv Hk; u dk r lv
r Sw fOmP f (buffer)x J o Gi f; , ly gw , f/ w u , fv dkU memory cell u dk jy Kjy i fv dku fw Jht c gr Sma w mh virtual
memory page w p fc kv Hk; u dk jy e fa & ; c H& r Smy g/ IDA Pro u a w mh memory page a w G& JU t p dw ft y dki f; u dk RAM
x Jr Smu dki fw G, fy gw , f/ jy Kjy i fx m; w Jh cell a w Gu dka w mh t c gt m; a v smfp Gm disk q Dq GJ, lr Smy g/ Page w p fc ku dk
u l; w i fz dkU v dkt y fc sde fr Sm page buffer u jy n fha e c Jh& i f? IDA Pro u y x r q Hk; jy i fx m; c H& w Jh page u dka w GUz dkU
buffer u dk& Smr Smjz p fjy D; ' gu dk disk q Dq GJ, lr Smjz p fy gw , f/ jy D; & i fa w mhv dkt y fw Jhpage u dk a e & mv Gw fq Du l; w i f
r Smjz p fy gw , f/
u l; w i f& r , fhmodule & JU image u dko dr f; q n f; jc i f; t jy i f IDA pro [ m label? function t r n fa w Ge JU
comment w dkUv dkt c su ft v u fa w Gt w Gu f r Sw fOmP fu dk v dkt y fy gw , f/ ' Dt c su ft v u fa w Gu dka w mh .ID0
extension & Sdw Jhz dki fx Jr Sm o dr f; w mjz p fy gw , f/ w & m; 0 i fx kw fa 0 w Jh p mt ky fp mw r f; a w Gr Sma w mh ' Dr Sw fOmP fu dk
btree t w Gu fr Sw fOmP fv dkU o Hk; Mu y gw , f/
( 2 ) y & dk* & r f\ GUI
exe y & dk* & r fw p fc ku dk IDA r Smz Gi fhr , fq dk& i fa w mh y Hk( 1 ) t w dki f; jr i f& r Smjz p fy gw , f/ z Gi fhx m; w Jhy & dk* & r fu dk
p p fa q ; jy D; o Gm; & i fa w mh y & dk* & r f& JU b , fz u fa x mi fhr Sm "The initial autoanalysis is finished" q dkw Jhp mo m; u dk
jy r Smjz p fy gw , f/
IDA Pro & JU main window r Sm tab a w Gt r sm; Mu D; a w GU& r Smjz p fy gw , f/ y Hkr Se fq dk& i fa w mh tab 8 c k& Sdr Sm
jz p fa y r , fh ' Dx u fv Jy dkE dki fy gw , f/ o i fht a e e JU tab t o p fa w Gu dk a y gi f; c si f& i fa w mh Views menu u Open
subviews u dka & G; jy D; x y fw dk; v dkU& y gw , f/ IDA View e JU Hex View u a w mh a e mu fx y f x y fy Gm; v dkU& y g
w , f/ ' ga Mu mi fh o i fht a e e JU u k' f? a ' w m section a w Gu dk r w ln Dw Jh window a w Ge JU Mu n fhv dkUr Smjz p fy gw , f/
w u , fv dkU a e mu fx y f window a w Gx y fw dk; v mr , fq dk& i fa w mhIDA View-A? IDA View-B? IDA View-
C p o n fjz i fhjz p fv mr Smjz p fy gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 4 -


t " du t u sq Hk; window u a w mhIDA View jz p fy gw , f/ ' Dwindow [ m exe u k' fa w Gu dkanalysis
v ky fjy D; a w mh& v mw Jh& v ' fa w Gu dkjy w mr dkUv dkUy g/ y Hk( 1 ) /

y Hk( 1 )
IDA Pro debugger e JU t v ky fv ky fr , fq dk& i fa w mh ' Dy & dk* & r fu dk u dki fw G, fz dkU t " du e n f; v r f; ( 3 ) c k& Sd
w , fq dkw m r a r y ge JU/ o lw dkUa w Gu a w mh menu command? toolbar button e JU hotkey a w Gy Jjz p fy gw , f/
IDA & JUv ky fa q mi fc su fw dki f; t w Gu fa w mh hotkey a w G & Sdr Smr [ kw fa y r , fh t o Hk; t r sm; q Hk; v ky fa q mi fc su fa w G
t w Gu fa w mh hotkey a w G& Sdy gw , f/ Oy r mjy & r , fq dk& i f . . . w u , fv dkU t c sdKU data block a w Gu o i fhu dk
o Ho , jz p fa p w , fq dk& i f C key u dkE Sdy fjy D; ( u k' ft w Gu f t w dka u mu f) ' gu dk u k' ft jz p fa jy mi f; E dki fy gw , f/ a e mu f
w p fc ku a w mh w u , fv dkU Assembly command a w G& JU t c sdKU block a w G[ m t " dy m, f& Sdy Hkr a y : b l; q dk& i f
o i fht a e e JU ' gu dkD key E Sdy fjy D; ( a ' w mt w Gu f t w dka u mu f) a ' w mt jz p f a jy mi f; E dki fy gw , f/
IDA Pro [ m a t mu fy g configuration z dki fa w Gu dkt o Hk; jy Ky gw , f . . .
lda.cfg y Hkr Se f configuration z dki f
idatui.cfg console y & dk* & r fr sm; t w Gu f configuration z dki f
idagui.cfg GUI y & dk* & r fr sm; t w Gu f configuration z dki f
Configuration z dki fa w G[ m IDA main directory & JU CFG subdirectory a t mu fr Sm& Sd& r Sm jz p fy gw , f/
( 3 ) exe u k' fu dku l; w i fjc i f;
w u , fv dkUo mo i fht a e e JU exe module w p fc ku dk IDA r Smz Gi fhr , fq dk& i fa w mh y Hk( 2 ) t w dki f; jr i f& r Smy g/ ' D
window u dkt o Hk; jy Kjy D; o i fht a e e JU z Gi fha e w Jh process e JU u e OD; analysis u dk a jy mi f; v Jv dkU& y gw , f/ ' D
window [ m a e mu fy dki f; r Sm & Si f; jy r , fhconfiguration setting a w Gt r sm; Mu D; u dka y ; p Gr f; E dki fy gw , f/
u dp a w mfa w mfr sm; r sm; r Sma w mh IDA u t o i fha w mfq Hk; setting u dk t Mu Hjy Kjy D; o Hk; p GJo lu b mr Sa jy mi f;
v Ja y ; z dkU v dkt y fr Smr [ kw fy gb l; / o i fht a e e JU OK button u dkE Sdy fa y ; z dkUy J v dkt y fy gw , f/ a t mu fy g option a w G
u dkw c gw & Hr Smo mt o Hk; jy Ka y r , fht u sOf; c sKy fa z mfjy a y ; v dku fy gw , f/
- Load file (directory/name) as ' Da e & mr Sma w mh o i fz Gi fhv dku fw Jhy & dk* & r fz dki fu dk IDA & JU v u f& Sd version
u o dx m; w Jh z dki f format (PE o dkUr [ kw f ELF)p m& i f; a w Ge JUw dku fp p fjy D; jz p fE dki fw Jhp m& i f; u dkjy w mjz p fy gw , f/ ' D
window r Smjr i f& w Jh t jc m; option a w Gu a w mh o i fz Gi fhw Jhy & dk* & r ft r sdK; t p m; a y : r lw n fjy D; a jy mi f; v Ja e r Sm
jz p fy gw , f/ Oy r mjy & & i fa w mh . . . PE module & JU MS-DOS stub u dk disassemble v ky fr , fq dky gp dkU/
' Dv dkv ky fz dkUt w Gu f p m& i f; x Ju MS-DOS executable option u dka & G; & r Smjz p fy gw , f/ w u , fv dkYy & dkq u fq m
t r sdK; t p m; u dk a jy mi f; c si fw , fq dk& i fv J Set button u dka & G; jy D; a jy mi f; v dkU& y gw , f/ u Re fa w mfht a e e JU x y fa jy mc si f
w mu a w mh module a w Gu dk p p fw Jht c gr Sm IDA u t o i fha w mfq Hk; u dka & G; jy D; p m& i f; jy Kp ka & G; c s, f a y ; x m; w m
jz p fy gw , f/ ' Da e & mr Sm IDA u PE module u dk y Hkr Se f PE module t jz p fa & m? MS-DOS y & dk* & r ft jz p fa & m?
binary z dki ft jz p fa & m b mo mjy e fa y ; E dki fy gw , f/ w u , fv dkU o i fht a e e JU .net y & dk* & r fw p fc ku dk z Gi fhMu n fh& i fy J
jz p fjz p f? Linux y & dk* & r fw p fy k' fu dkz Gi fhMu n fh& i fy Jjz p fjz p f jy o w Jhp m& i f; u Gmjc m; o Gm; r Smjz p fy gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 5 -



y Hk( 2 )
- Processor type Drop-down list w p fc kjz p fjy D; a & G; c s, fx m; w Jh module u dk compile v ky fx m; w Jh
y & dkq u fq mt r sdK; t p m; u dka & G; c s, fc Gi fhjy Ky gw , f/
- Loading segment & Loading offset o lu a w mhmodule u dk o w fr Sw fx m; w Jhoffset & Sdw Jhsegment
r Sm u l; w i fa y ; E dki fy gw , f/ ' g[ m MS-DOS module a w Gt w Gu fa & m? binary z dki fa w Gt w Gu fy g o Hk; 0 i fy g
v dr fhr , f/ ' Dparameter a w Gu dka w mhPE module a w Gt w Gu f t o Hk; r jy KMu y gb l; /
- Enabled ' gu a w mh Analysis t ky fp ku flag w p fc kjz p fjy D; u k' fu dk u e OD; analysis v ky fjc i f; r Sa & Smi fMu Of
E dki fz dkU uncheck v ky fE dki fy gw , f/ w u , fv dkU o lUu dka & G; x m; & i fa w mh z dki fu dku l; w i fjy D; w me JU analyze v ky fa w mhr Sm
jz p fy gw , f/
- Indicator enabled v ky fa q mi f& r , fhanalysis process indication u dko w fr Sw fw mjz p fy gw , f/
- Create segments o lUu dka w mh PE module a w Gt w Gu f t o Hk; jy Kjc i f; r & Sdy gb l; / ' Dflag u dk t o Hk; jy K& i f
a w mhIDA u v dkt y fw Jhsegment a w Gu dk z e fw D; r Smjz p fy gw , f/
- Load resources w u , fv dkU ' Dflag u dko w fr Sw fx m; r , fq dk& i fa w mh PE module & JU resource a w Gu dk
u l; w i fr Smjz p fy gw , f/ Binary module a w Gt w Gu fu a w mh ' Dflag u dk Load as code segment v dkUa c : jy D;
t o Hk; jy Ky gw , f/ Oy r mjy & & i f .com y & dk* & r fa w Gt w Gu fjz p fy gw , f/ y Hk( 3 ) /

y Hk( 3 )
- Rename DLL entries w u , fv dkU ' D flag u dkr o w fr Sw fx m; & i f IDA u ordinal a w Ge JU import
v ky fx m; w Jh function a w Gt w Gu f x y fa v mi f; comment a w Gu dkjz n fhq n f; a y ; y gw , f/ ' Dv dkr Sr [ kw f& i fa w mh
disassembler u function a w Gu dkt r n fa jy mi f; v dku fr Sm jz p fy gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 6 -


- Manual load w u , fv dkU ' D flag u dk a & G; x m; & i fa w mh disassembler u u l; w i fa e w Jh process & JU
t q i fhw dki f; t w Gu f o Hk; p GJo lu dkw dki fy i fa r ; jr e f; a e r Smjz p fy gw , f/
- Fill segment gaps o lu a w mh NE module a w Gt w Gu fo m t a & ; Mu D; w Jh flag jz p fjy D; disassmbler u dk
intersegment a e & mu dkjz n fhq n f; a y ; z dkU n Te fMu m; r Smjz p fy gw , f/ ' ga Mu mi fh Mu D; r m; w Jh segment w p fc ku dkz e fw D;
& y gw , f/
- Make imports segment ' D flag u dko w fr Sw fc sde fr Sma w mh import v ky fx m; w Jh t c su ft v u fa w Ge JU
q dki fw Jh.idata section u dko m b mo mjy e fa y ; z dkU disassembler u dkc dki f; y gw , f/
- Don't align segments Segment a w Gu dk n Sdz dkU disassembler u dkc dki f; y gw , f/ p dp p fp Of; p m; w ke f;
t q i fhr Sma w mh' Dflag u dk module a w Gt w Gu ft o Hk; jy Kjc i f; r & Sdy gb l; /
- Kernel options1 Flag a w Ge JUjy w Jh' Dwindow u a w mho Hk; p GJo lu dk exe u k' fa w Ganalyze v ky fw Jht c gr Sm
E Sp fo u f& mu dka & G; c s, fE dki fz dkU jy o y gw , f/
Create offsets and segments using fixup info u dk t o Hk; jy Kjc i f; jz i fh o i fht a e e JU u k' f analysis
jz p fp Ofx Ju relocations table u a e t c su ft v u fa w Gu dk t o Hk; jy Kz dkU disassembler u dk c dki f; E dki f
y gw , f/
Mark typical code sequence as code u a w mh analysis jz p fp Ofx Ju y Hkr Se fy & dkq u fq m
command sequence u dkt o Hk; jy Kz dkU disassembler u dkc kdi f; y gw , f/
Delete instructions with no xrefs u a w mh cross-reference v Hk; 0 r & Sdw Jh y & dkq u fq m
instruction a w Gu dkv sp fv sL& Ic dki f; y gw , f/
Trace execution flow u a w mh trace v kdu fz dkUc Gi fhjy Ky gw , f/ ' gr So m o i fht a e e JU y & dkq u fq m
instruction a w Gu dk& Sma w GUE dki fr Smjz p fy gw , f/
Create functions if call is present u a w mh call a w Ge JU function a w Gu dk r Sw fx m; a p z dkU
disassembler u dkc dki f; y gw , f/
Analyze and create all xrefs u a w mh t " du x m; a & G; c s, f& r , fht & mw p fc kjz p fjy D; analysis x Ju
cross-reference a w Gu dkdisassembler t m; t o Hk; jy Ka p y gw , f/
Use FLIRT signatures u a w mh signature a w Gt o Hk; jy Kjy D; library function a w Gu dk r Sw fr da p z dkU
t w Gu f Fast Library Identification and Recognition Technology (FLIRT) u dkt o Hk; jy Ka p z dkU
disassembler u dkc kdi f; y gw , f/
Create function if data xref data -> code32 exists u a w mh a ' w m{ & d, mx Jr Sm& Sdw Jh u k' fe JU
y w fo u fw Jhreference a w Gu dkp p fa q ; z dkU disassembler u dkc dki f; y gw , f/
Rename jump function as j_ u a w mh j_somewhere v dk jmp somewhere command
r Qo my gw Jh& dk; & Si f; v Sw Jhfunction a w Gu dkt r n fa y ; z dkUjz p fy gw , f/
Rename empty function as nullsub_ u a w mh nullsub_ v dk RET command w p fc ky gw Jh
function a w Gu dkt r n fa y ; z dkUjz p fy gw , f/
Create stack variables u a w mhfunction a w G& JU local variable a w Ge JU parameter a w Gu dk z e fw D;
( t " dy m, fz Gi fh) z dkUjz p fy gw , f/
Trace stack pointer u a w mhESP register & JUw e fz dk; u dktrace v kdu fz dkUjz p fy gw , f/
Create ASCII string if data xref exists u a w mh ASCII string t jz p f reference v ky fx m; w Jh
data item u dk o lU& JUt & G, ft p m; [ m w du sw Jhw e fz dk; w p fc kx u fa u smfv Ge fjc i f; & Sd^ r & Sd p Of; p m; E dki fz dkU jz p fy g
w , f/
Convert 32-bit instruction operand to offset u a w mh address w p fc kv dk y & dkq u fq m
instruction x Ju w dku f& dku f data item w p fc ku dkp Of; p m; E dki fz dkU disassembler u dkc kdi f; a p jy D; Mu dKw i fo w f
r Sw fx m; w Jhinterval x Ju dko lU& JUw e fz dk; a & mu fo Gm; a p y gw , f/
Create offset if data xref to seg32 exists u a w mh address a w Gv dk a ' w m{ & d, mx Jr Sm
o dr f; q n f; x m; w Jhw e fz dk; a w Gu dkp Of; p m; z dkU disassembler u dkc kdi f; a p jy D; Mu dKw i fo w fr Sw fx m; w Jhinterval
x Ju dko lU& JUw e fz dk; a & mu fo Gm; a p y gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 7 -


make final analysis pass u a w mh analysis v ky fw Jha e mu fq Hk; t q i fhu dk v ky fa q mi fjy D; c sde fr Sm
r p Hk; p r f; E dki fw Jh byte a w Gt m; v Hk; u dk a ' w m ( o dkU) instruction a w Gt jz p f a jy mi f; v Jz dkU disassembler
u dkc dki f; y gw , f/
- Kernel options2 a e mu fx y f flag a w Ge JUjy w Jh ' Dwindow u a w mh o Hk; p GJo lu dk exe u k' fa w Ganalyze
v ky fw Jht c gr Sm E Sp fo u f& mu dka & G; c s, fE dki fz dkU jy o y gw , f/
Locate and create jump tables u dk jump table & JUt & G, ft p m; e JU address t a Mu mi f;
a u mu fc su fc sE dki fz dkU disassembler u dkc dki f; y gw , f/
w u , fv dkU Coagulate data in the final pass flag u dky dw fx m; r , fq dk& i f analysis & JU a e mu fq Hk;
t q i fhr Sm code segment & JU byte a w Gu dko m a jy mi f; v Ja y ; r Smjz p fy gw , f/ ( Make final analysis
pass flag u dkMu n fhy g/ )
Automatically hide library function u a w mh FLIRT u dkt o Hk; jy Kjy D; p Hkp r f; x m; w Jh library
function a w Gu dka z smu fx m; ( collapse) z dkUt w Gu fo Hk; y gw , f/
Propagate stack argument information u a w mh a e mu fx y f call a w G& Sdv mc Jh& i f ( t jc m;
function r Sa c : o Hk; a o m function w p fc ku Jho dkU) call & JU stack parameter e JUy w fo u fw Jh t c su f
t v u fa w Gu dko dr f; q n f; z dkU disassembler u dkc dki f; y gw , f/
Propagate register argument information u a w mh a e mu fx y f call a w G& Sdv mc Jh& i f ( t jc m;
function r Sa c : o Hk; a o m function r sm; u Jho dkU) call & JU register parameter e JUy w fo u fw Jh t c su f
t v u fa w Gu dko dr f; q n f; z dkU disassembler u dkc dki f; y gw , f/
Check for Unicode strings u a w mh Unicode string a w G& Sd^ r & Sd y & dk* & r fu dk p p fa q ; E dki fz dkU
jz p fy gw , f/
Comment anonymous library functions u a w mh w du sw Jh library function w p fc ku dk p Hkp r f;
& & Sdw Jht c g library t r n fe JU signature a w Gu dkt o Hk; jy Kjy D; t r n fr o d library function a w Gu dk t r Sw f
t o m; v ky fx m; z dkU disassembler u dkc dki f; y gw , f/
Multiple copy library function recognition u a w mh y & dk* & r fw Gi f; r Sm& Sdw Jh w ln Dw Jh function & JU
copy t a jr mu ft r sm; u dkr Sw fx m; a p z dkUjz p fy gw , f/
Create function tails u a w mh function tails u dk& Sma z Ga y ; z dkUjz p fjy D; ' ga w Gu dk function t " dy m, f
z Gi fhq dkc su fr Sm v ma y gi f; r Smjz p fy gw , f/
- Processor options ' gu a w mhflag a w Ga & G; c s, fE dki fw Jhwindow u dka c : o Hk; w Jhbutton w p fc kjz p fy gw , f/
Convert immediate operand of "push" to offset u a w mh PUSH command x Jr Sm& Sdw Jh
w dku f& dku f operand u dkoffset w p fc k( address w p fc k) t jz p f a jy mi f; v Ja y ; E dki fp Gr f; u dkn Te fjy y gw , f/
Convert db 90h after "jmp" to "nop" u a w mhJMP command a e mu fu u y fy gv mw Jh 90H
byte a w Gu dkNOP command a w Gt jz p f b mo mjy e fa y ; z dkUjz p fy gw , f/
Convert immediate operand of "mov reg, " to offset u a w mhMOV reg, command
(reg u a w mh register u dkq dkv dkw my g/ ) x Jr Sm& Sdw Jh w dku f& dku f operand u dk offset w p fc k ( address
w p fc k) t jz p f a jy mi f; v Ja y ; E dki fp Gr f; u dkn Te fjy y gw , f/
Convert immediate operand of "mov memory, " to offset u a w mh MOV mem,
command x Jr Sm& Sdw Jh w dku f& dku f operand u dk offset w p fc k ( address w p fc k) t jz p f a jy mi f; v Ja y ; E dki f
p Gr f; u dkn Te fjy y gw , f/
Disassemble zero opcode instructions u a w mha t mu fy g instruction (00 00: ADD [EAX],
AL) u dkdisassemble v ky fc dki f; y gw , f/ y Hkr Se fq dk& i fa w mho lUu dkr a & G; c s, fy gb l; / y Hk( 4 ) /
Advanced analysis of Borland's RTTI (RTTI q dkw mu a w mhrun-time type information u dk
a jy mw my g/ )u a w mhIDA Pro u dkRTTI structure a w Gu dkp p fa q ; z dkUe JU z e fw D; z dkUc dki f; y gw , f/
Check "unknown_libname" for Borland's RTTI u a w mh RTTI structure a w G& Sdw Jht c g
unknown_libname t r Sw ft o m; e JUt r n fa w Gu dkp p fa q ; z dkUc dki f; w mjz p fy gw , f/
Advanced analysis of catch/finally block after function u a w mh catch/finally p w Jh
exception proceffing block a w Gu dk& Smc dki f; w mjz p fy gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 8 -



y Hk( 4 )
Allow references with different segment bases u a w mh o w fr Sw fx m; w Jh address u
o dr f; q n f; x m; w Jhw e fz dk; [ m character w p fv Hk; r [ kw fc Jh& i fa w mi f character a w Ge JUq dki fw Jh reference
a w Gu dko w fr Sw fc dki f; y gw , f/ ( character u k' fw p fc kt jz p f r a z mfjy c dki f; w mjz p fy gw , f/ )
Don't display reduntant instruction prefixes u a w mh listing u dk z w f& I& w m t q i fa jy a p z dkU
command prefix t c sdKUu dka z smu fx m; z dkUjz p fy gw , f/
Interpret int 20 as VxDcall u a w mh INT 20H u dk VxDcall/jump t jz p f b mo mjy e fc dki f; w m
jz p fy gw , f/
Enable FPU emulation instructions u a w mh INT 3?H w dkUv dk command a w Gu dk arithmetic
coprocessor command a w G& JU emulation a w Gt jz p f b mo mjy e fa p z dkUjz p fy gw , f/
Explicit RIP-addressing u dk o w fr Sw fr , fq dk& i fa w mh y & dk* & r fr Sm relative instruction pointer
(RIP) addressing u dko Hk; r , fv dkU , lq r Smjz p fy gw , f/ ' Dflag u kda w mh 64-bit y & dkq u fq ma w Gt w Gu f
q kd& i f a & G; c s, fa y ; x m; & r Smjz p fy gw , f/
- System DLL directory o lu a w mh IDA Pro u & Sm& r , fh DLL z dki fa w G& Sd& m directory u dk o w fr Sw f
w mjz p fy gw , f/ o w fq dki f& m library a w Ge JUq dki fw Jh.ids z dki fa w Gu a w mhc Ri f; c su fjz p fy gw , f/
( 4 ) Disassembler Window
IDA Pro r Sma w mh t v ky fa w mfa w mfr sm; r sm; u dk disassembler window x Jr Sm v ky fa q mi fMu w m jz p fy g
w , f/ ' ga Mu mi fh ' D window t a Mu mi f; u dk t a o ; p dw fo dz dkUv dky gw , f/ ' Da e & mr Sm a x mu fjy c si fw mu a w mh ' D
disassembler & JU developer a w G[ m disassemble v ky fx m; w Jh function e JU o lUu dk& Sma z Gw Jhe n f; v r f; a w Gu dk
a z mfjy E dki fz dkU t a v ; t e u fx m; p Of; p m; c Jhw , fq dkw Jht c su fjz p fy gw , f/
Hiding functions Disassembler window r Sm function a w Gu dk t u sOf; c sHK; y Hkp H ( hide) ( o dkU)
t u s, fc sJYy Hkp H( unhide) w dkUe JUjy E dki fy gw , f/ t u sOf; c sHK; y Hkp Hr Sma w mh function u dk p ma Mu mi f; w p fa Mu mi f;
w n f; e JU jy w my g/ ' Dt o Hk; 0 i fw Jht * Fg& y fu o i fhu dkdisassemble v ky fx m; w Jhu k' fa w Gu dkv G, fu lp Gmz w f& I
a p E dki fz dkU t a x mu ft u l jz p fa p r Smy g/ Function a w Gu dk t u sOf; c sHK; ^ t u s, fc sJUz dkU numeric keypad u
(+)/(-) key a w Gu dk t o Hk; jy K& y gr , f/ ' gr Sr [ kw f& i fa w mh View menu u Hide/Unhide u dk a & G; E dki f
y gw , f/
Indicating functions y Hk( 5 ) u a w mh disassmebler window u dkjy w mjz p fy gw , f/ ' Dwindow & JU
b , fz u ft u sq Hk; t y dki f; u dk o w dx m; jy D; Mu n fhy g/ ' Dt y dki f; u a w mh listing u dkMu n fh& I& Sma z G& mr Sm & dk; & Si f;
a p z dkUjz p fy gw , f/ Command a w Gu dk t p u fu a v ; a w Ge JUjy x m; y gw , f/ w u , fv dkU p ma Mu mi f; r Sm
t p u fw p fp u fr y g& i fa w mhr Sw fc su fw p fc ky g0 i fw Jhstring v dkU t " dy m, f& y gw , f/ w u , fv dkU o Hk; p GJo lu
' Dt p u fa e & mr Sm mouse e JUE Sdy fv dku fr , fq dk& i fa w mh IDA Pro u ' D address a e & mr Sm breakpoint
o w fr Sw fy gw , f/ Jump a w Gu dka w mh t p u f( o dkU) w p fq u fw n f; r sOf; a Mu mi f; a w Ge JU jy y gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 7 9 -


w p fq u fw n f; r sOf; a w Gu a w mh unconditonal jump (JMP) a w Gu dkn Te f; w mjz p fjy D; t p u fa w Ge JU
r sOf; a w Gu a w mhcondtional jump (JE, JNZ) a w Gu dkq dkv dkw mjz p fy gw , f/

y Hk( 5 )
Using Special Comments y & dk* & r fw p fc kt w Gi f; u address a w Gr Sm b , f jump a w Gu dk
( conditional jump E Si fh unconditional jump o dkUr [ kw f CALL command) v ky fa q mi fw , f?
n Te f; w , fq dkw Jh t x l; r Sw fc su fa w Gy g0 i fy gw , f/ w u , fv dkU reference u o w fr Sw fx m; w Jh address
q Djump v ky fw , fv dkU t " dy m, f& & i f r Sw fc su fa w G[ m CODE XREF e JUp a v h& Sdy gw , f/ w u , fv dkU ' D
command [ m a ' w mt jz p f refernce v ky fc Hx m; & w , fq dk& i fa w mh ( Oy r m MOV EAX, OFFSET
L1) DATA XREF e JUp y gw , f/ ' Dr Sw fc su fa w Gu dka w mh cross-refernce a w Gv kdUa c : jy D; cross-
refernce t r Sw ft o m; a e mu fr Sm colon v dku fy gw , f/ o lUa e mu fu address a w Gu a w mh ' Drefernce
a w Gp jz p f& m function ( o dkU) section & JUt p u dkjy w mjz p fy gw , f/ ' D address u kd mouse e JU E Sdy fjc i f;
t m; jz i fh o w fr Sw fx m; w Jh instruction & Sd& mu dkn Te f; w Jh u k' ft y dki f; t p u dk pop-up window t a e e JU
a c : , lE dki fy gw , f/ Address r Sma w mh <><> t u & ma w Gy g0 i fr Smjz p fjy D; ' D instruction u dk
refernce v ky f& m u k' f& Sdw Jhp ma Mu mi f; u dk o w fr Sw fy gw , f/ Reference p w i fw Jh p ma Mu mi f; & Sd& mu dk
w e f; o Gm; c si f w , fq dk& i fa w mh address a e & mr Sm double-click E Sdy fjy D; o Gm; v dkU& y gw , f/
o w fr Sw fx m; w Jh p ma Mu mi f; t w Gu f reference t a & t w Gu f[ m 4 c kx u fe n f; a e r , fq dk& i f o lw dkUu dk
p m& i f; o m jy Kp ky gw , f/ ' Dv dkr S r [ kw f& i fa w mh reference a w Gu dk t p u fa w Ge JUjy r Smjz p fy gw , f/
w u , fv dkU ' D address a w Gx Ju w p fc ku dk right-click E Sdy fjy D; Jump to cross reference
u dka & G; v dku f& i f v dkt y fw Jhitem & Sd& mu dk w e f; o Gm; E dki fy gw , f/ y Hk( 6 ) / ' gjy D; & i fa w mhy Hk( 7 ) t w dki f; address
a w Gt m; v Hk; p m& i f; a y : v my gv dr fhr , f/ y Hk( 7 ) u o i fo Gm; c si fw Jhaddress u dka & G; jy D; OK u kdE Sdy fv dku fy g/
y Hk( 6 )
y Hk( 7 )
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 0 -


Designating an address Disassembler window x Ju listing u a w mh address w p fc ku dk
o w fr Sw fw Jh e n f; v r f; r sdK; p Hku dk jy y gw , f/ Oy r mt m; jz i fh? w u , fv dkU API function w p fc ke JU y w fo u f
v mc Jh& i fa w mh ' Dfunction & JUt r n fu dk w du sp Gmo w fr Sw fy gw , f/ ' Dt jy i f IDA Pro u r sm; a o mt m;
jz i fh string a w Ge JUy w fo u fv m& i fa w mh p Hkp r f; o d& Sdx m; w Jh string a w Gu dk reference a w G& JUt r n fa w G
t jz p f t a jc c Hx m; a y ; y gw , f/ e r le mjy & r , fq kd& i fa w mhYou are wrong! q dkw Jhp mo m; y gw Jhstring u dk
IDA u reference t jz p fo w fr Sw f& mr Sma w mh ' D string u dk aYouAreWrong t jz p fa jy mi f; v dku fy g
w , f/ "a" e JUp w Jh ' D prefix a w Gu dk IDA Pro u ASCII string a w Gt jz p f, lq y gw , f/ y Hk( 8 ) /
t jc m; t r n fa w Gt m; v Hk; u a w mh prefix e JU address w p fc ka y : r lw n f jy D; function t r n fa w G( o dkU)
data address a w Gu dko w fr Sw fy gw , f/ y Hk( 9 ) r Smjr i f& w Jht w dki f; a t mu fy g prefix a w Gu dk o i fht a e e JU
Mu HKa w GU& E dki fy gw , f
sub_ Function
locret_ Address of the return instruction
loc_ Instruction address
off_ Data specifying the address (offset)
seg_ Data specifying the segment address
asc_ Address if an ASCII string
byte_ Byte address
word_ Word address
dword_ Double word address
qword_ Address of a 64-bit value
flt_ Address of a 32-bit floating-point number
dbl_ Address of a 64-bit floating-point number
tbyte_ Address of an 80-bit floating-point number
stru_ Structure address
algn_ Alignment directive
unk_ Address of an univestigated area

y Hk( 8 )

y Hk( 9 )
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 1 -


Using the context menu Disassembler window e JU t v ky fw GJv ky fr , fq dk& i f window w p fc kr Sm
right-click E Sdy f& i fa y : v mw Jh context menu a w Ge JU t o m; u sa e & r Smjz p fy gw , f/ t c sdKU menu a w G
u a w mho i fa & G; w Jht y dki f; u dkr lw n fjy D; u GJjy m; a e r Smjz p fy gw , f/ Oy r m function t r n fa w G? instruction
a w G? r Sw fc su fa w Ge JU a & G; x m; w Jh block w dkUt w Gu f listing r Smjz p fy gw , f/ t c sdKU menu item a w G
u a w mh debugger w p fc ku Jho dkUa o m IDA Pro & JUv ky fa q mi fc su fa w Ge JU y w fo u fa e y gw , f/ ( Run to
cursor? Add breakpoint E Si fh Add execution trace) / t x l; o jz i fh Rename menu u dk
o w djy Ka p v dky gw , f/ ' Ditem u o i fhu dk command & JU operand a w Gu dkw n f; jz w fa p E dki fv dkUy g/
Navigating a listing t a & ; Mu D; q Hk; u dp & y fu a w mh listing u dk & Sma z Gjy o jc i f; y Jjz p fy gw , f/
Crossreference u n Te fjy w Jha e & ma w Gu dk w e f; o Gm; E dki fy gw , f/ a e mu fw p fe n f; u dkv J ( cross-
reference a e & mr Sm double-click E Sdy fjc i f; jz i fh) return jy e fv ma p z dkUt w Gu f t o Hk; jy KE dki fy gw , f/
( Oy r m? conditional jump q Do dkU? CALL command q Do dkU? o dkUr [ kw f MOV EAX, OFFSET
address u Jho dkUa o m command w p fc kx Jr Saddress q Do dkU) / o dx m; & r Smu a w mhIDA Pro [ m o i fh& JU
jump a w Gt m; v Hk; u dk r Sw fx m; w mjz p fw Jht w Gu f Mu dKu fw Jht c sde fr Sm Mu dKu fw Jha e & mu dk
button a w Go Hk; jy D; a & SUw dk; ? a e mu fq kw fv dkU& y gw , f/
( 5 ) t jc m; Window r sm;
- Hex View ' Dwindow r Sm u l; w i fx m; w Jhmodule & JU hex dump a w Gy g0 i fjy D; ' Ddump a w Gu dk ASCII
p mv Hk; a w Ge JUjy y gw , f/ ' Dwindow [ m disassembler window e JUy w fo u fw Jht & e f window w p fc kjz p fw mr dkU
o le JUv G, fu lp Gm synchronize v ky fE dki fy gw , f/ ' Dv dkv ky fc si fw , fq dk& i fa w mh y Hk( 1 0 ) t w dki f; hex window & JU
w p fa e & m& mr Sm right-click E Sdy fjy D; Synchronize with IDA View u dka & G; & y gr , f/

y Hk( 1 0 )
' gq dky Hk( 1 1 ) t w dki f; VA 0040B440 & Sd& m IDA View u dkw e f; a & mu fv mr Smjz p fy gw , f/ q dkv dkw mu
a w mhHEX p mv Hk; 5E [ m POP ESI e JUn Dw , fq dkw Jht a Mu mi f; y g/

y Hk( 1 1 )
- Exports ' D window r Sma w mh export v ky fx m; w Jh function a w Gp m& i f; y g0 i fy gw , f/ ' g[ m DLL
a w Ge JUw GJv ky f& mr Sm t o Hk; 0 i fy gw , f/ o mr e f exe module a w Gt w Gu f start function v dkUt r n f& w Jh element
w p fc kw n f; jy r Smy g/ y Hk( 1 2 ) /

y Hk( 1 2 )
- Imports ' Dwindow r Sma w mh import v ky fx m; w Jh function a w Ge JU module a w Gp m& i f; y g0 i fy gw , f/
Import v ky fx m; w Jh function u dk double-click E Sdy fr , fq dk& i fa w mh disassembler window q Da & mu fo Gm; r Sm
jz p fjy D; entry point t a e e JU a w GU& Sdr Smjz p fy gw , f/ ' ga Mu mi fhr dkU y & dk* & r fx Ju ' Dfunction e JUy w fo u fw Jh cross-
reference a w Gt m; v Hk; u dko i fht a e e JU v G, fu lp Gm & Sma w GUE dki fr Smjz p fy gw , f/ y Hk( 1 3 ^ 1 4 ) /
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 2 -



y Hk( 1 3 )

y Hk( 1 4 )
- Names ' D window r Sma w mh import v ky fx m; w ma w Gt m; v Hk; e JU library function a w Gy g0 i fy gw , f/
IDA Pro u o dx m; w Jhvariable a w Ge JU lable a w G& JUt r n fa w Gv n f; y g0 i fy gw , f/ t r n ft o D; o D; & JU b , fz u f
jc r f; r Sm& Sdw Jhp mv Hk; ( t & ky f) u a w mht r n ft r sdK; t p m; jz p fy gw , f/ y Hk( 1 5 ) /
L Library function
F Regular functions and API functions
C Instructuion (label)
A ASCII string
D Data
I Imported function

y Hk( 1 5 )
t r n f& Sd& mu dk double-click E Sdy fjc i f; jz i fh ' Dt r n fu dka c : o Hk; w Jh y & dk* & r f& JUw n fa e & mu dk w e f; a & mu fo Gm;
r Sm jz p fy gw , f/ w u , fv dkU t r n fo p fu dk z e fw D; c si fw , fq dk& i f a jy mi f; c si fw Jhaddress & Sd& ma e & mr Sm Insert key
u dkE Sdy fjy D; a jy mi f; v dkU& y gw , f/ y Hk( 1 6 ) /

y Hk( 1 6 )
& dku fx n fhv dku fw Jht r n fu a w mhdisassembler window r Smv Ja y : a e r Smjz p fy gw , f/ y Hk( 1 7 ) /

y Hk( 1 7 )
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 3 -


- Functions ' D window r Sma w mh library function a w Ge JU import v ky fx m; w Jh user function a w G
t y gt 0 i f IDA Pro u o dx m; w Jhfunction a w Gp m& i f; u dkjy r Smjz p fy gw , f/ y Hk( 1 8 ) /

y Hk( 1 8 )
- Strings ' D window r Sma w mh disassembler u & Sma w GUx m; w Jh string a w Gt m; v Hk; y g0 i fr Smjz p fy gw , f/
y Hk( 1 9 ) /

y Hk( 1 9 )
String w p fc ku dk double-click E Sdy fjy D; Mu n fhr , fq dk& i f ' Dstring u dk a Mu n mx m; w Jha e & mu dk w e f; a & mu f
o Gm; r Smjz p fy gw , f/ o mr e ft m; jz i fha w mh ' Dwindow r Sm C p w dki f string a w Gu dko mjy o y gw , f/ t jc m; string
t r sdK; t p m; a w Gu dk jy o c si fw , fq dk& i fa w mh ' Dwindow r Sm right-click E Sdy fjy D; Setup command u a e a & G; a y ;
v dkU& y gw , f/ y Hk( 2 0 ) /

y Hk( 2 0 )
- Structures ' Dwindow r Sma w mh disassembler u & Sma w GUx m; w Jh structure a w Gt m; v Hk; y g0 i fr Smjz p fy g
w , f/ y Hk( 2 1 ) / Structure t o p fw p fc ku dkx y fx n hfc si f& i fa w mhInsert key u dkE Sdy fjy D; x n fhv dkU& y gw , f/

y Hk( 2 1 )
- Enums ' Dwindow u a w mh y & dk* & r fw Gi f; r Sm p Hkp r f; v dkUa w GU& Sdx m; w Jh enumeration a w Gt m; v Hk; u dk jy o z dkU
& n f& G, fy gw , f/
' Dht jy i f disassembler u t jc m; window a w Gu dkv J t o Hk; jy KE dki fy gw , f/ t x l; o jz i fh Library
window jz p fy gw , f/ t Ge fv dki f; help p e p fr Sma w mh ' Dwindow u dk signatures window v dkUa c : y gw , f/ ' D
window r Sma w mh library function a w Gu dko d& Sda p z dkU t o Hk; jy Kw Jh signature p m& i f; u dk jy o y gw , f/ y Hk( 2 2 ) /
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 4 -


y Hk( 2 2 ) r Smjr i f& w mu a w mhfunction signature a w Gy g0 i fw Jhz dki ft r n f? ' Dsignature a w Gu kdt o Hk; jy Kjy D; a w GU& Sdx m;
w Jhfunction t a & t w Gu f? ' Dsignature a w Gu dkt o Hk; c sx m; w Jhfunction a w Ge JUq dki fw Jht r n fw dkUjz p fy gw , f/

y Hk( 2 2 )
w u , fv dkU v dkt y fw Jhsignature z dki fa w Gu dk x y fx n fhc si fw , fq dk& i fa w mhInsert key u dkE Sdy fjy D; E Sp fo u f
& mu dk x n fho Gi f; E dki fy gw , f/ y Hk( 2 3 ) / ' Dz dki f& JU signature a w Gu dka w mh function t o p fa w Gu dk o da p z dkUt w Gu f
c su fc si f; t o Hk; jy Kr Sm jz p fy gw , f/

y Hk( 2 3 )
( 6 ) Menu E Si fhtoolbar
IDA & JU menu e JU toolbar a w Gt a Mu mi f; u dka w mht Mu r f; z si f; y J& Si f; jy o Gm; r Smjz p fy gw , f/
File menu & JU item a w Gu a w mha t mu fy gt w dki f; jz p fy gw , f
Open Disassemble v ky fr , fhexe module u dkz Gi fhz dkUjz p fy gw , f/
Load z dki ft r sdK; r sdK; u dk z Gi fhz dkUjz p fy gw , f/ Reload the input u a w mh disassemble v ky fx m; w Jh
module u dk jy e fz Gi fhz dkUjz p fy gw , f/ Additional binary file u a w mh database x Ju dk a e mu fx y f
binary file w p fc k v mu l; w i fr Smjz p fy gw , f/ IDS file u a w mh o w fr Sw fx m; w Jh import library & JU
function a w Ge JUy w fo u fw Jht c su ft v u fa w Gy g0 i fw Jh IDS (intrusion-detection system)
z dki fu dkz Gi fhz dkUjz p fy gw , f/ ( IDS directory x Jr Sm& Sdw Jh IDS z dki fa w Gt m; v Hk; u dk t v dkt a v smu fu l; w i fr Sm
jz p fy gw , f/ ) PDB file q dk& i fa w mhdebug t c su ft v u fa w Gy gw JhPDB z dki fu dk u l; w i fr Smjz p fy gw , f/
DBG file q dk& i fv J debug t c su ft v u fa w Gy gw Jhz dki fu dk u l; w i fr Smjz p fy gw , f/ FLIRT signature
file q dk& i fa w mh signature z dki fa w Gu dku l; w i fjy D; t o Hk; c sr Smjz p fy gw , f/ ( y Hk- 2 2 r Smjr i f& w Jh signature
window x Jr Sm w ln Dw Jhv ky fa q mi fc su fu dk v ky fa q mi fr Smjz p fy gw , f/ ) Parse C header file u a w mh
structure t o p fa w Ge JU enumeration t o p fa w Gu dk a e mu fx y fa Mu n mz dkUt w Gu f header z dki fu a e
t r sdK; t p m; t " dy m, fz Gi fhq dkc su fu dk z w f& Iw mjz p fy gw , f/ ( Enums E Si fh Structures window r sm;
t a Mu mi f; w Gi fMu n fhy g/ )
Produce File Disassemble v ky fx m; w Jhu k' fa y : r lw n fjy D; z dki ft o p ft r sdK; r sdK; u dk z e fw D; a y ; y gw , f/
.map u dka w mhdebugger a w Gu t o Hk; jy KE dki fy gw , f/ .asm u a w mhAssembly z dki fjz p fjy D; .lst u a w mh
IDA View r Smjr i f& w Jhu k' fa w Gu dk o dr f; a y ; w mjz p fy gw , f/ .inc? .exe? .dif. ? html p w Jh z dki fa w Gt a e
e JUv J o dr f; a y ; E dki fy gw , f/ Hex-Rays Decompiler u dk install v ky fx m; r , fq dk& i fa w mh disassemble
v ky fx m; w Jhexe z dki fa w Gu dk.c (C source code) z dki ft jz p f decompile v ky fa y ; E dki fy gw , f/ y Hk( 2 4 ) /
if ( LCData ) {
lstrcpyA(v5, &LCData);
v7 = LoadLibraryExA(ValueName, 0, 2u);
v3 = v7;
if ( !v7 )
{
v14 = 0;
lstrcpyA(v5, &LCData);
v3 = LoadLibraryExA(ValueName, 0, 2u);
}
}
y Hk( 2 4 )
IDC file Scritp z dki fa w Gu dku l; w i fz dkUe JU t v ky fv ky fa p z dkUjz p fy gw , f/
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 5 -


IDC command Script a w Gu dkc su fc si f; execute v ky fE dki fz dkU window u dka c : o Hk; w mjz p fy gw , f/
Save v u f& Sd disassemble v ky fa e w Jh database u dk .idb extension e JUo dr f; q n f; w m jz p fy g
w , f/
Save as v u f& Sd disassemble v ky fa e w Jh database u dk o w fr Sw fx m; w Jht r n fe JU o dr f; w m
jz p fy gw , f/
Close Disassemble v ky fa e w Jhdatabase u dko dr f; jy D; disassemble v ky fx m; w Jhz dki fu dky dw fw my g/
Edit menu & JU item a w Gu a w mha t mu fy gt w dki f; jz p fy gw , f
Copy a & G; c s, fx m; w Jht & mu dkclipboard q Du l; w i fy gw , f/
CODE Block u dkexe u k' ft jz p fa jy mi f; v Jy gw , f/
DATA a & G; c s, fx m; w Jhblock u dka ' w mt jz p fa jy mi f; v Jy gw , f/
Struct var Block u dka & G; x m; w Jhstructure t jz p fa jy mi f; y gw , f/
Strings String t jz p fa jy mi f; v Jy gw , f/ ( String t r sdK; t p m; u dka w mh submenu u a e
a & G; c s, fE dki fy gw , f/ )
Array Mu dKw i fo w fr Sw fx m; w Jhparameter a w Ge JU array t jz p f a jy mi f; v Ja y ; y gw , f/
Undefine Mu dKw i fr o w fr Sw f& a o ; w Jh structure w p fc k& JUa ' w mt jz p f a & G; x m; w Jh block
u dkt r Sw ft o m; v ky fy gw , f/
Name t r n fa jy mi f; w mjz p fy gw , f/
Operand type Operand t r sdK; t p m; u dko w fr Sw fw mjz p fy gw , f/
Comments r Sw fc su fa w Gx n fho Gi f; z dkUjz p fy gw , f/
Segments Segment a w Gu dku dki fw G, fE dki fz dkUjz p fy gw , f/
Structs Structure a w Gu dku dki fw G, fE dki fz dkUjz p fy gw , f/
Functions Function a w Gu dku dki fw G, fE dki fz dkUjz p fy gw , f/
Other Alignment directive u dko w fr Sw fjc i f; ? instruction r sm; ( o dkU) a ' w mr sm; u dk
& dku fx n fhjc i f; ? t a & mi fw p fa & mi fjz i fhjy jc i f; p w Jh t jc m; v ky fa q mi fc su fa w Gu dk a q mi f& Gu fw m
jz p fy gw , f/
Plugins t jc m; plug-in module a w Gu dkt o Hk; jy Kz dkUjz p fy gw , f/
Jump menu & JU item a w Gu a w mh disassemble v ky fx m; w Jhu k' fa w Gx Ju jump t r sdK; r sdK; t w Gu f
& n f& G, fw mjz p fy gw , f/ Oy r m o w fr Sw fx m; w Jh address q Djump v ky fjc i f; ? o w fr Sw fx m; w Jh function q D
jump v ky fjc i f; ( o lUu dka w mh list u a e a & G; c s, fE dki fy gw , f) ? y & dk* & r f& JU entry point (EP) q Djump v ky fjc i f; ?
o w fr Sw fx m; w Jhlabel q Djump v ky fjc i f; / y Hk( 2 5 ) /

y Hk( 2 5 )
Search menu & JU item a w Gu a w mh disassemble v ky fx m; w Jhp mo m; x Jr Sm& Sdw Jh & Sma z Gw Jhv ky fa q mi f
c su ft r sdK; r sdK; t w Gu f & n f& G, fy gw , f/ Oy r m p mo m; u dk& Smjc i f; ? a e mu fx y f a ' w m block u dk& Smjc i f; ? a e mu f
x y f Assembly instruction u dk& Smjc i f; ? a e mu fx y f byte sequence u dk& Smjc i f; / y Hk( 2 6 ) /
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 6 -



y Hk( 2 6 )
View menu & JU item a w Gu dk t o Hk; jy Kjy D; IDA Pro & JU jr i fu Gi f; a w Gu dk E Sp fo u f& mx m; v dkU& y gw , f/
Window t o p fa w Gu dk x y fz Gi fhjc i f; ( Open Subviews) ? toolbar a w Gu dk z e fw D; jc i f; E Si fhz su fjc i f; Toolbars) ?
function a w Gu dka z smu fjc i f; ^ jy e fa z mfjc i f; ( hide/unhide) w dkUjy Kv ky fE dki fy gw , f/
Debugger menu u command a w Gu a w mh o i fhu dk IDA Pro & JU t r sdK; r sdK; a o m debugging
p Gr f; a q mi f& n fu dk jy o r Smjz p fy gw , f/ ' ga w Gu a w mhbreakpoint r sm; u dku dki fw G, fjc i f; ( Breakpoints) ? watch
r sm; u dku dki fw G, fjc i f; ( Watches) ? trace v dku fjc i f; ( Tracing) ? register t r sdK; r sdK; x Jr Sw e fz dk; r sm; u dk Mu n fhjc i f;
( General registers? Segment register? FPU register) w dkUjz p fy gw , f/
Option menu u a w mhIDA Pro & JU setting a w Gu dk a jy mi f; v Jz dkUt w Gu fjz p fjy D; t a p my dki f; r Sm u Re fa w mf
& Si f; jy c Jhw Jht w dki f; jz p fy gw , f/
Windows menu & JU item a w Gu dkt o Hk; jy Kjy D; IDA Pro & JU window a w Gu dku dki fw G, fE dki fy gw , f/
Help menu item a w Gu a w mho i fhu dke n f; y n my dki f; q dki f& m t a x mu ft u la w Ga y ; r Smy g/
( 7 ) Built-In IDA Pro y & dk* & r fb mo mp u m;
IDA Pro disassembler r Sma w mhbuilt-in y & dk* & r fb mo mp u m; w p fc ky gv my gw , f/ ' ga Mu mi fhy & dk* & r f
i , fa v ; a w Gu dk u dk, fw dki fa & ; o m; E dki fjy D; o lw dkUu dk disassemble v ky fx m; w Jhu k' fa w Gt jz p f jy e fv n fp p fa q ;
Mu n fh& IE dki fr Smjz p fy gw , f/
IDA Pro r Sm w c gw n f; y gv mw Jh y & dk* & r fb mo mp u m; [ m C (ANSI C) b mo mp u m; e JU a w mfa w mf
a v ; q i fy gw , f/ ' ga Mu mi fhv J ' Db mo mp u m; & JUt r n f[ m IDC (Interactive Disassembler C) jz p fa e w my g/
IDC subdirectory a t mu fr Sm ' Db mo mp u m; e JUy w fo u fw Jh e r le my & dk* & r fa w Gy g& Sdy gw , f/ IDA Pro u a w mh
' Dy & dk* & r fa w Gu dk disassemble v ky fx m; w Jhp mo m; a w Gt jz p f analyze v ky fz dkUt w Gu f t o Hk; jy Kw mjz p fy gw , f/
' Dy & dk* & r fa w Gt m; v Hk; u dk analyze v ky f& w m v G, fu ly gw , f/ ' ga Mu mi fh o i fht a e e JU IDC b mo mp u m; u dk
a v hv mz dkUt w Gu f o lw dkUa w Gu dkt o Hk; jy KE dki fy gw , f/
IDC command a w Gu dkexecute v ky fz dkU e n f; v r f; E Sp fc k& Sdy gw , f/
1 / y x r e n f; v r f; u a w mh command window u dkt o Hk; jy Kv dkUjz p fy gw , f/ Command window u dka c : o Hk; z dkU
File | IDC command u dka & G; jy D; a o mfv n f; a u mi f; ? Shift + F2 u dkE Sdy fjc i f; jz i fha o mfv n f; a u mi f; t o Hk; jy KE dki f
y gw , f/ Command window u a w mh y Hk( 2 7 ) t w dki f; jz p fy gw , f/ ' D window r Sm IDC command a w Gu dk
w n f; jz w fE dki fy gw , f/ t m; v Hk; jy D; p D; & i fa w mh OK button u dkE Sdy fv dku f& Hky gy J/ IDA Pro u a w mh ' Dcommand
a w Gu dk b mo mjy e fjy D; execute v ky fz dkUMu dK; p m; r Smjz p fy gw , f/ ' ga Mu mi fh ' Dwindow u dkt o Hk; jy Kjy D; & dk; & Si f; v Sw J
hy & dk* & r fa w Gu dkIDC b mo mp u m; e JU a & ; o m; E dki fr Smjz p fy gw , f/
2 / y dkjy D; t a jc c Hu sw Jhc sOf; u y fe n f; u a w mh .IDC extension t r n fe JU IDC u k' fa w Gy g0 i fw Jhz dki fa w Gz e fw D; z dkUy g/
y & dk* & r fw p fc ku dkz Gi fhz dkU File menu u Idc file u dka & G; & y gr , f/ ' Da e & mr Sma w mh y & dk* & r fu dk compile v ky fjy D;
c su fc si f; execute v ky fr Smjz p fy gw , f/ ' Dht jy i f y Hk( 2 8 ) t w dki f; a e mu fx y f window w p fc kx y fa y : v mr Smjz p fjy D;
y & dk* & r fu k' fu dkw n f; jz w fz dkUe JU y & dk* & r fu dkexecute v ky fz dkU button a w Gy g& Sdr Smjz p fy gw , f/
IDC r Sm y & dk* & r fa & ; r , fq dk& i f t e n f; q Hk; a w mha t mu fy gt c su fa w Gy g0 i f& r Smjz p fy gw , f/
#include <idc.idc>
static main(void)
{
// Your Code here;
}
t c e f; ( 7 ) IDA Pro Advanced 5.2 r dw fq u f
- 8 7 -



y Hk( 2 7 )

y Hk( 2 8 )
e d* Hk; c sKy ft a e e JU IDA Pro t a Mu mi f; t w Gi f; u su so dc si f& i f Chris Eagle a & ; o m; w Jh ]The IDA Pro
Book The Unofficial Guide to the World's Most Popular Disassembler} p mt ky fu dkz w f& Iz dkU
t Mu Ha y ; v dky gw , f/
.., PE Header
..


tcef;(8) - PE Header
, PE . . ._ .
Portable Executable (PE) .-. 32bit 64bit Windows OS .-.. .._._--
executable (EXE) . object (DLL) ..--- ..-. _..-. Portable .-....
-- 32bit 64bit Windows OS .-_-.. _ .-- .._.-.- __.-.
PE ..-. ._.._..-. wrap ..- executable code .-- ... Windows OS
loader -- -.-.--.-- encapsulate ..- data structure -. . .
link .-- dynamic library reference .- API - export import . table .-
resource management data .- TLS data .- -. . - . - - . - -.-.-.
Microsoft _.._. VAX/VMS ....- COFF . . -. . .. -._.. -.
"Portable Executable" ...--.-.-. intent -. Windows .. .- - ._
-. .. . _.. _ . CPU -... . ._..-. Windows NT . ..- Windows
95 ...- Windows CE -.. .._. Microsoft compiler .- - - ..- OBJ
. .- -.-. COFF (Common Object File Format) ._.._. encoding ... ...- .._
-. 64-bit Windows .- . ..-. PE .- _..__... -. ,. . _..-.-
.-. PE . -. . . - ._ . ._ .-_ ...- _.. -.











,
PE ... _....-. section . . -. -. -.-. - .---_.._. ..--.-
.-. .-..- - - _.. -. Windows NT application -....-. ..--.
. - .- -.-. .text .bss .rdata .data .rsrc .edata .idata .pdata .debug - _..-.
application .- -.-. section .-....-. -.-. . - - - .- _ .
- -. _.. . -.
.-... .-...- section .--.-.
executable code section .text (Microsoft) CODE (Borland)
data section .data, .rdata, .bss (Microsoft) DATA, BSS (Borland)
resources section .rsrc
export data section .edata
import data section .idata
debug information section .debug
Section ._.--. --..-. ...-. OS - ._ .- - . ..
-. .._- .- - -.-. disk ...- PE . -. . ._ . -. . - . .- .- -
. . - ._. -. . -_ .- ._-. . --. . . - - .- - disk .-
...........-.-..-.--..--.-- .....
-. _.. .. . - . - . . -. . -_ . - .- - -. .- - - . Windows loader
- -...-- ........ -...-- ....-.- .._.-...-.
DOS MZ Header
DOS Stub
PE header
Section Table
Section 1
Section 2
Section
Section n
.., PE Header
.


........ - - - .- - .-. ........ -. section .-.. .-.
_ . . ..- . .. . ....-. .. debug information,
. - . . - .- - . . disk ...- . item -. -_ ..- -. - _...
-. -.._-. . .-. Windows -.._- page -.__- virtual memoy management
.. ._-. _.. -. Section .-- RAM .- .- - - . - -. 4KB - memory page
.- - - _ .. ._ . section ....-. page .. - .- -. Virtual memoy -.-.
,-. _..-.
,
Virtual memory ... - -.-. ... . .- - physical memory - - - -
. .. .... ... .- .. OS . . _-.. ._. - .-. - .- . - -. . - . -
.- . _- .... - - . .- ..-. -. process -. -. physical memory address -
--. . .. .. . -.- page table _ . .-. . - . - .. .. .. .- - table entry
-...-. -.-. ..-. ._...-. page table -. physical memory . . . .- _- ..
-., ._-. .- ...- -. . - . - page .- _.. ._..-._.. -. - .
.- -.-.
, ._..- _... . .... address space .-- .-..-. Address space .-.-.-. .-.
access ... _..- .._.. page -._..-. .-.-.-. - -. .,
process .. .-.-. ...-.- -..--. -.-. .._...._--. ._-.
. -.-... crash _.. _.. -. -. address space - .. . . - ._.. ..-.
, .-.- -. access . . - ._ .. ..- - - .- ..- - ._- .
. -. PE ..-.. section .-- -. -.._-...-. .- ......-
module -. - .- - - . memory manager - .- _ . . ..-... - .- . .
section header - . - setting .-. ._- section . .. .- - memory manager -.
memory page .-... access .-..- .-. - -. - - .- . - ..-
section -. .--... ..-... execute -... .._.--. Section ..
..-. ..-. fresh page -.-...-. ._._..-.
-. _.. _.. Windows - - page size -.-. 4096 bytes (1000h) _.. -. Disk .-
page ....-. exe -- _.....-. -._..- .. -.._-...-.
-.-_. ...._-........ _.. ._-.. PE header ...-_- alignment field
.. -. .-.--.-. section alignment file alignment Section alignment .-.
-.-. ......--. .-... section .- - -. _ . . . -. _.. -.
, PE . .- - windows loader - . - . - - .- - . . .- ...- module
.-. . .- - ...._ ..- - .. . address - HMODULE .-. . - .
.., PE Header



..- module -.-. exe .-. process -.- - - .-. resource .- .. .-
... _. -. PE . _....-- .-... .-....-. ...._ . . - .
.. relocation,
, DOS Header
PE . .- -. DOS header .._. . ... 64 bytes _.. .- -. -. -.
DOS -..- -._.. -. ._-. DOS - . - - executable ._..._-.. .
.-_... header ..-.. ...._...- DOS stub - .. _..-. DOS stub -.-.
..._. 'This program must be run under Microsoft Windows' . - .....- - ... _ .
.-.-.-. DOS -. _.. . -. Windows application .-- build .. linker -
. exe .- winstub.exe .- stub -.- link -..--. _..-.
DOS header -. structure -._.._. windows.inc ., winnt.h ..-.. .- ....
...-. --. ... assembler ., compiler - install _.... .-.--
\include\ directory ..- . . .. -. DOS header . . member .-- 19 _. magic
lfanew -.-. . - ......-. .-.
IMAGE_DOS_HEADER STRUCT
e_magic WORD ?
e_cblp WORD ?
e_cp WORD ?
e_crlc WORD ?
e_cparhdr WORD ?
e_minalloc WORD ?
e_maxalloc WORD ?
e_ss WORD ?
e_sp WORD ?
e_csum WORD ?
e_ip WORD ?
e_cs WORD ?
e_lfarlc WORD ?
e_ovno WORD ?
e_res WORD 4 dup (?)
e_oemid WORD ?
e_oeminfo WORD ?
e_res2 WORD 10 dup (?)
e_lfanew DWORD ?
IMAGE_DOS_HEADER ENDS
PE ...- DOS header magic ...-.-.-. 4Dh 5Ah -.. MS-DOS
. . _. .- --. ._.. - Mark Zbikowsky --...._- MZ ..., _.._. .-. .--
DOS header _.. ._-. . ..-.... -. MZ -. .. . .. .. . ._.. _ . hex editor ...
- -. PE ..... .-_..-.
lfanew -. DWORD -._.._. DOS header .. DOS stub .._-.... -_
-. . . . -. . - .- - PE header offset -. Windows loader - offset -
... -. ._-. . DOS stub - .-. . _ . PE header . - - - . ... -. . -
DWORD (double word) = 4bytes ., 32bit WORD = 2bytes ., 16bit --.. DWORD
- dd _. . -. dw -.-. WORD _.. _ . byte ---.-. db ,

,
DOS header -.-. PE . ... 64 bytes _.. .- ._-. . ._. -. . -.-
, ... ._-.. offset 0000 -. offset 0030 ,_.. -. DOS stub .. ..-..
.., PE Header



DWORD . . -.-.-. 00h 01h 00h 00h _..-. ..-.....-. ._. ._ _ .
_.....-.-. 00 00 01 00h _.._. PE header .- .. .._.. -. PE header -._ .
. ..- -_.. - 50h, 45h, 00h, 00h .- -. "PE" .-.....-.. ._.---.,
--. .. PE header ..- -... . PE ... NE .- .-. 16-bit
Windows . . - NE . _.. -. ..- LE .- Windows 3.x virtual device
driver (VxD) _.._. LX .- OS/2 2.0 . _.. -.
, PE Header
PE header -.-. IMAGE_NT_HEADERS .- structure -._..-. structure
.. Windows loader - .._..- - - .- -. IMAGE_NT_HEADERS ..
member _. .-- windows.inc .. ......._._..-.
IMAGE_NT_HEADERS STRUCT
Signature DWORD ?
FileHeader IMAGE_FILE_HEDER <>
OptionalHeader IMAGE_OPTIONAL_HEADER32 <>
IMAGE_NT_HEADERS END

Signature -.-. DWORD _.. _ . . . . -.-.-. 50h, 45h, 00h, 00h . - - . .
. _.- - - PE', _.. -.
FileHeader -.-. PE . ..- 20bytes _.._. . physical layout -.-.-
-. .. section .- - exe .--.--,
OptionalHeader -.-. ..- 224bytes _.._. PE . - .- logical layout
- .- - ._-. ..- -. .. AddressOfEntryPoint, .....- ...-.
-.-. FileHeader member -. - member .- structure -_. windows.inc ..
......._._..-.
FileHeader - ..- - .... _. -.
IMAGE_FILE_HEADER STRUCT
Machine WORD 014C (Intel 386)
NumberOfSections WORD 0005
TimeDateStamp DWORD 846C26F0
PointerToSymbolTable DWORD 00000000
NumberOfSymbols DWORD 00000000
SizeOfOptionalHeader WORD 00E0
Characteristics WORD 818E (File is exe)
IMAGE_FILE_HEADER ENDS
-.-..-.......-.-. -.-. - .._...---. ... NumberOfSections
-.-. PE . - section .-- .-_.._.. _ _.. _.. . ._-.
Characteristics ...-. flag .-_. .--. PE .- executable .., DLL ....-.-
._....-. PE header .-. ._..-...-. NumberOfSections Section -...
..-. ._.-. ,

,
, -.-.- ...- PE . . . section .-. .--. PE browse Lord
PE - - . ._..-.
OptionalHeader -.-. 224bytes ...-. ..-.. 128bytes ...-. DataDirectory
-.
.., PE Header



IMAGE_OPTIONAL_HEADER32 STRUCT
Magic WORD 010B (PE32)
MajorLinkerVersion BYTE 02
MinorLinkerVersion BYTE 19
SizeOfCode DWORD 00000600
SizeOfInitializedData DWORD 00001800
SizeOfUninitializedData DWORD 00000000
AddressOfEntryPoint DWORD 00001000 (CODE)
BaseOfCode DWORD 00001000
BaseOfData DWORD 00002000
ImageBase DWORD 00400000
SectionAlignment DWORD 00001000
FileAlignment DWORD 00000200
MajorOperatingSystemVersion WORD 0001
MinorOperatingSystemVersion WORD 0000
MajorImageVersion WORD 0000
MinorImageVersion WORD 0000
MajorSubsystemVersion WORD 0003
MinorSubsystemVersion WORD 000A
Win32VersionValue DWORD 00000000
SizeOfImage DWORD 00006000
SizeOfHeaders DWORD 00000400
CheckSum DWORD 00000000
Subsystem WORD 0002 (Windows GUI)
DllCharacteristics WORD 0000
SizeOfStackReserve DWORD 00100000
SizeOfStackCommit DWORD 00002000
SizeOfHeapReserve DWORD 00100000
SizeOfHeapCommit DWORD 00000000
LoaderFlags DWORD 00000000
NumberOfRvaAndSizes DWORD 00000010
DataDirectory IMAGE_DATA_DIRECTORY
IMAGE_OPTIONAL_HEADER32 ENDS
AddressOfEntryPoint PE loader - PE . - run . . _.. . . .. . ..
instruction . RVA . . . _- - . . .- . instruction - ...-. RVA -
._..-._.._.. instruction - _-._.._.. _.-. Packer .- -.-. ........_.
. - decompression stub .- _._--._..--- -.- execute -.. . entry
point OEP, .- .-..._._..-. Starforce _ ._. protect ..- ..--. disk
... -_.. .CODE section .-. .-. Execute ... virtual memory -
..- .-. . - virtual address ... _-.
ImageBase PE ..--- preferred load address ..._. --. field . .
- - . .-. 400000h _.. .. . PE loader - 400000h -.- virtual address .. .-
-.-. _-....... 'Preferred' . - . .. . . - -.-. _.. module -.-
address range . . .- .. . PE loader -. address . . . - - .- ... . .- - - . .
. ...- -.-. 400000h _.. -. Microsoft Visual C++ x.x Method2 [Debug] compile
..- ..---.-. 1000000h _.. -.
SectionAlignment . - . - section ...- alignment ... .._ --. field
-- . .-. 4096 (1000h) _.. section -.-. 4096bytes ._. .- ... - .- ..- .-
.. . -. --. .. . section -. 401000h .._. .....-. 10bytes
.-. ..- section -. 402000h . . .. . 401000h 402000h _-..- - .- address
...--.-. ........_. .._.. .---.
FileAlignment . - section ...- alignment ... . ._ --. field -
-..-. 512 (200h) _.. section -.-. 512bytes ._. .- ... - .- ..- .- ..
. -. --. .. . section -. offset 200h . . _ . . . ...-. 10bytes
.-. ..- section -. 400h .. ... 512 1024 _-..- - .- offset ...--.-. ..
_.. .---.
SizeOfImage . - . - PE image . . . . . ..._.. -. SectionAlignment
align ..- header ... section .. . . . _.. -.
SizeOfHeaders section table header ...- .... _..-. _._. -..-.
.....-. ...- section .......- ....- . - _ . _ .-.
.., PE Header



DataDirectory IMAGE_DATA_DIRECTORY structure 16 - array -. _.. _ . -. . -.
import address table (IAT) PE . - .._- .- data structure -. . .- . . .-.
,.. ..._..-.-.-. PE header .._.- hexeditor _-_ ..-. .- _. .
-.-. DOS header PE header -. . - ... hexeditor .._-_ ....
. . .- -. - _ .. . DOS STUB -.-. . ... ._. . . -.

,
PE header ._-..- Olly .. ....- _-_-. Olly debugger - ._. Alt +
M -. ,-. _...

,
,- PE header .- .......- right-click ._. Dump in CPU - .. ,-.
_. . . _.. -.

,
.., PE Header



,- hex window . . right-click ._. special - PE header - . . - .-. .,
-. _...

.,
, Data Directory
DataDirectory ._-. . ._... . .-. DataDirectory .-. OptionalHeader
..-.. 128bytes _..-. OptionalHeader .-.- PE header _..- IMAGE_NT_
HEADERS ..-.. member _.. -.
...._.. DataDirectory -. 16 - IMAGE_DATA_DIRECTORY array -.
_.._. structure -..-. PE .- .._-.- data structure -. . .- . . .-. Array
....-. import table _--.-.-..- item -..- __.-. Structure ..
member . . _ . -. - -_ .. ..--.- ....- _-.
IMAGE_DATA_DIRECTORY STRUCT
VirtualAddress DWORD ?
isize DWORD ?
IMAGE_DATA_DIRECTORY ENDS
VirtualAddress -.-. data structure relative virtual address (RVA) _.. -. isize
-.-. byte _- data structure . ..._.. -.
windows.inc .. ._-_...- directory 16 ._ .- -.-. ..- - . _.. -.
.., PE Header



IMAGE_DIRECTORY_ENTRY_EXPORT equ 0 (export symbols)
IMAGE_DIRECTORY_ENTRY_IMPORT equ 1 (import symbols)
IMAGE_DIRECTORY_ENTRY_RESOURCE equ 2 (resources)
IMAGE_DIRECTORY_ENTRY_EXCEPTION equ 3 (exception)
IMAGE_DIRECTORY_ENTRY_SECURITY equ 4 (security)
IMAGE_DIRECTORY_ENTRY_BASERELOC equ 5 (base relocation)
IMAGE_DIRECTORY_ENTRY_DEBUG equ 6 (debug)
IMAGE_DIRECTORY_ENTRY_COPYRIGHT equ 7 (copyright string)
IMAGE_DIRECTORY_ENTRY_GLOBALPTR equ 8 (unknown)
IMAGE_DIRECTORY_ENTRY_TLS equ 9 (thread local storage)
IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG equ 10 (load configuration)
IMAGE_DIRECTORY_ENTRY_BOUND_IMPORT equ 11 (bound import)
IMAGE_DIRECTORY_ENTRY_IAT equ 12 (import address table)
IMAGE_DIRECTORY_ENTRY_DELAY_IMPORT equ 13 (delay import)
IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR equ 14 (COM descriptor)
IMAGE_NUMBEROF_DIRECTORY_ENTRIES equ 16
LordPE .. .. exe .-.-_-_... ,-. _...

,
,- _-_ .. . _... highlight _...- . --..._---..
.-.. ._.- __.-. .-..

,
,- _-_ .. . import directory - ... _..-. ... 4bytes -.-.
40000h ._. ._ . -._.. -. , _.. -. Import directory . ...-.-. 1CDCh bytes
_.. -. PE header .-. DWORD 80bytes -. _.-.. import directory RVA
_.. -. .. -.-. resource directory _.._. ....-.-. TLS directory _.. -.
--- directory -.- ...-- .. data directory -.._ . virtual address
- - - - .. ..- .-. -. directory -. -. section ..-..-. ... virtual
.., PE Header



address - .._ -. section .. -. directory .- . . -. . -. - -- offset -
... section section header - .._
, Section Table
Section table -.-. PE header ..-.. --.-. .-. IMAGE_SECTION_
HEADER structure . array -._.._. member . .. .. . attribute virtual offset .- PE
. - section . .. . ._-. .- .- -. Section .---..._.-.- file
header - . member _..-..-. .- PE header .. 6bytes ...., --.
.. PE . . . section .-.. table - structure .. .. 8 . . Header
structure ....-. 40bytes _. windows.inc . . ._-_...-.
IMAGE_SECTION_HEADER STRUCT
Name1 BYTE IMAGE_SIZEOF_SHORT_NAME dup (?)
union Misc
PhysicalAddress DWORD ?
VirtualSize DWORD ?
ends
VirtualAddress DWORD ?
SizeOfRawData DWORD ?
PointerToRawData DWORD ?
PointerToRelocations DWORD ?
PointerToLinenumbers DWORD ?
NumberOfRelocations WORD ?
NumberOfLinenumbers WORD ?
Characteristics DWORD ?
IMAGE_SECTION_HEADER ENDS
IMAGE_SIZEOF_SHORT_NAME equ 8
structure - member -.-. ...--- --..._-.- member
.- ._-. .- .. ._..
Name1 field -. 8bytes -., ._-. label -. ..._.. _ . - - . .. .-.
-. .- ... .- . -. ASCII string .----- \0 (null terminator) . ..- ..
. - .
VirtualSize DWORD union, Section ..- .-..- --....._.._. byte
_-. . -. disk ...- section . ... SizeOfRawData, - _..-.._..
-. --. - . .-. SizeOfRawData - _- ..- section . . . _.- __ .. ._..
-.
VirtualAddress Section RVA _.. -. PE loader -. .-. section - map ..
field - -..- ....._. .._-. ._-.. --. field - -..-. 1000h
_.. .. . PE .-. 400000h .. .-_. section -.-. 401000h .. ...
SizeOfRawData Disk .- ...- section .-. . ..._.. -. Module header .
FileAlignment .-.-._.._. --. .-..-. virtual size - . . section
--..--. ._ __... _..-. Section .. uninitialized .-..- .-.-
. . ..-. . __.. ..
PointerToRawData Raw Offset, PointerToRawData -. . . -. -.._-.
. .-. . -. . .-. section .-..-- offset _.. . --. . -.. __..
... section .-..- . ..- - - . . -. module header - FileAlignment .- .- .
_.... Section . . unintialized .-..- .- .- . . ..-. .__.... PE loader
-.-. field ..--..-..__. .--. section . . .-..- . . -. . . ..
Characteristics section . . - exe - initialized data uninitialized data .-..-- .._.
.- _ ..- flag .- -.
FLAG EXPLANATION
00000008 Section should not be padded to next boundary
00000020 Section contains code
00000040 Section contains initialised data (which will become initialised with real values before the file is
launched)
00000080 Section contains unitialised data (which will be initialised as 00 byte values before launch)
00000200 Section contains comments for the linker
00000800 Section contents will not become part of image
00001000 Section contents comdat (Common Block Data)
.., PE Header



00008000 Section contents cannot be accessed relative to GP
1-800000 Boundary alignment settings
01000000 Section contains extended relocations
02000000 Section can be discarded (e.g. .reloc)
04000000 Section is not cacheable
08000000 Section is pageable
10000000 Section is shareable
20000000 Section is executable
40000000 Section is readable
80000000 Section is writable
PE header . .- .- section .-- -.-.--.- hexeditor _-_ -
,-. _...

,
,- . . ... _..-.-.-. PointerToRawData _..... ,-.
LordPE _-_ ..

,
Section header _....-. section .-- .-. Disk .-. . ..-. section ..
..-. offset -.-..--. .-.- Optional header ...-- FileAlignment -..
._. .- ... - . -._.. -. Section .... .-..-_-.....-. . _.- _.. .. .
RAM .- - .- . . section .--. page boundary .. . _. -. . .- _--.
._-. . section .... ... byte -. memory page .-.-. x86 CPU page
.- -.-. 4kB align .._. IA-64 -.-. 8kB align ..-. alignement
- . .- .-. OptionalHeader .. SectionAlignment .. .....-.
.._ --. optional header -. file offset 981 . .. ._ . FileAlignment -. 512
_.. .. . .. . section -. byte 1024 .. .... .-....-.-. .. section
.-- PointerToRawData ., VirtualAddress -. .. -. ._-. alignment .-
_ . ..... . .-. - .
, PE File Sections
Section .-.. -.-.-. - .-. resource _..- - - _.. -.
Section ...... header -. body raw data,-.-. Section table .. section
header .-... section body .-.. _-.... ..._. ..-. .-..-- decipher
_ ... . header .. ..----.- __.... linker - . - - . ._ . . ._ .
. -.
Windows NT application -. . . _- - .- . - ..- section ._ 9 ..- -.
. - .- -.-. .text .bss .data .rdata .rsrc .edata .idata .pdata .debug -_..-.
application .- . ..-. section .- .. .. - . .- . ..-. - _ . . -.
.., PE Header
.


, Executable code section
Windows NT . ..-. code segment ...-. .text ., CODE .- section
-.-_... -. Windows NT - virtual memory .....-..__. _-....- code
secton -._.- OS --.. application developer - - . . .. . . - ..-.
secton .. ....-..._- entry point IAT .-_- jump thunk table --.
, Data section
.bss section - function -.., source module - static _..._-_...- variable
... application -- uninitialized data .-- -...._-.
.rdata -.-. literal string constant debug directory information - read-only
.-..- - - . ..._-.
_.. variable .-... stack - .- ... automatic variable . -.,- .-. .data
section .. ...-._..-.
, Resource section
.rsrc section ...-. module -. -.-- resource - - .- -. .
.. 16bytes -.-. _.. section .... header _..-. ... section .-.
.-- resource editor ..__._-_... resource tree . . ._ ...-. _. . .
ResHacker -.-. . . - tool -. _.. _ . resource .-- ..__. .- _ . __ _ .
_.-. ,

,
tool - dialog box .-_-_... .....-. shareware application .- . .
- nag screen .-- ResHacker .._. .-...-..-.
, Export data section
.edata section ...-. application ., DLL - - - export directory -.
... export ..- function .- address .- ._ .- -. - .-. ..- .-.
.... - ._..
, Import data section
.idata section ...-. Import Directory Import Address Table import ..
- function .--.-- --... -. .- ..-. ....- ........
_.. -.
, Debug inforamtion section
Debug information -.-. .debug section .. .....-. PE .-. .._...-
debug . .- - - -. ... .._. .-. .dbg extension _.. -. , Debug section . .
debug information .- ... debug directory .--.-. ....-._.- .rdata section . .
_--. Debug directory ....-. .debug section ..- debug information - __._-
-.


.., PE Header



, Base Relocation section
Linker - exe . -. - . - . - . . . - . - -. ... . - map-in .
.-.- ..-. -.__. linker - exe .- - .-.- --. address .-
...-. --. .. loader -. linker - ..-- base address ..-.-.. -.-
. .. . .reloc section .-.- ...---_ ...
.reloc section ..- entry .-- base relocation .-. -.._-...-. .--
.._.-. loaded image base address ..-_ Base relocation .- -.-. image -
location .- - . ._ ...-._.. _ . . - - . ._ . - . .-. .-. . .. Base relocation
. -.-. _ ._ ... .. ..-. Base relocation entry .-- chunk -.-.
package ..-. Chunk ... .-. image - 4KB page -.-- relocation ..._
-.
Base relocation -...-.... ..-. _-_ .. Exe .-.-
base address 0x10000 - ..-. . ._-. Image - offset 0x2134 -. string
address - pointer -. _.. -. String -. physical address 0x14002 - .-. ._-.
pointer .. 0x14002 - . . -. . - load . . loader - physical address 0x60000
...-- image - map .._-.. .._.--. Linker -....- base load address
--. load address -_-.. _....-- delta .-. ... ..-. delta -. 0x50000
_.. -. Image -. .-. . - . . . 0x50000bytes ....-.._-. string -. . ..-.
address 0x64002 .. _..-. Pointer -. string -_._.-. ...-. ...-.-. exe
... string .-_.- pointer . - . -_ ..- - base relocation -.-.
Base relocation - .._.-. loader - base relocation address ..-..-.... delta -..-
.. .-. ... ..-. loader - . . pointer -.._..- 0x14002 .. 0x50000 - .. .
.._.._. _..- 0x64002 -.-. pointer . - . _ . . .. . _.. -.
, Export Sections
section -.-. DLL .- . -- .- -. ..- ....._..- ...--.-.
Win32 Programmer's Reference -_.._. DLL ._-. .- ._..-._.. -.
In Microsoft Windows dynamic-link libraries (DLL) are modules that contain functions and data. A DLL is
loaded at runtime by its calling modules (.EXE or DLL). When a DLL is loaded it is mapped into the address space
of the calling process.
DLLs can define two kinds of functions: exported and internal. The exported functions can be called by other
modules. Internal functions can only be called from within the DLL where they are defined. Although DLLs can
export data its data is usually only used by its functions.
DLLs provide a way to modularize applications so that functionality can be updated and reused more easilly. They
also help reduce memory overhead when several applications use the same functionality at the same time because
although each application gets its own copy of the data they can share the code.
The Microsoft Win32 application programming interface (API) is implemented as a set of dynamic-link libraries
so any process using the Win32 API uses dynamic linking.
Funtion .-- DLL -. - ._ . ... _ ..-. . oridianl . ... _ ..-. .
_ .. . . . export .-. Ordinal .-.-.-. 16-bit (WORD) - .-. _.. _ . function
-.- --- DLL -. . . ._... . .- . - ..-. Ordinal _. export _.- ..-
.. . .. ... ...
--. function -.- ._ export .. . _.. DLL .- . , exe .- -
function - ..... .--. GetProcAddress ..- .._.. ordinal .._-.
GetProcAddress function -. export ..- DLL address -_..-. Win32
Programmer's Reference -.-. GetProcAddress - ..--. ._..-.
--..-. -... Microsoft - ... __ .. - ., ... . highlight _. ..-..- -
.- .._ . .- .. -.
GetProcAddress
The GetProcAddress function returns the address of the specified exported dynamic-link library (DLL) function.
FARPROC GetProcAddress(
HMODULE hModule, // handle to DLL module
LPCSTR lpProcName // name of function
);
Parameters
.., PE Header



hModule
Identifies the DLL module that contains the function. The LoadLibrary or GetModuleHandle function
returns this handle.
lpProcName
Points to a null-terminated string containing the function name, or specifies the function's ordinal value. If
this parameter is an ordinal value, it must be in the low-order word; the high-order word must be zero.
Return Values
If the function succeeds, the return value is the address of the DLL's exported function.
If the function fails, the return value is NULL. To get extended error information, call GetLastError.
Remarks
The GetProcAddress function is used to retrieve addresses of exported functions in DLLs.
The spelling and case of the function name pointed to by lpProcName must be identical to that in the EXPORTS
statement of the source DLL's module-definition (.DEF) file.
The lpProcName parameter can identify the DLL function by specifying an ordinal value associated with the
function in the EXPORTS statement. GetProcAddress verifies that the specified ordinal is in the range 1 through
the highest ordinal value exported in the .DEF file. The function then uses the ordinal as an index to read the
function's address from a function table. If the .DEF file does not number the functions consecutively from 1 to N
(where N is the number of exported functions), an error can occur where GetProcAddress returns an invalid, non-
NULL address, even though there is no function with the specified ordinal.
In cases where the function may not exist, the function should be specified by name rather than by ordinal value.
See Also
FreeLibrary, GetModuleHandle, LoadLibrary
GetProcAddress - - -.._-. . -. . .-. export ..- function ._
.- address .-- Export Directory - structure -... ...._... -.-.-.
Export Directory - ....-. -.._-...-. .-. data directory - .. .
element _.._. .-.-- RVA -. PE header . offset 78h ... .
Export structure - IMAGE_EXPORT_DIRECTORY .-. ... member .
11 _. -.-. ..._-.-.
IMAGE_EXPORT_DIRECTORY STRUCT
Characteristics DWORD ?
TimeDateStamp DWORD ?
MajorVersion WORD ?
MinorVersion WORD ?
nName DWORD ?
nBase DWORD ?
NumberOfFunctions DWORD ?
NumberOfNames DWORD ?
AddressOfFunctions DWORD ?
AddressOfNames DWORD ?
AddressOfNameOrdinals DWORD ?
IMAGE_EXPORT_DIRECTORY ENDS
nName Module internal ._ _.. -. field -. -. -.._-...-. .
._- ....- ._... ._..... PE loader - internal ._- . ._
. ..
nBase Starting ordinal number index .-- function address array _....-.,
NumberOfFunctions Module - export ..- function .... ..--.-_.. __.
.-.,
NumberOfNames ._ export ..- ..---. -..-. module ..-
function/symbol .. . - . .- - - . - .- - . . NumberOfFunctions -
.. .... -. . -. 0 _.. . -. ... ..-. module - ordinal ... export
. -. --. .- . . . export .. function/symbol ... data directory
- export table RVA -. . __.. . ..
AddressOfFunctions Module/Export Address Table (EAT) . . - function .- RVA
.- pointer .- array -.- __- RVA -. Module ..- function .- .. .
.- RVA .--.-. array -... ...._..._. field -. array head - __.-.
AddressOfNames Module/Export Name Table (ENT)..- function ._.-.- RVA
.- array - __.- RVA -.
.., PE Header



AddressOfNameOrdinals .__.... function/Export Ordinal Table (EOT) .- ordinal
.-- 16-bit array -.- __.- RVA -.

,
._-.. IMAGE_EXPORT_DIRECTORY structure -. array .. ASCII string
table -. - _ .-. .._- .. . array -.-. EAT _.. _ . . -. export ..-
function .- address .-- function pointer .- array -. _.. -. _.. array . .
EAT EOT,-.-. assending .. _ run ._. function ._ .. -_ -.
._-.. function -. ._-- binary search - ...-.-._.._. _.. array
-. . ..- - . ordinal .. ._.-... Ordinal -.-. ..-.-. index -._.._.
function -- EAT _.. -.
EOT array -. ._ .- address .-_-.. linkage -._..-_-.._-. ... ENT
array - element _.... .---. .-.- ._...... associated address
-.... ._.._..-. ..-. address -... associate ..- ._ ._..-
_... --. alias .- function .--. -_- address - __._-...
..- . . ENT - EOT - element .-....

,
.._ --. DLL -. -. function ..-- export ... AddressOf
Functions (EAT) - _ ... array .. member ..-.-... NumberOfFunctions
field .. -....- ..
.., PE Header



Function -. address - . ._-.... OS - .. . Export Directory
- NumberOfFunctions NumberOfNames - - . .- .... ..- -. . -.-.
AddressOfNames (ENT) AddressOfNameOrdinals (EOT) - __- array -. function
._ - .-. --. ENT .. ._-..- EOT ..- associated element -
-..- extract _. EAT -- index _...._-.
.._ - .-. - function - DLL . . functionX - ... _-_ .. --.
ENT ._..- element - - .-. - functionX .__.. pointer . ..-_.,-
. . . - .-. - . ENT - ._..- element .._-__. -.. 5 - .- -.
..- functionX RVA -.. -.-.- _-_..- EAT ._..- element . ._.. -.
--. function -. ordinal _...._..... .. EAT . ---..._.
_. . address - ....-. Function ._ - . .__ .- ordinal -. function
-. address -._.-. _..-_.... ..-.-.-. module -...... -
-. --. DLL - upgrade/update _. function .- ordinal .- -. ._. . ..
. DLL ...- _.. -..- - - . ..
, Ordinal .- .- _. export _.
NumberOfFunctions -.-. _... NumberOfNames _ .. -. _.. _.. -.
- . ..-. NumberOfNames -. NumberOfFunctions - _ .. . .. Function -.-.
ordinal .- .- .. export ... ENT EOT . . . .. . entry .-.. .---.
. . . ._ -. .-. ...---. ._.- function .-- ordinal .-.-.. export
. . . _.. -.
.._ --. function _. ENT .. entry ... module .. ordinal
.- .- export ..- function -. .-. ...-. function .- -.
-..- . -. -. . ... ... . - . -. . . - . . . exclusion .....
.-. .-.- EAT - entry .--. ordinal .-.- export ..- function .-
RVA .-- EOT -. reference .._ ..
-. ..-.-. .def ...- starting ordinal - .- .- . - . -. ..._.
,- table -. 200 . ..- . -. Array - .. . - .- entry ..- -
-- -......-- nBase member .. starting -..-_.._. loader - EAT .-
- index - . . - - . . -. ordinal -.- subtract -.
, Export Forwarding
-- . ..-. function .--. --- DLL -. -. export ..... --. -. .
.-.-.- .._-.-_.._.....- DLL -... - export forwarding .-.
.._ WinNT Win2k XP -.. kernel32.dll function _..- HeapAlloc -. ntdll.dll -
export ..- RtlAllocHeap function . forward ..-. ntdll.dll .. Windows
kernel --- interface _..- native API -. Forward _.- .DEF ...-
. instruction -.- link - . . ... - -._.. -.
Forward _.-. -_..- Win32 API set -. - . -_.. Windows NT
Windows 98 -_-.. internal API set - ..- low-level ..-_.._.....- ..-..
.._- Microsoft _ .. .-. _.. -.
Application .--.-. native API set ..- call function .- . . . .- .
-.._-...-. Windows 9x Windows 2k/XP - internal API set .-_-.. .-.-_...-
...- .- ._- ._-. . pack ..- exe ..-- unpack - OS -...
.- import .-- -.- reconstruct - _.. OS -. . . . . -. -.
forwarding .. ._-. ... _ ..-. . _..- - .- ._. . _ .._-. ... _ . .-. .
_.. . -.
..- - function,-.- forward .. . RVA -. - module ..- -
.-. address ._.. . - . EAT table .. DLL ASCII string .- pointer -. ..
... forward .. function ._ -. . ... ..-. . -. ntdll.dll RtlAlloc
Heap _.. . ..
.., PE Header



--. function -.-- EAT entry -. Export section . -.- ASCII string,
..- address -.- point _. .. function - forward ..-..-.
. ....
., Import Sections
Import section (.idata) ...-. DLL -. import ..- function .-...
- - .- -. - - .- - .... .... data structure .-.. ...._...-.
. - - .._- .. .-.-. ..- .. ... ... ... Import Directory Import Address
Table -_..-. executable ..-.. Bound_Import Delay_Import directory -
.-. Delay_Import -.-. -.-.--- ...._-.-. ... Bound_Import
directory -.-. ..-... ........ _..-.
Windows loader -.-.-. application - .._- DLL .--...- load
. .-- process address space _.. map ... _..-. _ ....... DLL
.-..- import ..- function .-... address .-- ...._.._. load -
.. executable -- .._.. ..-.
DLL -. - function .- address .--. static ._..-. ... DLL --
updated version .--....-. ._..--. ._-. application .-- .....
.....- function address .- . .__ . -_ ...- ...-.-. --._-. run
. . . executable .-.-.-- _-....... ._......- mechanism -. -
.-...-. - Import Address Table (IAT) -. . .__ . ._. .. -. -.
windows loader - DLL _.. load .. _._._...- function address .-.- pointer
.- table -. .._.. -.
Pointer table -.- ..__._. loader -. - - -. ... ... . - - .. . .-
.. import ..- function .- address .-- ._... .-....---. ..-
import table - ..-. . . . - - address - . .. ._.. -.
., Import Directory
Import Directory .-. --..-. IMAGE_IMPORT_DESCRIPTOR structure array
-. .._.. -. Structure -.-. 20bytes _.._. -.-.- PE . - -. function .- -
import ..-. . - DLL -.--._-...- -. .._ --. - .-.
- PE .- .-_- DLL . - function .-- import ... array .. IMAGE_
IMPORT_DESCRIPTOR .. . _.. -. array - structure .- - - _ _-
field .-. ...---. ... ..-.. structure .. ._.-__.- filed .- ...
Export Directory . . . . Import Directory -..... ..-. ....
-. PE header . 80 bytes _..-., ... ..-.. member .--.-. .._-...
_.. -.
IMAGE_IMPORT_DIRECTORY STRUCT
union
Characteristics DWORD ?
OriginalFirstThunk DWORD ?
ends
TimeDateStamp DWORD ?
ForwardChain DWORD ?
Name1 DWORD ?
FirstThunk DWORD ?
IMAGE_IMPORT_DIRECTORY ENDS
... member _.. - OriginalFirstThunk -.-. DWORD union _.. -. flag
. _ ._.. . -. -. _.. _.. Microsoft -.-. . ...- ._.._. WINNT.H -
update . -. .-. . . . . ... - . field . . --. -. . -.-.-. IMAGE_THUNK_
DATA structure .-- array -. RVA _.. -.
TimeDateStamp - .-. . _ .- . - -. . . . 1 _.., ForwarderChain
member -.-. .-.-.. binding -- .._-._.._. .... ........---.
Name1 ...-. DLL ASCII ._ . - pointer (RVA) -. -.
.., PE Header



..-.. member _..- FirstThunk .._. DWORD ....- IMAGE_THUNK_
DATA structure array -. RVA -. .. . array duplicate -._._..-.
--. ..._ function -. bound import _..-.. ..-...-. FirstThunk .. IMAGE
_THUNK_DATA . - RVA ... function --. address . . structure .- -
..- - . . .. . . -.
IMAGE_THUNK_DATA32 STRUCT
union u1
ForwarderString DWORD ?
Function DWORD ?
Ordinal DWORD ?
AddressOfData DWORD ?
ends
IMAGE_THUNK_DATA32 ENDS
IMAGE_THUNK_DATA ....-. DWORD union -. _.. -. Disk .-
. . ..-. . . . import ..- function ordinal .. IMAGE_IMPORT_BY_NAME
structure .- RVA -. -. -. _- . . ..-. FirstThunk - _ _.- -. -.
import ..- function .- address .- overwrite _. .-. Import Address Table
_.. .-.
IMAGE_IMPORT_BY_NAME -.-. ..--. ......-.
IMAGE_IMPORT_BY_NAME STRUCT
Hint WORD ?
Name1 BYTE ?
IMAGE_IMPORT_BY_NAME ENDS
Hint Hint ...-. function -_. DLL Export Address Table .- index -.
-.-. - .._. _..-. ._-.. DLL Export Address Table - function -
_. _-_ . -. index ..- ._- _-....- --. .-. match ._..-..
binary search -. ._ - ... _ .._..- _ _.. -. - . .-. . ._.. .-. .- - - .
linker .--.-. .... ._ .-.-_--.
Name1 Name1 ...-. import ..- function ._ -. ._ -.-. null-
terminated (\0) ASCII string _.. -. . - ... .- Name1 ....- byte .
......-._..-. ... .-. --.-.....-. variable . ... - field -.
_.. -. Structure -... variable ....- field -.- ..._.. _....
.._- .. . ..- -.-. import ..- DLL ._.- IMAGE_THUNK_
DATA structure array .- _..-. IMAGE_THUNK_DATA structure ....-. DLL
-. import ..- function -. . .- . . .-. OriginalFirstThunk FirstThunk -
__- array .- -. -_ -_ . run ._. null DWORD . ..- -. Import ..-
DLL ....-- .-.--. IMAGE_THUNK_DATA structure .._....- array
- .- _.. -.
..-- -... _.._...-.-. ._..-........ IMAGE_IMPORT_BY_
NAME structure .- _.. -. . . array ..- .-..-. _..-. .-- IMAGE
_IMPORT_BY_NAME structure .- RVA .- _._ ._ .. ._.. -. ._-. array ...
.. -_--...- ... .-.- --- duplicate, . ..-. . . .
.. array RVA - OriginalFirstThunk _ ... ._.. _ . - . array RVA -.-. First
Thunk _ ... ._.. -.
OriginalFirstThunk FirstThunk ..- element .- - -.-. DLL -. import
..- function .--. .-_-. .._ --. PE . - user32.dll -.
function ..- import .. . IMAGE_IMPORT_DESCRIPTOR structure ..-
Name1 .. user32.dll string RVA .._.._. array ...... IMAGE_THUNK_DATA
.. . ._.. -.
_.- array ..-.-. ._....-. ......_..... .......-.-.
Import Address Table FirstThunk - point - -. - - , Import Name Table . ,
Import Lookup Table OriginalFirstThunk - point - -. - - ,- _.. -.
.., PE Header



-.._-. IMAGE_IMPORT_BY_NAME structure .- pointer parallel array
. . -. Import Name Table .--.-. ......._. -..-.. modify . ..- -
-. Import Address Table .-- loader - --. function address .- overwrite --.
Import Name Table .-..- RVA .- array .--.-. .._..--... ._-.
--. import ..- function .- ._ - ... . - -_. .... PE loader -
.--.......
IAT - Data Directory - entry number 12 - point ... _ . linker .- -
directory entry - .- . - _ .. - . Application -.-. run ..._..-. Loader -.-.
- import resolution -... IAT .-- read-write _.. ....-....--..
.._-._.._. .. import .- - ._. .. . . _.. -.
-.-. Windows loader - read-only section .. IAT - overwrite .
-. . . .... . -. . - ._-. . _.. -. Load -...-. system - read/write
. import .-- page .- attribute .-- ....._. .-.--. -._-....-.
import table - page .-- initialize _.-. .- . protected ..- attribute
.-_..... ........-.

,
Import ..- function .- call .--. IAT - function pointer --..
_--. . ... . -. -. -.-. ..- -. - _ . . . -.
... FirstThunk array entry .---.- __.- address 00405030 - ....._-_
-_-.. .- loader - user32.dll - GetMessage address - overwrite ..
-.
GetMessage -.... ..-..._...-.-. ..--._..-.
0040100C CALL DWORD PTR [00405030]
_ .-.-. . . .._- .
0040100C CALL [00402200]


00402200 JMP DWORD PTR [00405030]
. .-.-. - ._ .- - - ... _ .. - .. .-. . .
.._.._. jump ._-. execute ... _-..._..-.
-.._-. import ..- function .- - _ . _ _--. Compiler -.-.
-_- module ..- ordinary function .- import ..- function .-- _.....
.--- ...-- - _- output -..-.... _..-. CALL [XXXXXXXX]
.., PE Header



[XXXXXXXX] ... ..-. - ..- .. . _._ .... --. - address -..._..-.
pointer .---., Linker -.-. import ..- function address - . . ..- - - .
._-. . - ... . chunk -.- .._.._..-. .- JMP stub . . _. . -.
Compiler - DLL ..- function .._._.. . .-. - . -.-. _declspec
(dllimport) modifier ..__. .-. ..-...-. .-. CALL DWORD PTR
[XXXXXXXX] - - ... ._.. -.
--. exe - compiler .. _declspec(dllimport) - ..._-.. -.--
.... import ..- function .--- ---.._...- jump stub .- ...
.-.-. transfer area ., trampoline ., jump thunk table .- ._.... ._--.
., Ordinal .- .- _. function ..... export _ .
Export section -.- ....... function .-- ordinal .- .- .. export
_--. .....-. caller's module . . function -- IMAGE_IMPORT_BY_
NAME . ..- - - . ... function -- function ordinal - IMAGE_THUNK_
DATA . .
exe .- -..- MSB (most significant bit) ., high bit -_-__..._.
IMAGE_THUNK_DATA -. . . ordinal -. ., RVA -._.. .. ._..
-. --. .. .- . - lower 31 bits - ordinal - . .-. . . . ._.. -.
--. ..- . - - .- - .. . - . .-.-. IMAGE_IMPORT_BY_NAME .-
RVA -._.... Microsoft -.-. DWORD MSB _..- IMAGE_ORDINAL_FLAG32 - -
._.... constant -. - .- . - ....-. . . ..-. 80000000h - . . -.
.._ --. function -.- ordinal .- .- export - . ordinal
-. 1234h _.._. function -- IMAGE_THUNK_DATA -.-. 80001234h _....
., Bound Import
Loader - PE . -. - . - . - .- - . . . -. import table - .. ..._ .
- DLL .-- process address ..-.-. -.--. ..-...-. .-.
FirstThunk - __- array ...-._. import ..- function .- --. address .-
IMAGE_THUNK_DATA .- - ... .-. --. -. ..-. -_ ._ . function
.- address .- - . - . .- - - . .. . PE loader - PE .- run --...
IMAGE_THUNK_DATA .-- __.. ..-.-. -.._-...-. address .-.
...
Bind.exe .- utility -. -.-. Microsoft compiler .- ._ . PE . IAT
(FirstThunk array) - .._. IMAGE_THUNK_DATA .-- import ..- function .-
address .- ....-. .--.-.. PE loader - address .-.-_..
.. .... -. --. DLL version .--. PE . --..- .- - _ - .. . , DLL
.-- __....... ... PE loader - bound address .- -. . ...-. - .. -.
._. address ..----. Import Name Table (OriginalFirstThunk array) ....-.
._-...--.-. INT -... INT . exe ..-- bound .- .
Borland linker _..- TLINK -. INT - .-.....--- Borland - - ..- . .- -.
bound .- . INT ..- . ._ . ..- - ..- -.-. ..-.-. ......
..
., Bound Import_Import Directory
Loader - bound address .-....._.-. .._- --.-- IMAGE_
BOUND_IMPORT_DESCRIPTOR structure . . .. -._.. -. Bound executable -...
-.-.-. structure .-..._.._. import ..- DLL . .. .- - -. -.-.
bound .._._..-.
IMAGE_BOUND_IMPORT_DESCRIPTOR STRUCT
TimeDateStamp DWORD ?
OffsetModuleName WORD ?
NumberOfModuleForwarderRefs WORD ?
IMAGE_BOUND_IMPORT_DESCRIPTOR ENDS
.., PE Header



TimeDateStamp member -. export .- DLL FileHeader TimeDateStamp
- - _ .. --. .- - _ loader - binary -. ......- DLL - bound .-.
.._. imort ...- __. patch . .. .- -. export .- DLL version .--
_ . ,. - . . . _ _ ..... _.. -.
OffsetModuleName member . . -.-.-. . IMAGE_BOUND_IMPORT_
DESCRIPTOR -. . _ . .- ASCII ..- DLL ._ offset (RVA .---.) _..
-.
NumberOfModuleForwarderRefs member ...-. IMAGE_BOUND_FORWARDER_
REF structure .- .- - _.. -.
IMAGE_BOUND_FORWARDER_REF STRUCT
TimeDateStamp DWORD ?
OffsetModuleName WORD ?
Reserved WORD ?
IMAGE_BOUND_FORWARDER_REF ENDS
structure _.- structure ..- ...- ..-.. member _..- Reserved
. -. - -..- .. . - -..- . . _.. DLL - forward - function -.-.-_.
bind .. forward ..- DLL . - . - - .- - . . .. ..... IMAGE
_BOUND_FORWARDER_REF . . forward ..- DLL .- .... - - - .-
-.
.._ kernel32.dll - function -._..- HeapAlloc -. ntdll.dll - RtlAllocate
Heap - forward -..._-. --. -.-.-- HeapAlloc - import ..-
application -.- .-.-_. application .. bind.exe - .._-... ntdll.dll
IMAGE_BOUND_FORWARDER_REF -._. .. kernel32.dll -- IMAGE_BOUND_
IMPORT_DESCRIPTOR -. ...
.- _ Function .-._.--. structure .-.. ...---. -.._-...-.
loader - -. function .-- IMAGE_IMPORT_DESCRIPTOR -. bound .. . -.
. ..
, Loader
.-.-. . ._.. .-. .- - ... OS - - - .....-- _
.-. _.- .., ...,- -. .- . . . . . -.- ._ -.
, Loader --..
Executable . -. . . Windows loader - process -- virtual address
--.- .-.-_. executable module - disk -. process address - ....
--. Loader - image - ..-... base address . . - .- . _- ...._ . . - . . .
Section .-- ....-. Loader - section table - .-..._. base address .. section
RVA -.._. ---.- address .. section ....- ..-. Page attribute
.--.-. section characteristic - .-.--._..-. .-... section .--
...._...-...-. load address -. ImageBase ..- ..-... base address _
._ loader - base relocation -...--.
..-...-. import table -....._. - DLL .-- process address ..-
map . -. DLL module .-...- ...._...-...-. loader - DLL ....
export section - .. ..._ . import ..- --. function address - __.. IAT - _
-. --. ..--. _..-., loader - error _..
Cracking .. . . - .... .-. .-..- -.-. DLL .- - - .- _ . import .--
._. .-._.. -. _.. ..--. .._. Microsoft - ..... - ._ .. - ntdll.dll
..- forward ..-, ....... function .- routine .- . ._ .._. .-. - .-.
....- ._.. Function forwarding .-. -_..- Win32 API set -.- .-_..
.-_- OS .-_-.. low-level function .--_.._.....- ..-.. .._- Microsoft _.
. .-. _.. -. GetProcesAddress ...-...- kernel32 function .-. .-. ......
-. --. - LdrGetProcAddress ntdll.dll - export .._...- ..- wrapper
.- .._.. -.
.., PE Header
.


.- - - .- -- _. .-. . . Win Debugger 6.x windows symbol
package Microsoft -. ...-.,- install .-. ..--.-. SoftIce 4.x
kernel-mode debugger - install .-. .. Olly ...-. Microsoft
symbolserver - .._.. configure .. function .-- _-_.-.-_-_..
..--.-. ._...- function ._.-.- pointer .- memory address .-
-. _.. _.. Olly -.-. user-mode debugger _.._. . application - load _... -..-
_.. - .-.- .. _ . .. Loading process -_-_.. .- _...-. .---. Win
Debugger ... - .- - Olly . .. .. . -.. .._...- ... OS -...-_ .
_.._. loading process - _.... ,

,
Exe .- load -.. --._-- API ....-. kernel32.dll
LoadLibraryExW function . . ...- . . ._-_ . ntdll.dll LdrpLoadDll function .
.-_ . ..-. function -. ..-...-.-- ...-- LdrpCheckForLoader
Dll LdrpMapDll LdrpWalkImportDescriptor LdrpUpdateLoadCount LdrpRunInitialize
Routines LdrpClearLoadInProgress .- subroutine 6 - ---.....-.
Module - - .- .._ . _.. ._.. . .. .. -.
Module ..- _.. .... - - .- - . - . . . ..-.
Module import descriptor table . ...-. -.- import ... _.. module
.-- .-.,
DLL ._-. .- _..-..- module load count - update -.
Module - initialize -.
- .- _ .._-. ._- flag .- - . .-.
.., PE Header




.,
DLL -.-. cascade .-..- _.. module .-- import . -. Loader
-. load . -..- . - .- - dependency .-- ........ module ... .
--. loop -.... ._-. LdrpWalkImportDescriptor ._ . _.. -.
... subroutine ..-. LdrpLoadImportModule LdrpSnapIAT -_..-. ...
Bound Imports Descriptor . Import Descriptor table .-- ..... RtlImageDirectory
EntryToData . call . . .- -. . - ... - loader -. bound imports .- - .. ...
...-. Import directory .... bound import .---- application - run -._..
-.
..- -. _.. - LdrpLoadImportModule -.-. Import directory . . - DLL
. .. .- - Unicode string -.- -_...--. ..-...-. .-.-- -.-_.._.
. . .. LdrpCheckForLoadedDll - ..-.
..- -. _.. - LdrpSnapIAT routine -.-. Import directory ..- DLL reference
.- .. .- -1 -.._..._.. .....-. .-.- _. bound import .-- ...
.. ...-. , ..- IAT memory prtotection - PAGE_READWRITE _.. ._. . _ .
LdrpSnapThunk subroutine . .. .. IAT ..- entry ....- ...... .--...
-.
LdrpSnapThunk -.-. . address - ..... function -. ordinal - ..__.
- forward .._.. .._.--. ..--.-. .-. ordinal - _. .....
.-- export table .- binary search -.- .._- LdrpNameToOrdinal - ...
-. --. function - ..--.. STATUS_ENTRYPOINT_NOT_FOUND - _ _ .
.- - .-. API entry point - IAT .. entry - ...._. memory protection - restore
_- LdrpSnapIAT . _ . ..-. . -. ... .- ._. . . .._ . IAT -
memory block .. . cache refresh _..-- NtFlushInstructionCache -..._.
LdrpWalkImportDescriptor . _ . ..-.
-. Windows version .-_-.. -..._..- -_.._....._..-. Windows 2000
...-. exe .- -..- ntdll.dll - bound import ... . import directory . ..
- .- . - ..-. .. -. Windows 9x Windows XP . ..-. import .-. application
- ...-. Loader - . - . . . - --. address -.- ---.. API
-.-. forward .. _ . . .... import ..- API -.- ......._..
-. Import ..- DLL . .. .. . ..- module .-.._. process - dependen-
cy .-...- ....._...._-.. ... .. ._.. -.


.., PE Header



, PE .-.. -__.
Cracker .- . protection scheme -.- crack . ...-...- _
.... -.- -.- _ . .. ._..- -- . . _----. .- -_
..- .-_..._-. -.-.
.--- ..--..- _.... section -. . . - - .._ -.
--. ..- - ... _ .... section - .. -.
Secion .. -. - . .-.
, _ .... section -. -__.
-.-.-. _.... section - - .- . ._ -. . CODE section ..
.._-.-. ...._. CODE section .. 00 .- __.-..- -._-_
-.. - cave' ...-. ..-.- cave -.-... CODE section -
LordPE _-_ _-..

,
... . - .-. - _. -.-.-. VirtualSize (00029E88) - SizeOfRawData (0002A0
00) - _ ._ .... .-. .- -. SizeOfRawData . -.-.-. . hard disk .. .
.- ....- .......- ._._ ._.. -. . - ... .- . VirtualSize -
hard disk .. . ... .. . ...- . .-. - -.._-. _.. -. . .-. compiler
.--. ._-... -_-..-.- section -. _ . . ...- .. . ._.. ..
. Hex editor _-_.-. CODE section .. DATA section ..-, - ,
-. .-..

,
..-.-- ..._. .-.- - ..- - . - .-. - . .....
. .- - .-. - _ . ... - .- - . - . - ... . - .-. - .
_.... size attribute - ._. ..... . ..-. section virtual size - 29E88 .._..
-. -.._-...-. compiler - ..- -.-.-..-. -_._.
.. -. ._-. LordPE .. CODE section virtual size - 29FFF _ -
.. -. -.-.- _.- _......._..-. RawSize -.-. 2A000 _.. -. ,
_. CODE . - ....... . right-click ._. edit section header - .. VirtualSize
.... 29FFF __. .- ...._.-
-. . ..-. - .-. - patch ..-- ...._.. ..-.-..-.- _
_ ._ - .-. - _ -.- Section Table - CODE section -- VirtualSize DWORD
- . ._.. -. - - .-. - . hexeditor .. -.-_ -.
-_. ...._..-- .. assembly stub ...._-_ .. .. .
..- LordPE ...-- entry point - . . 0002ADB4 ImageBase - . . 400000 - .-...
._-. Olly -. application - -.-...-. entry point -. 0042ADB4 _.... -.-.
-. ..--.-- ..__. entry point - ...-. 42AF00 - ._. ...
MOV EAX, 0042ADB4 ; Load in EAX the Original Entry Point (OEP)
.., PE Header



JMP EAX ; Jump to OEP
- .-. - . - .- - .. ._. - hexeditor - 0002A300h .... ...._..
-. Olly ...._.-- raw offset - RVA ._. ... . .-. .._ ...- . .. .

RVA = raw offset - raw offset of section + virtual offset of section + ImageBase
= 2A300h - 400h + 1000h + 400000h = 42AF00h
._-. Olly - . _ . - .-. - _ ....- ---..... Ctrl + G - . _ .
42AF00 - -__. --_....... _. ,-. _

,
..- . ..-. _ ..- - .- - . . .._ .. right-click ._. Copy to executable - All
modification - . . ..- message box .. Copy - . . - window -...
... window . . right-click ._. Save file - .._. _--...-.._ ...-
.-..._.... LordPE .. Entry point - 0002AF00 ._. ._ . . - . . .._ . -
Application . .. ._-_ _ . . . ...- . - Olly .. _._-_ Entry point ._. .
.-. .- ..

,
Hexeditor .._-_- ,-. .-.._.._. ..-.- ..._-. -...-..-
..

,
_.... section -_. section ..-._.-- ..._.._ ...._.-. ....-.
ARTeam . Goppit ........ PE File Format - .- _- .. -. ,
, PE header _......_. ._ .
PE header - ..-..-. --_ -.._-. PE header - ..- .... - . .
-. . . ._.. . . .. ._-. . -. -. - -.-_-__-..
-. RegisterMe.oops.exe,- Lena151 . ...,. . download ..-. -.-
Olly ..._..._-_- ,-..--.

,
.., PE Header



Data (dump) window -_-_- ,-. -........-. .-..

,
.-. ._ . . .._ ... .- - . . protector .-,.--. debug
.... PE header .. _.......- ..---. ._-. PE header -
_ ._ ...- _-_ - _-.. Alt+M (Memory map) - . - ,

,
,- _-_- section .- ..- .-. .- ... . . PE header -. -_ . .
-. - .-. - _. .-_.. - - .-. .-..- -. -. ..- . .. Header ..
- 5000 .-. _...-. ........_. header ..-. 1000 -. ._..-.
. -
.-. _ ._ ...- ._. .-. ._ .-._....- .- PE header -
_ ._ ... ._. . - - - . - -._. .-. - . . protector .._ -
. -., . -. -. Windows XP .. .-...-...... Olly -.-.
._....-..--- ..-.- .. _- ....- - - -..- .-. .
-. , .-. .-. ... .- ._.- . ..-. Header - _-_-_-.. ,
,
, VA 00400000 ..- . . - . - ,-. _... Mouse ..--
scroll _ ._ .. _-_ -
.,

., SizeofCode -. 40000400 ... 400 _.... -. VA 004000DC . .
..- .. . ._. .. .. . - .. - SizeofInitializedData -.-. 400004A00 ... A00 _..
..
BaseofCode -.-. 40001000 ... 1000 _.... BaseofData -.-. 40002000 ...
2000 _.. . . ..- - scroll _._..- ,

,
.., PE Header



NumberOfRvaAndSizes -.-. 40000004 ... 00000010 _.. . . Export Table
address -.-. 500000 ... ._ _.... Export Table size -_. 500000 ... ._
_.. . .
- .-. . - - Olly - .-..- tool .- -. .--..-. -
..-........... -._. - -.-.._.--..-- -_._.-_-.. -.-.
-.-. .-- Olly dump window . . . .
. - - . . ._. . - -..- - binary - .._. . - -_ ._.- -.
endian .- - .-. ... ..- -. _- . ._... . tool .- ..._-.-. -.
_.. _.. - .-. . -.-. . -. .. . -. .._ . .. .._- .-. -.

,
,.. _..--. dump window .. rightclick ._. Go to - Expression -
...-

,
_ . ,. . _..- - . 4000DC - -_- _. -_._.-.. rightclick
._. view executable file - . . - ,- . _. . ..

,
,- rightclick ._. binary menu . edit - .. ,-. _....

,
-._ . . . .- -_ ._.- _ --. . . opcodes .- - . - .
...-. . . , _.- ._. .-. memory module .. -_._.--.- .... -.-.-
_.- _ ...- -_._.-_..-. ,-. _...
.., PE Header




,
,.. _.-.-.-. -.-.- -_._.- .. ..- - -_ ._.- _ . _ . .-.
rightclick ._. Save file -..- _. Olly . . . - - . - _ _-_ - ,
-. _....

,
,. ..-. -..- .- section .-- __.-. .-... .-...-
- -. - -.-. ,. . _. - header .... 5000, .-. section .....
header -- ...._..- ..
PE header _..- Olly ._..-. --. ._-. PE tool -.- ..__.
._.._-_.. --.....- -.-.-. Lena151 ....,- UnpackMe#5
.exe -. -.- PEiD .. _-_ .. ..-. ,- . .- -.

,
--. .-. UnpackMe#5 .exe - Visual C++ .......-. .- - - . Protector -.
- Visual C++ .......-. .. _ .....-._.. -. Protector .-._-..-
.. ... .. ..- - - - - - - ...... .. .. -
.-.._ PE header -.-_. -..-_.......-. ... -.- Olly ..
._-_- ,

,
.., PE Header



,.._.--. -.- . .._ .. - -. run (hang) .-..- -. Task
manager -_-_-.-. .,.._..--..--.

.,
UnpackMe#5.exe - ..-.- task manager page file ....-. 149MB -.
87KB - UnpackMe#5.exe -.-.--.. -.._-. page file -- ...
. PE header .. _..-.--.-. ._-. UnpackMe#5.exe - PE Tools 1.5
._-__-.. ,

,
Tools menu - PE Editor -.._. UnpackMe#5.exe -.- ,-. _.-.
,- Optional Header button -..- ,-._...
.., PE Header




,
Size Of Init Dat - 3FA00 Size of UnInit Data - 0 Base Of Code - 3E000 Base of
Data - 13000 Number Of Rva and Sizes - 10 Size of Heap Commit - 1000 Size of Heap
Reserver - 100000 Size of Stack Commit - 1000 Size of Stack Reserve - 100000 __.
.-...- ...--.- ...- ,- ._. ..

,
,- OK button -....-.-. ,- ._. ..
,
,- error message - _. -.-.-. code section -.. ...._..-. Olly -
error message _... -.- .-...._.. - - - . - ...-. .-. error
.-- .. .-. code section -..- memory map (Alt+M) .._-_- ,

,
._-.. ,- Base Of Code .._- 3E000 -..... 1000 _.... -..-
PE editor -..._-_. . - . . . - .. . -. error . _.-... .---.

.., PE Header



, PE header - . ._... .-....
ReverseMe.exe . ......_. _..._,
(1) TimeDateStamp 3/17/2000, 1:04:06 AM (38D1291E)
TimeDateStamp .-. .- .-.-- __.-. Olly ...-. Hex -.
_-. ReverseMe -.---.-. 38D1291E _.. -. PE Viewer .- . . Hex
._- . . . _-. .. 3/17/2000, 1:04:06 AM/ -..-. -.- -
-....-. .-.--_.._. ... ..- .- .. .- - _ .- -
-. - . - - - - .-. .. 38D1291E - .. .. . ._. . .- . .
953231646 ... .- _.. .- - - . .._.... ...- 264786 .
-. - - . . ..._ . . . . . ..... . . . .-. - _-. .. .- -
- -. - .-. - .- ._.- -. . .. ... .. . .-. -. - -
. . - - --- - - . .. . ._.. - .- . - ._. - . .
(2) Machine FILE_MACHINE_I386
.- .._.. --. .-... .... . ....- - . ..- -.-.
FILE_MACHINE_I386
Intel 80386 . , ..- .... . .... .-.-_.. ... .- .....
FILE_MACHINE_AMD64
x64
FILE_MACHINE_IA64
Intel Itanium .- .. . ...
(3) Characteristics 0x10f ....- _.- flag .-,
FILE_RELOCS_STRIPPED 0x1
0x1 .. _..... ... base relocation .- . ._-. loader -. . base address ..
. . --. base address ...-.. loader -. error _..._-.._.. Linker .
-.-. EXE . -. base relocaion - .. . ,
FILE_EXECUTABLE_IMAGE 0x2
-.-. image . -. . - ._-. . . ._-. . _-. --. flag .. .-..
. - linker error _..._-.. _..,
FILE_LINE_NUMS_STRIPPED 0x4
COFF ..- .. .. - -.,
FILE_LOCAL_SYMS_STRIPPED 0x8
Local ..--.--- COFF ..- -... entry .- ....--.,
FILE_32BIT_MACHINE 0x100
- -.-. 32bit _._.- ._..-.,
(4) Subsystem SUBSYSTEM_WINDOWS_GUI
image - .-- - .. .- _.. -. _.. . - - . ..- -.-.
SUBSYSTEM_NATIVE
Device driver .... Window . process ...
SUBSYSTEM_WINDOWS_GUI
Window GUI
SUBSYSTEM_WINDOWS_CUI
Window .. ...
SUBSYSTEM_POSIX_CUI
Posix .....
.., PE Header
.


SUBSYSTEM_WINDOWS_CE_GUI
Windows CE
SUBSYSTEM_EFI_APPLICATION
Extensible Firmware Interface (EFI) application.
SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER
Boot services ... EFI driver
SUBSYSTEM_EFI_RUNTIME_DRIVER
Run-time services ... EFI driver
SUBSYSTEM_EFI_ROM
EFI ROM image
(5) LinkerVersion 5.12
._.. -_...-. .._- linker version Microsoft linker -._...- PE
. .- - - .-. version --. Visual Studio version - .- . -.
(6) SizeOfImage 20480 (0x5000)
.- .-.. -.--... system . . .. .. .. ... . - . ..
..-. section alignment .- .- .-. _.. ..
(7) SizeOfCode 1024 (0x400)
Code section ... Byte _. _._, ., -._ code section ._..-_.....
- section ... ..
(8) SizeOfInitializedData 2560 (0xa00)
Initialized data section . .. Byte _. _._, ., -._ initialized data
section ._..-_.....- section ... ..
(9) SizeOfUninitializedData 0 (0x0)
Unnitialized data section ... Byte _. _._, ., -._ uninitialized
data section ._..-_.....- section ... ..
(10) ImageBase 0x400000
Image ......- .-.. -.--_ . address -..._ 64K
bytes .- .- . _.. ._ DLL . ...- - ..- . .. . 0x10000000 _.. ._ 32bit
application ...-- ..-.... 0x00400000 _.. ._
(11) BaseOfCode 0x401000
Code section .. _ _._ Image base .-...._
(12) BaseOfData 0x402000
Data section .. _ _._ Image base .-...._
(13) AddressOfEntryPoint 0x401000
Entry point function . _ _._ Image base address .-...._ entry point
function ._ DLL . ...- - . _ ..._ Entry point . _- . .._ . _ _.. ..
._
(14) FileAlignment 512 (0x200)
Image . section ... raw .-. alignment Byte _._._ -..._ 2 .-.
- ...._.. _ . 512 . 64K _-.... ., _.. ._ ..- . .. . 512 _.. ._ -. _ Section
Alignment ._ system page ....-..- _-..._ SectionAlignment .
- _ .. ._
(15) SectionAlignment 4096 (0x1000)
Section ... Alignment - . - . - . - .- ._ Byte _. _._ _- . .._ File
Alignment . _._ ., _-.._ ..-..._ system page .... _..._
.., PE Header



(16) OperatingSystemVersion 4.0
(17) SubsystemVersion 4.0
(18) ImageVersion 0.0
(19) CheckSum 46233 (0xb499)
Image - - - .....- . . .-....- . . .._..- .......-_-_.. ..
... . ._... - - - ..._ - . . .-....- ...._._.... ._...- ..__
checksum - - - - ._ checksum .. .-_... error -__ .-.- ..--._-. _
_ . . .._ .._ Checksum ...._ error -.- ....... Checksum - ._ error
_.. .....-....- ._ . ... , Checksum ...._ kernelmode driver .... ...
system DLL ...-- ._ -_..... _..- . __.. _ ._
(20) SizeOfStackReserve 1048576 (0x100000)
EXE ....- process ... thread _-........ _......
. - . .. .- .-. .. .._. .... . .- - - .
(21) SizeOfStackCommit 4096 (0x1000)
EXE ....- stack . . .. .._. ...._ . - . ..
(22) SizeOfHeapReserve 1048576 (0x100000)
EXE ....- process heap .. .. .. .. .... . ...
(23) SizeOfHeapCommit 4096 (0x1000)
EXE ....- heap . . .. .._. ...._ . - . ..
(24) LoaderFlags 0 (0x0)
. .._.-. ,
(25) Win32VersionValue 0 (0x0)
. .._.-. ,
(26) PointerToRawData
Module ...- ... page page -_.- . pointer .-. module header -
FileAlignment .- .- . _.. .. Section .. uninitialized .-..- .- .- . . .
.-. . __.. ..
(27) VirtualAddress
. - . - - .- - ... image base . .-..._ section .. ....
... address _.. ._
(28) VirtualSize
.-.- -.--... section ...... -._.. _-..._ Size
OfRawData - _- ..- section ._ . __. __ .._ _.. ._
(29) SizeOfRawData
Disk . initialized .-. . ... . ._ module header . FileAlignment
.-.-._..._ -._ _-..._ Virtual Size -..- section - ... ....
._ . _..._. __ .._ Section .. uninitialized .-..- .- .- . . ..-. . _
_.. ..
(30) Data Directory
Exe . ... .._- .... ....- _ _.... ... IMAGE_DATA_DIRECTO
RY array -. array -. loader - .....-..- .._...- ..._. image
section ....- _-._-.-...- image --- section .- - _. _. ... ..
... -. .. import ..- function ...,
(a) Load Configuration
- . ... .. ...- _..._.._.-.-- ...- IMAGE_LOAD_
CONFIG_DIRECTORY .._.- __-.
.., PE Header



(b) IAT (Import Address Table)
... Import Address Table (IAT) .- __-. Import ..- DLL ..
..-- IAT .- -. . - . . . . ..-. Size field -.-. IAT .. . . . . .
..- _-. Loader -. address ....- import resolution -... IAT .--
readwrite _.. ... . - .... . ._-.
(c) TLS Table
Thread Local Storage initialization section - __-. TLS section . . declspec
(thread) ._-_...- thread local variables .- ..-. variable .- ....
compiler - .-- .tls ._- section .. .....-. .... run ... ..
variable .- _ .-. - .- . ..- _ . -.
(d) Base Relocation Table
Base relocation information - __-.
(e) Debug Directory
IMAGE_DEBUG_DIRECTORY .._. array -.- __-. .-....-.
image - - debug information - ..._-.
(f) Bound Import Table
IMAGE_BOUND_IMPORT_DESCRIPTOR .- array -.- __-.
(g) Resource Table
Resources .-- __-.
(h) Delay Import Tables
Visual C++ - DELAYIMP.H .. -...- ClmgDelayDescr . ._ . array
-._..- Delayload information - __-. .-...-- API - ._-. ..
.. .. . Delayloaded DLL .- - - ..- - . Windows .. delay loading DLL .- -.-
_ . . ..... . _-_ ..- - - .-..--- .-.... .._-.-.
SCN_CNT_INITIALIZED_DATA Section .. initialized .-..- -.
SCN_MEM_READ Section - .--.
SCN_MEM_WRITE Section - ..-.
SCN_CNT_CODE Section .. execute -- -.
SCN_MEM_EXECUTE Section --_.. execute -.
SCN_MEM_DISCARDABLE Section - . .....-.
SCN_MEM_SHARED section .-..- - physical page .--.-. executable -
-.-.. process ..._-.. share ... . ._-. process -.-. section . . - .-.
-- -_----..- _... Process -. ..... ._-.. share ... global
variable .- _..-. ..-.
(i) .arch Alpha architecture information section
(i) .bss Uninitialized data section
(i) .crt Data added for supporting the C++ runtime (CRT). A good example is the
function pointers that are used to call the constructors and destructors of static C++ objects.
(i) .data Initialized data section
(i) .debug Debug information section. A debug section exists only when debug
information is mapped in the address space. The default for the linker is that debug information
is not mapped into the address space of the image.
(i) .didat Delayload import data. Found in executables built in nonrelease mode. In
release mode, the delayload data is merged into another section.
(i) .edata Export tables section
(i) .idata Import tables section
.., PE Header



(i) .pdata Exception information section
(i) .rdata Read-only initialized data section
(i) .reloc Image relocations section
(i) .rsrc Resource directory section
(i) .text Executable code section
(i) .tls Thread-local storage section. The section contains data for supporting thread
local storage variables delcared with__declspec(thread). This includes the initial value of the
data, as well as additional variables needed by the runtime.
(i) .xdata Exception information section
, . . PE signature ...
, ASPack v2.12
60 E8 03 00 00 00 E9 EB 04 5D 45 55 C3 E8 01
00401000: 60 PUSHAD
00401001: E8030000000 CALL 00401009H
00401006: E9EB045D45 JMP 459D14F6H
0040100B: 55 PUSH EBP
0040100C: C3 RET
0040100D: E801003E00 CALL 007E1013H
, Armadillo v1.xx v2.xx
55 8B EC 53 8B 5D 08 56 8B 75 0C 57 8B 7D 10 85 F6
00401000: 55 PUSH EBP
00401001: 8BEC MOV EBP, ESP
00401003: 53 PUSH EBX
00401004: 8B5D08 MOV EBX, [EBP+08H]
00401007: 56 PUSH ESI
00401008: 8B750C MOV ESI, [EBP+0CH]
0040100B: 57 PUSH EDI
0040100C: 8B7D1O MOV EDI, [EBP+10H]
0040100F: 85F6 TEST ESI, ESI

., Teleport Pro 1.61 -.. ..._-. crack _ .



.,._] Teleport Pro 1.61 eq-qe.- ee._e crack -e_.-.
u Re fa w mfw dkU[ m a & SUt c e f; a w Gr Sm cracking e JUy w fo u fw Jh t a jc c Ht kw fjr p fa w Gu dk a v hv mc Jhy gw , f/
' ga Mu mi fho i fht a e e JU C? Assembly b mo mp u m; a w Gu dk w D; r da c gu fr d& Sdx m; jy Dv dkU x i fy gw , f/ a q mhz f0 Jv fa w G
u dkv J b , fv dke n f; e JU u mu G, fx m; o v Jq dkw mu dkv J o do Gm; a v mu fy gjy D/ Cracker w p fa , mu fr Sm & Sdo i fh& Sdx dku f
w Jhtool a w Gt a Mu mi f; u dkv J a v hv mjy D; jz p fw Jht jy i f ' Dt x Ju tool w p fc kjz p fw JhOlly debugger t a Mu mi f; u dkv J
t Mu r f; z si f; e m; v n fa e a v mu fy gjy D/ t q Hk; p Ge f a jy m& & i f cracking a v mu r Sm e m; v n f& c u fw , fq dkw Jh PE
header t a Mu mi f; u dka w mi f o i fa v hv mjy D; o Gm; y gjy D/ b my Ja jy ma jy m o i fa v hv mc Jhw m[ m o Dt dk& Do u fo u fo m
jz p fy gw , f/ v u fa w GUr y gw Jho Dt dk& D? o Dt dk& Dr y gw Jhv u fa w GU[ m jy D; jy n fhp Hkjc i f; ? t E Sp fo m& jy n fh0 jc i f; r & Sdw Jh
t w Gu f u dk, fw dki fv u fa w GU crack v ky fMu n fhr So m cracking o a b mw & m; a w Gu dk a u mi f; a u mi f; e m; v n f
v mr Smjz p fy gw , f/ ' ga Mu mi fh y x r q Hk; crack v ky fjc i f; t jz p f p D; y Gm; jz p fa q mhz f0 Jv fw p fc kjz p fw Jh Teleport Pro
1.61 u dk crack v ky fMu n fhMu y gr , f/ o i fht a e e JU update r jz p fa w mhw Jh y & dk* & r fu dk e r le mx m; jy D; b ma Mu mi fh
crack v ky fjy & w mv Jv dkU o Ho , 0 i fy gv dr fhr , f/ ( u Re fa w mfw dkUt a e e JU a q mhz f0 Jv fa w Gu dk crack v ky fa e w m[ m
a i Ga Mu ; t w Gu f r [ kw fy gb l; / y n m& y fw p fc kt a e e JUo m a v hv ma e jc i f; jz p fy gw , f/ ' ga Mu mi fhr dkU crack v ky fx m;
jy D; o m; a q mhz f0 Jv fa w Gu dk w & m; r 0 i f jz e fUc sD^ a & mi f; c sc Jh& i f jz p fa y : v mr Jh & v ' fa w G[ m o i fhw m0 e fo mjz p fy g
a Mu mi f; . . . )
( 1 ) y & dk* & r ft v ky fv ky fy Hku dka v hv mjc i f;
u Re fa w mfw dkUt a e e JU a q mhz f0 Jv fw p fc ku dk crack r v ky fc i fo dx m; & r , fht " du t c su fu a w mh' Da q mhz f0 Jv f
u dk b , fy & dk* & r fb mo mp u m; e JU a & ; x m; o v Jq dkw m t & i fo da t mi fv ky fz dkUy g/ ' gr So m a & SUq u fb mv ky f& r v Jq dk
w m q Hk; jz w fE dki fr Smjz p fy gw , f/ a u mi f; jy D? Teleport Pro u dk www.tenmax.com u a e download v ky fjy D;
install v ky fv dku fy g/ Help menu u About ... u dka & G; v dku f& i f y Hk( 1 ) t w dki f; a w GU& y gr , f/

y Hk( 1 )
y Hk( 1 ) r Sm jr i f& w mu a w mh unregistered version jz p fw Jht a Mu mi f; y g/ ' ga Mu mi fh register v ky fMu n fhy g
r , f/ Help menu u Register u dka & G; v dku fy g/ y Hk( 2 ) t w dki f; jr i f& y gr , f/
y Hk( 2 )
y Hk( 2 ) u Your name a e & mr Sm Myanmar Cracking Team v dkU& dku fx n fhjy D; Registration code
a e & mr Sm 4780610 (BABE16)v dkU & dku fMu n fhy gr , f/ ' gq dky Hk( 3 ) t w dki f; a w GU& y gr , f/

y Hk( 3 )
., Teleport Pro 1.61 -.. ..._-. crack _ .



y Hk( 3 ) r Sm jr i f& w mu a w mhu Re fa w mfw dkU& dku fx n fhv dku fw Jhregistration u k' f[ mr Sm; a e w Jht a Mu mi f; a jy mw Jh
MessageBox y g/ ( r Sw f& e f/ / t c sdKUy & dk* & r fa w Gr Sm v Sn fhu Gu fa v ; a w G& Sdy gw , f/ ' gu b mv Jq dka w mh regis-
tration u k' fu dk& dku fx n fhv dku fw Jht c g r Se fw , f^ r Sm; w , fr a jy mb J y & dk* & r fu dk jy e fz Gi fhc dki f; w mjz p fy gw , f/ t c sdKU
y & dk* & r fa w Gq dk b m MessageBox r Sa w mi f a y : r v my gb l; / b ma Mu mi fhv Jq dka w mh ' Dv dky & dk* & r fa w Gu o i f& dku f
x n fhv dku fw Jh registration u k' fu dkc su fc si f; r p p fv dkUy g/ Registry x Jr Sm ( o dkU) z dki fw p fz dki fr Sm o i f& dku fx n fh
v dku fw Jhu k' fu dko dr f; x m; jy D; a e mu fw p fMu dr f y & dk* & r fu dkz Gi fhjy D; t v ky fv ky fw Jht c gr S u k' fu dkp p fa q ; w mjz p fy gw , f/ )
' DMessage Box r Smjr i f& w Jh We're sorry! q dkw Jhp mo m; u dk p m& Gu fv Gw fw p f& Gu fr Sm r Sw fo m; x m; y g/ t o Hk; 0 i f
v my gv dr fhr , f/
a u mi f; jy D? y & dk* & r fu dky dw fv dku fjy D; b , fb mo mp u m; e JU a & ; x m; o v Jq dkw m p p fMu n fhy gr , f/ Program
files\Teleport Pro z dk' ga t mu fu pro.exe z dki fu dkright-click E Sdy fjy D; PEiD e JU p p fMu n fhv dku fy g/ y Hk( 4 ) /
y Hk( 4 )
y Hk( 4 ) t & q dk& i fa w mh ' Dy & dk* & r fu dk Visual C++ 6.0 e JU a & ; x m; w mjz p fy gw , f/ ' Da v mu fq dk u Re fa w mf
w dkUt w Gu f v Hka v mu fy gjy D/ pro.exe u dkOlly r Sm z Gi fhy gr , f/ y Hk( 5 ) /

y Hk( 5 )
y Hk( 5 ) r Smjr i f& w mu a w mhy & dk* & r f& JU entry point a e & my g/ ( r Sw fc su f/ / Visual C++ jz i fha & ; x m; a o m
y & dk* & r fr sm; o n f y Hk( 5 ) w Gi fjy x m; o n fht w dki f; kernel32.GetVersion \ t a y : z u f& Sd PUSH EBP u k' f& Sd& m
virtual address o n f entry point jz p fo n f/ ) ' Dy & dk* & r fu dk e n f; ( 2 ) e n f; e JU crack v ky fjy r Smjz p fy gw , f/
y x r e n f; u a w mh SND Team u nick123b o Hk; w Jhe n f; jz p fy gw , f/ ' kw d, e n f; u a w mh ARTeam u
ThunderPwr o Hk; w Jhe n f; jz p fy gw , f/ t jc m; e n f; a w Gu dka w mht v sOf; o i fhw Jht c e f; r Sm a z mfjy o Gm; r Smjz p fy gw , f/
( 2 ) y x r e n f; ( nick123b@SND Team)
y Hk( 2 ) r Sm register v ky fw ke f; u y Hk( 3 ) t w dki f; error message a y : v mw mr Sw fr dr , fx i fy gw , f/ ' D
message p mo m; u dk Olly r Sm& SmMu n fhv dku fMu & a t mi f/ y Hk( 5 ) r Sm right-click E Sdy fjy D; Search for u All
referenced text strings u dka & G; v dku fy g/ ' gq dk& Smx m; w Jhtext string a w Gy gw Jhwindow w p fc ka y : v my gr , f/
y Hk( 6 )
., Teleport Pro 1.61 -.. ..._-. crack _ .



a y : v mw Jhwindow r Sm y Hk( 6 ) t w dki f; u Re fa w mfw dkU & Smc si fw Jhp mo m; u dk & dku fx n fhjy D; OK u dkE Sdy fv dku fy g/
' ga y r , fh u Re fa w mfw dkU& Smw Jh p mo m; u dk Olly e JU& Smw mr a w GUy gb l; / b ma Mu mi fhv Jq dka w mh ' Dy & dk* & r fu dk a & ; o m;
c Jhw Jhy & dk* & r fr mu We're sorry! p mo m; u dk .text section r Sm r a & ; o m; b J y Hk( 7 ) r Sm jy x m; o v dk .data section
r Sma & ; o m; x m; v dkU Olly u & Smr a w GUE dki fw my g/ ( o mr e ft m; jz i fh y & dk* & r fr sm; \ 8 0 % a u smfo n f .text section
(code section) w Gi fo m a & ; o m; Mu y go n f/ )

y Hk( 7 )

y Hk( 8 )
y Hk( 8 ) u dkMu n fhv dku fa w mhu Re fa w mfw dkU& Sma e w Jhmessage u dka w GU& y gw , f/ y Hk( 7 ^ 8 ) w dkUu dk PE Explorer
1.99 (www.heaventools.com) r Sm z Gi fhMu n fhx m; w mjz p fy gw , f/
y Hk( 6 ) t w dki f; text string u dk& Smw m & Smr a w GUv dkU o i fht a e e JU a c gi f; a w mfa w mfa jc mu fa e a v mu fjy Dx i fy g
w , f/ ' Dmessage u dk& Sma w GUr So m u Re fa w mfw dkUt a e e JU serial a & ; x m; w Jh registration routine u dka w GUjy D;
serial u dk& Sma z GE dki fr Sm jz p fy gw , f/ a u mi f; jy D? nick123b & JUe n f; e JU serial u dk& SmMu n fhMu & a t mi f/
Olly r Sm Ctrl + N (View Names) u dkE Sdy fv dku fy g/ y Hk( 9 ) t w dki f; API a w Gu dkjr i f& y gr , f/

y Hk( 9 )
y Hk( 9 ) r Sm jy x m; w Jht w dki f; USER32.GetWindowTextA r Sm right-click E Sdy fjy D; Find references to
import (Enter key) u dk a & G; v dku fy g/ y Hk( 1 0 ) t w dki f; jr i f& y gr , f/ ( GetWindowTextA t a Mu mi f; t a o ; p dw f
u dk]Cracker r sm; o w dx m; o i fha o m Windows API r sm; } t c e f; w Gi f z w f& Iy g/ )

y Hk( 1 0 )
y Hk( 1 0 ) r Sm jr i f& w Jht w dki f; right-click E Sdy fjy D; Set breakpoint on every command u dk a & G; v dku f
y g/

y Hk( 1 1 )
., Teleport Pro 1.61 -.. ..._-. crack _ .



y Hk( 1 1 ) t w dki f; GetWindowTextA u dkbreakpoint r o w fr Sw fc i f pro.exe u dky Hk( 1 2 ) t w dki f; Olly r Sm
register v ky fa e w m a o c smy ga p / ( q dkv dkw mu Teleport Pro u dk Olly e JUz Gi fhjy D; register v ky fc dki f; w my g/
y Hk( 1 2 ) r Sm OK u dkr E Sdy fc i f y Hk( 9 ^ 1 0 ^ 1 1 ) r Sm jr i f& w Jht w dki f; breakpoint o w fr Sw fw m jz p fy gw , f/ )

y Hk( 1 2 )
y Hk( 1 1 ) t w dki f; breakpoint o w fr Sw fjy D; o Gm; & i fa w mh y Hk( 1 2 ) u OK u dkE Sdy fv dku fy g/ y Hk( 1 3 ) t w dki f; Get
WindowTextA() API & Sd& m breakpoint q Dw e f; a & mu fo Gm; y gv dr fhr , f/

y Hk( 1 3 )
y Hk( 1 3 ) t w dki f; jr i f& w Jht c g y Hk( 1 4 ) u dkjr i f& w Jht x dF8 (step over) u dkE Sdy fy g/

y Hk( 1 4 )
y Hk( 1 4 ) u dkMu n fhy g/ CALL 0042F675 r Sm registration key w Gu fc su fjc i f; u dk v ky fa q mi fy gw , f/
' Dha e mu fr Sma w mhEAX x Jr Sm& Sdw Jhw e fz dk; w p fc ke JU ESI x Jr Sm& Sdw Jhw e fz dk; w p fc kw dkUu dkn D?r n Dp p fy gw , f/ w u , fv dkU
w e fz dk; E Sp fc kr n Dc Jh& i f BadBoy message q Da & mu fo Gm; r Smjz p fy gw , f/ ' ga Mu mi fh"JNZ 042ECDB" q dkw Jha e & m
a & mu f& i f F8 E Sdy fv mw m & y fv dku fy g/ jy D; a w mhRegisters (FPU) window u dkMu n fhv dku fy g/ y Hk( 1 5 ) /

y Hk( 1 5 )
y Hk( 1 5 ) & JU EAX register x Jr Sm u Re fa w mfw dkUv dkc si fw Jh serial a & mu fa e y gjy D/ r Sw fx m; & r Smu ' Dserial
[ m ECX register x Jr Sm& Sdw Jh "Myanmar Cracking Team" q dkw Jh user t w Gu fo mjz p fy gw , f/
., Teleport Pro 1.61 -.. ..._-. crack _ .



b ma Mu mi fhv Jq dka w mh u Re fa w mfw dkUu y Hk( 1 2 ) r Sm jy x m; w Jht w dki f; user name a e & mr Sm "Myanmar Cracking
Team" v dkU & dku fx n fhc Jhv dkUy g/

y Hk( 1 6 )
w u , fa w mh y Hk( 1 4 ) u EAX register x Jr Sm& Sdw Jh serial [ m hexadecimal * P e f; o mjz p fy gw , f/
258680D9 a e & mu dk E Sp fc su fE Sdy fv dku fy g/ jy D; & i f 629571801 u dku l; , lv dku fy g/ y Hk( 1 7 ) / 629571801 u o m
serial t p p ft r Se fjz p fy gw , f/

y Hk( 1 7 )
' gq dk u Re fa w mfw dkU v dkc si fw Jh serial u dk & & Sdjy Djz p fw Jht w Gu f Olly u dky dw fv dkU& y gjy D/ Teleport Pro
y & dk* & r fu dkjy e fz Gi fhv dku fy g/ jy D; & i f Help menu u Register u dka & G; jy D; register v ky fz dkU jy i fq i fy g/

y Hk( 1 8 )
y Hk( 1 8 ) t w dki f; Name e JU Registration Code u dkjz n fhjy D; & i f OK u dkE Sdy fv dku fy g/ y Hk( 1 9 ) t w dki f;
jr i f& y gr , f/

y Hk( 1 9 )
y dka o c smo Gm; a t mi f Help menu u Register u dkx y fE Sdy fMu n fhy g/ u Re fa w mfw dkU a e mu fw p fMu dr f
register v ky fp & mr v dka w mhw m jr i f& r Smy g/ y Hk( 2 0 ) /
., Teleport Pro 1.61 -.. ..._-. crack _ .




y Hk( 2 0 )
Help menu u About Teleport Pro u dka & G; jy D; Mu n fhv dku f& i fa w mhy Hk( 2 1 ) t w dki f; jr i f& r Smy g/

y Hk( 2 1 )
' gq dk y x r e n f; e JU u Re fa w mfw dkU& JU serial & Smjc i f; t v ky fjy D; o Gm; y gjy D/ ' Dv dke n f; e JU serial & Smw mu dk
t * Fv dy fv dka w mh serial fishing ( Serial z r f; jc i f; ) v dkUa c : y gw , f/ Cracking a v mu r Sma w mh serial fishing
e n f; [ m t c sde fu ke fo u fo mjy D; v G, fu lv Sw Jht w Gu f t o Hk; r sm; v Sy gw , f/
( 3 ) ' kw d, e n f; ( ThunderPwr @ARTeam)
' kw d, e n f; u a w mh y Hk( 2 2 ) r Smjr i f& w Jh MessageBox & Sd& ma e & mu dkt & i f& Smjy D; registration routine u dk
& Sma z Gw Jhe n f; jz p fy gw , f/ ( r Sw fc su f/ / a & SUy dki f; u GetWindowTextA() API r Smo w fr Sw fx m; w Jhbreakpoint
a w Gu dkz , f& Sm; jy D; a Mu mi f; a o c smy ga p / )
Teleport Pro [ m register v ky fw m a t mi fjr i fo Gm; & i f a e mu fw p fMu dr f register x y fv ky fv dkU r & a w mh
y gb l; / ' ga Mu mi fh registry editor (regedit.exe) u dkz Gi fhjy D; HKLM e JU HKCU w kdY& JU Software directory
a t mu fu Tennyson Maxwell directory key u dkz su fy p fv kdu fy g/

y Hk( 2 2 )
Olly r Sm pro.exe u dkz Gi fhjy D; F9 (Run) u dkE Sdy fy g/ ' gq dk Teleport Pro y & dk* & r fy Gi fhv mw m jr i f& y gr , f/
y & dk* & r f& JU Help menu u Register u dkE Sdy fjy D; register v ky fMu n fhy g/ y Hk( 2 2 ) t w dki f; BadBoy MessageBox
u dkjr i f& y gr , f/ ' Dt c g Olly q Djy e fo Gm; jy D; F12 (Pause) u dkE Sdy fy g/ F12 u dkE Sdy f& w Jht a Mu mi f; & i f; u a w mhy & dk* & r f
t v ky fv ky fw m c P & y fa p c si fv dkUy g/ jy D; & i f Olly & JU stack window r Sm scroll q GJjy D; Mu n fhv dku fy g/ y Hk( 2 3 )
t w dki f; jr i f& y gr , f/
., Teleport Pro 1.61 -.. ..._-. crack _ .
.



y Hk( 2 3 )
y Hk( 2 3 ) u dkMu n fhy g/ VA 0049112C u a w mh"We're sorry! " p mo m; u dko dr f; q n f; x m; w Jhvirtual
address y g/ VA 004542CD u a w mh y Hk( 2 2 ) u MessageBox API u dkv ky fa q mi fjy D; c sde f a & mu f& Sdr , fh
a e & my g/ c kc sde fr Sm u Re fa w mfht a e e JU p dw f0 i fp m; w Jhvirtual address [ m 004542CD jz p fy gw , f/ b ma Mu mi fhv J
q dka w mh' Daddress u a e registration routine & Sd& ma e & mu dka jc & mc Hr Smr dkUv dkUy g/

y Hk( 2 4 )
Registration routine u dk a jc & mc Hz dkU y Hk( 2 4 ) u highlight jz p fa e w Jha e & mr Sm right-click E Sdy fjy D;
Follow in Disassembler u dka & G; y g/ y Hk( 2 5 ) t w dki f; jr i f& y gr , f/

y Hk( 2 5 )
y Hk( 2 5 ) u 004542CD a e & mr Sm breakpoint o w fr Sw fjy D; F9 u dkE Sdy fr , fq dk& i fa w mh a e mu fw p fc g
register v ky fw Jht c g ' Da e & mu dkw e f; a & mu fv mr Sm jz p fy gw , f/ y Hk( 2 6 ) /

y Hk( 2 6 )
' Dt c gr Sm y Hk( 2 5 ) e JUr w lw mu a w mhpro.004541C4 [ m text string a w Ge JU jz p fv my gw , f/

y Hk( 2 7 )
., Teleport Pro 1.61 -.. ..._-. crack _ .



y Hk( 2 6 ) u u k' fa w Gu dk F8 E Sdy fjy D; u k' fa w Gp p fv mw Jht c g y Hk( 2 6 ) u CALL u dk v ky fa q mi fjy D; w me JU y Hk( 2 7 )
& Sd& mu dka & mu fv mr Smy g/ ' Dw p fc gr Sma w mhserial u dkEAX register x Jr Sm b , fv dkr S& Sma w GUa w mhr Sm r [ kw fy gb l; /
b ma Mu mi hfv Jq dka w mh y & dk* & r fu serial r Se f^ r r Se fu dk p p fa q ; jy D; v dkU error message u dkx kw fa y ; v dku fw ma Mu mi fh
jz p fy gw , f/ ' ga Mu mi fhr dkU serial u dkv dkc si f& i f u Re fa w mfw dkUt a e e JU VA 0042ECCA a e & mr Sm breakpoint
o w fr Sw fjy D; y & dk* & r fu dk a e mu fw p fMu dr f register v ky fz dkUv dky gw , f/ ' Dbreakpoint u dka & mu fw Jht c g u Re fa w mf
w dkU& Sma e w Jh serial u dk EAX register x Ju a e u l; , lv dkU& y gjy D/ a e mu fx y fp dw f0 i fp m; p & ma u mi f; w mu a w mh
y Hk( 2 3 ) u RETURN to pro.0042ED10 from pro.004542AB y g/ ( Assembly o i fc e f; p mw ke f; u CALL
w p fc k[ m o la e mu fx y fv ky fr , fhinstruction & Sd& m address (EIP) u dk stack r Smo dr f; q n f; w , fv dkUa jy mc Jhw mu dk
t r Sw f& y g/ a e mu fx y fa jy mc Jha o ; w mu a w mh CALL w p fc ku dkv ky fa q mi fjy D; c sde fr Sm return value u dk EAX r Sm
t jr Jw r f; e D; y g; o dr f; q n f; w , fq dkw Jht a Mu mi f; y g/ )
( 4 ) Teleport Pro y & dk* & r ft w Gu f keygen a & ; o m; jc i f;
a & SUy dki f; r Sm u Re fa w mfw dkUt a e e JU serial z r f; jy D; Teleport Pro u dk register v ky fjy D; o Gm; y gjy D/ ' ga y r , fh
t r n fu "Myanmar Cracking Team" jz p fa e y gw , f/ w u , fv dkU o i fht r n fe JU register v ky fc si f& i f?
o i fhr dw fa q G^ c sp fo lt r n fe JU register v ky fc si f& i f Olly e JU serial x y f& Sm& r , fq dk& i f t c sde fu ke fv ly e f; y gw , f/
' ga Mu mi fhr dkU keygen a & ; z dkUv dkt y fv my gw , f/ "Myanmar Cracking Team" t r n fe JU serial & Sm& mr Sm
629571801 q dkjy D; & v my gw , f/ b , fv dk& v mr Se f; o i fht a e e JU 0 g; w m; w m; jz p fa e r Sm a o c smy gw , f/ ' ga Mu mi fh
serial key x kw fa y ; w Jhroutine u dkt a o t c sm a v hv mMu n fhy gr , f/ y Hk( 2 8 ) /

y Hk( 2 8 )
' Da e & mr Sm y Hk( 2 8 ) u CALL 0042F675 [ m serial key u dkx kw fa y ; w Jh routine jz p fw , fq dkw m
o i fht a e e JU & dy fr dr Smy g/ b ma Mu mi fhv Jq dka w mh ' D CALL u dk v ky fa q mi fjy D; c sde fr Sm u Re fa w mfw dkU & dku fx n fhw Jh
serial e JU w Gu fc su fv dkU& v mw Jh serial u dk y & dk* & r fu E dIi f; , SOfv dkUy g/ ' D CALL a e & mr Sm breakpoint
o w fr Sw fv dku fjy D; y & dk* & r fu dk (Ctrl+F2) jy e fp w i fv dku fy g/ jy D; & i f F9 u dkE Sdy fjy D; y & dk* & r fu dk run y g/ Register
v ky fy g/ ' gq dk& i f breakpoint o w fr Sw fx m; w JhVA 0042ECC2 a e & mu dk a & mu fv my gr , f/ VA 0042ECC2
a e & mu dka & mu fv m& i f F7 (step into) u dkE Sdy fjy D; CALL x Ju dk0 i fMu n fhy gr , f/ y Hk( 2 9 ) /

y Hk( 2 9 )
Serial key u dkx kw fa y ; w Jh routine a v ; u a w mh y Hk( 2 9 ) r Sm jy x m; o a v mu fy gb J/ VA 0042F691
x du p dw f0 i fp m; p & mr & Sdy gb l; / & dku fx n fhv dku fw Jh user t r n f[ m p mv Hk; a & 5 v Hk; x u fe n f; ^ r e n f; p p fa q ; w m
., Teleport Pro 1.61 -.. ..._-. crack _ .



y J& Sdy gw , f/ 5 v Hk; x u fr sm; & i fa w mh VA 0042F694 u p jy D; serial w Gu fc su fjc i f; v ky fi e f; p Ofu dk p w i fr Sm
jz p fy gw , f/ a v hv mMu n fhv dku f& a t mi f/
1 / EBX e JU ESI w dkUu dkvariable t a e e JU a Mu n my gw , f/
2 / ESI = 5DFEE4A4 v dkU initialize v ky fy gw , f/
3 / EBX w e fz dk; u dko kn jz p fa t mi fv ky fy gw , f/
4 / TEST u a w mhjump (JE) jz p f^ r jz p f flag w e fz dk; u dko w fr Sw fw mjz p fy gw , f/
5 / EDI x Ju w e fz dk; a w Gu dk ECX x Ja jy mi f; x n fhw my g/ ( Stack r Sm a e mu fq Hk; o Gi f; w mu dk t & i fx kw f, l& y g
w , f/ )
6 / EAX w e fz dk; x Ju 4 E Iw fy gw , f/ ( EAX x Jr Sm c ke u u Re fa w mfw dkU & dku fx n fhv dku fw Jh user t r n fe JU
y w fo u fw Jhp mv Hk; t a & t w Gu f & Sdy gw , f/ "Myanmar Cracking Team" jz p fw Jht w Gu f 2 1 v Hk; y g/ )
7 / EBX e JU EAX w dkU E dIi f; , SOfy gw , f/
8 / w u , fv dkU EBX [ m EAX x u fr i , fc Jh& i f jump jz p fr Smjz p fy gw , f/ ( c kc sde fr Sma w mh EAX u 17 jz p fjy D; ?
EBX u o kn jz p fy gw , f/ )
9 / ESI w e fz dk; e JU user t r n fu y x r p mv Hk; 4 v Hk; & JU Unicode (Hex) w e fz dk; w dkUu dk XOR v ky fr Smjz p fy gw , f/
( c kc sde fr Sma w mhESI w e fz dk; u 5DFEE4A4 jz p fjy D; ? DS:[EBX+EDI] w e fz dk; u 6E61794D jz p fy gw , f/ )
1 0 / EBX w e fz dk; u dk1 a y gi f; y gw , f/
1 1 / ' Dv dke JU "Myanmar Cracking Team" q dkw Jhp mv Hk; a w Gu dk u ke fa t mi fz w f? XOR v ky fjy D; & v mw Jha e mu fq Hk;
t a jz u dkEAX r Sm o dr f; y gw , f/
' gu dk Assembly u k' ft a e e JU jy e fa & ; & i fa w mh a t mu fy gt w dki f; a w GU& r Smy g/ ' gu a w mh u k' ft jy n fht p Hk
r [ kw fy gb l; / Serial key x kw fa y ; w Jh a e & ma v ; u dky J a & ; x m; jc i f; jz p fy gw , f/ a & ; o m; x m; w Jh y & dk* & r fr mu
a w mhSND Team u Ziggy jz p fy gw , f/
invoke lstrlenA, addr namebuffer ;get the length of the name string
mov ecx, eax ;copy length of name string in eax to ecx
sub ecx, 4 ;loop counter ecx = name string length - 4
lea edi, namebuffer ;edi = address to name string
mov esi, 05DFEE4A4h ;esi = starting code value = 04E6AF4BC hex
L005: ; Ripped code from Ziggy's KeygenMe
mov eax, dword ptr ds:[edi] ;load 4 name string ascii characters in eax
xor esi, eax ;exclusive or eax with the new edx value - result in esi
inc edi ;point to next group of 4 name chars
dec ecx ;decrement the loop counter
jnz L005 ;jump back if ecx loop counter not = zero
Assembly e JU keygen a & ; o m; e n f; u dka w mh ]t a jc c H Assembly b mo mp u m; } t c e f; r Sm & Si f; jy jy D;
jz p fw Jht w Gu f x y fr Hr & Si f; jy a w mhy gb l; / Keygen e JU y w fo u fjy D; a jy mv dkw mu a w mh u Re fa w mfw dkUt a e e JU
keygen a w G& JU GUI u dk u dk, fw dki fa & ; p & mr v kdy gb l; / a & ; x m; jy D; o m; keygen template a w Gu dk t o i fh, lo Hk;
& Hky g/ Serial key a w Gu dkx kw fa y ; r , fhregistration routine u dko m a & ; a y ; z dkUv dkt y fy gw , f/
;
; Ziggy April 2005
;
;
; Notes
;
; - Requires MASM32 V8
; - Requires linking with matching resource file ;
;
;
.586p
.mmx
.model flat, stdcall
option casemap :none
include \masm32\include\windows.inc
include \masm32\include\user32.inc
include \masm32\include\kernel32.inc
include \masm32\include\masm32.inc
include \masm32\macros\macros.asm
includelib \masm32\lib\user32.lib

., Teleport Pro 1.61 -.. ..._-. crack _ .



includelib \masm32\lib\kernel32.lib
includelib \masm32\lib\masm32.lib
; Prototypes
DialogProc PROTO :DWORD,:DWORD,:DWORD,:DWORD
ClipboardCopy PROTO
KeygenProc PROTO
.const
DIALOG_1 equ 1 ;identifier in resource file
IDC_APPNAME equ 1001
IDC_NAME equ 1002
IDC_SERIAL equ 1003
BTN_CLOSE equ 1004
BTN_GENERATE equ 1005
BTN_COPY equ 1006
BTN_ABOUT equ 1007
; may need to edit these constants
MinNameLength equ 5 ; Should be consistent with .data NameTooShort
MaxNameLength equ 30 ; Maximum length of name string
; edit about text as needed
About_Text equ " ",13,10,"Keygenned by Ziggy ",13,10,10,\
"30 July 2008",13,10,13,10
Max_Buffer equ 100 ; set to at least maximum length of name or serial
;
.data
; edit app name as needed
Appname db "Myanmar Cracking Team proudly presents:",0
; following data not required if name not used to derive serial
NoName db 'No Name Entered',0
NameTooLong db 'Name is too long',0
NameTooShort db 'Name must be at least 5 characters',0 ; edit to match MinNameLength
NameOK db 'Press "Generate"',0
namebuffer dd Max_Buffer dup (00) ;buffer for entered name
genedserial dd Max_Buffer dup (00) ;buffer for genedserial
tempbuffer dd Max_Buffer dup (00) ;scratch buffer
fixedstring db " ",0
decimalformat db "%d",0
;
.data?
hInstance dd ? ;Module handle
handle dd ? ;Dialog handle
hIcon dd ? ;caption bar icon handle
;
.code
main :

invoke GetModuleHandleA,NULL
mov hInstance ,eax ; save handle for later use

;mov hIcon, FUNC(LoadIcon, hInstance,2) ; get the icon 2 resource

; setup the dialog processing
invoke DialogBoxParamA,hInstance,DIALOG_1,NULL, addr DialogProc,NULL
invoke ExitProcess,NULL ; terminate after dialog is closed
;
; Main Dialog Processing

DialogProc Proc hwnd:dword, message:dword, wParam:dword, lParam:dword
pushad
mov eax,hwnd
mov handle,eax ;save dialogbox handle, to use in other procedures
.IF message==WM_INITDIALOG
invoke SetDlgItemTextA,handle,IDC_APPNAME, addr Appname ;show the appname in dialog box
invoke SendMessage, handle,WM_SETICON,ICON_BIG,hIcon ; set icon on caption bar

.ELSEIF message==WM_COMMAND
mov eax,wParam
.IF ax==BTN_GENERATE ; "Generate" button presssed
; check name is ok, not too long & not too short
invoke GetDlgItemTextA,handle,IDC_NAME,ADDR namebuffer,Max_Buffer
.if eax == 0
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr NoName
.elseif eax > MaxNameLength ; max namr length

., Teleport Pro 1.61 -.. ..._-. crack _ .



invoke SetDlgItemTextA,handle,IDC_SERIAL,addr NameTooLong
.elseif eax < MinNameLength ; minimum name length
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr NameTooShort
.elseif
;Invoke Keygen algo on 'generate' and name ok
Invoke KeygenProc ; do the business

.endif
.ELSEIF ax==BTN_CLOSE ; "Close" button pressed
jmp @close
.ELSEIF ax==BTN_ABOUT ; "About" button pressed
invoke MessageBox,handle,SADD(About_Text),
SADD(" ",34,"Myanmar Cracking Team",34),
MB_OK or MB_ICONINFORMATION
.ELSEIF ax==IDC_NAME ; name character enetered
; check name ok, not too long & not too short
invoke GetDlgItemTextA,handle,IDC_NAME,ADDR namebuffer,Max_Buffer
.if eax == 0
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr NoName
.elseif eax > MaxNameLength ; max namr length
invoke SetDlgItemTextA,handle,IDC_SERIAL,addr NameTooLong
.elseif eax < MinNameLength ; minimum name length
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr NameTooShort
.elseif
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr NameOK
.endif
.ELSEIF ax==BTN_COPY ; "Copy" button pressed
invoke ClipboardCopy

.ENDIF

.ELSEIF message==WM_CLOSE ; dialog closed
@close:
invoke EndDialog,handle,NULL
popad
xor eax,eax
ret
.ELSE
popad
mov eax,FALSE
ret
.ENDIF
popad
xor eax,eax
ret

DialogProc endp
;
; Copy generated serial to the clipboard
; This function is not really necessary in a simple keygen but code is short
; and does not need any modification.
;
ClipboardCopy proc
pushad

invoke GetDlgItemText, handle, IDC_SERIAL, addr genedserial, SIZEOF genedserial
.if eax != 0
invoke OpenClipboard, handle
.if eax
invoke GlobalAlloc, GMEM_MOVEABLE or GMEM_DDESHARE, SIZEOF genedserial
.if eax != NULL
push eax
push eax
invoke GlobalLock, eax
mov edi, eax
mov esi, OFFSET genedserial
mov ecx, SIZEOF genedserial
rep movsb
pop eax
invoke GlobalUnlock, eax
invoke EmptyClipboard
pop eax

., Teleport Pro 1.61 -.. ..._-. crack _ .



invoke SetClipboardData, CF_TEXT, eax
.endif
.endif
invoke CloseClipboard
.endif
popad
ret
ClipboardCopy endp

;
; your Key Generator Code goes in this procedure
;
KeygenProc PROC
nop ; these nops make the Keygen procedure easy to find in Olly
nop ; when debugging the keygen.
nop ; comment these out on final assembly
nop
nop
nop
nop
nop

;[[[[[[[[[[[[[[[[[ Your keygen code goes in here to replace the example
invoke lstrlenA, addr namebuffer ;** get the length of the name string
mov ecx, eax ;** copy length of name string in eax to ecx
sub ecx, 4 ;** loop counter ecx = name string length - 4
lea edi, namebuffer ;** edi = address to name string
mov esi, 05DFEE4A4h ;** edx = starting code value = 04E6AF4BC hex
L005:
mov eax, dword ptr ds:[edi] ;** load 4 name string ascii characters in eax
xor esi, eax ;** exclusive or eax with the new edx value - result in edx
inc edi ;** point to next group of 4 name chars
dec ecx ;** decrement the loop counter
jnz L005 ;** jump back if ecx loop counter not = zero
invoke wsprintf, addr tempbuffer, addr decimalformat, edx
invoke lstrcpyA, addr genedserial, addr fixedstring
invoke lstrcatA, addr genedserial, addr tempbuffer
;]]]]]]]]]]]]]]]]]]
invoke SetDlgItemTextA,handle,IDC_SERIAL, addr genedserial ; display serial
ret
KeygenProc ENDP
;

end main
' Dassembly u k' fa w Gu dkassemble v ky fv dku f& i f y Hk( 3 0 ) t w dki f; a w GU& r Smy g/

y Hk( 3 0 )
Assembly e JU keygen a & ; w m t q i fa jy y go v m; / r a jy b l; q dk& i fa w mh C b mo mp u m; e JU keygen
a & ; e n f; u dk& Si f; jy y gr , f/
#include <conio.h>
#include <stdio.h> // C Console Application
#include <string.h> // Compiler - Borland C++ 5.02
#include <memory.h> // Copyright by Myo Myint Htike, September 14 2009
unsigned long StringtoHex(const char *string);
int main()
{
char User_Name[30] = {0};
char Read_4_Bytes[4] = {0};
unsigned long index = 0, ESI = 0x5DFEE4A4, EAX;
unsigned long string_length;

., Teleport Pro 1.61 -.. ..._-. crack _ .



printf("Teleport Pro 1.3x - 1.6x Keygen");
printf("\n========================\n\n");
printf("\nYour Name : ");
scanf("%[abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ ]",User_Name);
string_length = strlen(User_Name);
if(string_length < 5 || string_length > 30)
printf("Name must be 5->30 characters.\n");
while(index < string_length-4){
memmove(&Read_4_Bytes, &User_Name[index], 4);
strrev(Read_4_Bytes);
EAX = StringtoHex(Read_4_Bytes);
ESI = ESI ^ EAX;
index++;
}
printf("\nRegistration Code : %d\n",ESI);
getch();
return 0;
}
unsigned long StringtoHex(const char *string)
{
unsigned long hex_value = 0, index = 0;
const char *character_read = string;
while(*character_read){
hex_value = (hex_value*0x100) +(unsigned long)character_read[index];
character_read++;
}
return hex_value;
}
y & dk* & r f& JU t v ky fv ky fy Hku a w mh-
1 / unsigned long StringtoHex(const char *string);
' gu a w mhu dk, fy dki f function w p fc ku dkt o Hk; jy Kr , fv kdU Mu dKw i fa Mu n mw my g/
2 / char User_Name[30] = {0}, char Read_4_Bytes[5] = {0};
User name t w Gu f p mv Hk; a & ( 3 0 ) z w fr Smjz p fy gw , f/ ' Dp mv Hk; a w Gu dk z w fjy D; x m; r , fhbuffer a e & mu dk
00 ('\0') a w Ge JU jz n fhv dku fw my g/ Read_4_Bytes[4] u v J' Dv dky gy J/
3 / unsigned long index = 0, ESI = 0x5DFEE4A4, EAX;
XOR v ky fr , fhESI w e fz dk; u dk0x5DFEE4A4 v dkU initialize v ky fy gw , f/
4 / scanf("%[abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ ]",User_Name);
Registration v ky fr , fh user name u dka w mi f; w my g/ %s e JU z w f& i f& a y r , fh user t r n fr Sm
r v dkt y fw Jho a u Fw a w G ( space r St y ) y gv mr Sm p dk; & dr fw Jht w Gu f u e fUo w fv dku fw mjz p fy gw , f/ ' ga Mu mi fh
keyboard u a e t r n f& dku fx n fhw Jht c gr Sm a-z? A-Z e JU space w dkUo m & dku fx n fhv dkU& r Smjz p fy gw , f/
Myanmar Cracking Team v dkU & dku fx n fhy gr , f/
5 / string_length = strlen(User_Name);
& dku fx n fhv dku fw Jh user name u dk b , fE Sp fv Hk; v Jq dkw m w Gu fc su fy gw , f/ Myanmar Cracking
Team jz p fw Jht w Gu f 2 1 v Hk; jz p fy gw , f/ w u , fv dkU user name [ m 5 v Hk; x u fe n f; a e & i fy Jjz p fjz p f?
t v Hk; 3 0 x u f r sm; a e & i fy Jjz p fjz p f serial t r Sm; u dky Jx kw fa y ; r Smjz p fy gw , f/
6 / while(index < string_length-4){
string_length x Ju 4 E Iw fw mjz p fw Jht w Gu f string_length w e fz dk; t o p f[ m 1 7 jz p fv my gr , f/
index w e fz dk; u a w mhc kc sde fr Sm o kn jz p fa e y gr , f/ ' ga Mu mi fhwhile loop u dk1 7 Mu dr fv ky fa q mi fy gr , f/
6 . 1 / memmove(&Read_4_Bytes, &User_Name[index], 4);
memmove() function u a w mh&User_Name[0] = VA 12FF68 r Smp w Jh4D 79 61 6E (Myan)
p w Jhp mv Hk; 4 v Hk; u dk&Read_4_Bytes = VA 12FF88 r Sm o Gm; x m; a p w mjz p fy gw , f/ y Hk( 3 1 ) /

y Hk( 3 1 )
., Teleport Pro 1.61 -.. ..._-. crack _ .



6 . 2 / strrev(Read_4_Bytes);
Myan q dkw Jh string u dk a jy mi f; jy e fv Se fy gw , f/ ' ga Mu mi fh Myan [ m nayM jz p fv my gw , f/
b ma Mu mi fhstrrev() function u dko Hk; & o v Jq dk& i f y & dk* & r f[ m endian e n f; e JU a ' w ma w Gu dkz w fv dkUjz p fy gw , f/
6 . 3 / EAX = StringtoHex(Read_4_Bytes);
StringtoHex() function u a w mh a jy mi f; jy e fv Se fx m; w Jh string a w Gu dk XOR v ky fz dkUt w Gu f
* P e f; t jz p fa jy mi f; v Jw mjz p fy gw , f/ ' D function u dkv ky fa q mi fjy D; c sde fr Sma w mh EAX [ m 6E61794D
jz p fv my gw , f/
6 . 3 . 1 / while(*character_read){
hex_value = (hex_value*0x100) +(unsigned long)character_read[index];
character_read++;
}
character_read u VA 12FF88 r Sm& Sdw Jh y x r p mv Hk; n u dk z w fy gw , f/ r Sw fx m; & r Smu a w mh
*character_read [ m character_read[0] e JUn Djy D; character w p fv Hk; u dkz w fy gw , f/

y Hk( 3 2 )
z w fv dku fw Jhp mv Hk; n u dk * P e f; t jz p fa jy mi f; y gw , f/ hex_value w e fz dk; [ m ' Dt c sde fr Sm 6E16(11010)
jz p fv my gr , f/ character_read w e fz dk; u dk w p fa y gi f; v dku fw Jht w Gu f character_read[1] jz p fv mjy D; a u dk
z w fy gw , f/ ' Dt c g hex_value = (6E*0x100) + 61 = 6E61 jz p fv my gw , f/ ' Dv dke JU 00 (\0) u dkr a w GUr c si f;
a e mu fx y fp mv Hk; a w Gz w fa e r Smjz p fy gw , f/ a e mu fq Hk; r Sma w mh hex_value [ m 6E61794D jz p fv my gw , f/
6E61794D w e fz dk; u dkEAX q Djy e fy dkUy gw , f/
6 . 4 / ESI = ESI ^ EAX;
EAX (6E61794D) e JU ESI (5DFEE4A4) w dkUu dk XOR v ky fy gw , f/ & & Sdv mw Jh 339F9DE9
w e fz dk; u dkESI r Smo dr f; y gw , f/
6 . 5 / index++;
index w e fz dk; u dkw p fa y gi f; v dku fw Jht w Gu f a e mu fw p fMu dr f while loop u dkv ky fa q mi fc sde fr Sm . . .
while(index < string_length-4){ // while(1<17){
memmove(&Read_4_Bytes, &User_Name[index], 4); // Read_4_Bytes = "yanm";
strrev(Read_4_Bytes); // Read_4_Bytes = "mnay";
EAX = StringtoHex(Read_4_Bytes); // EAX = 6D6E6179;
ESI = ESI ^ EAX; // ESI = 339F9DE9 ^ 6D6E6179 = 5EF1FC90;
index++; // index = 2;}
}
// while (2<17){ ..................}
// while (3<17){ ..................}
// while (4<17){ ..................}
// ......................................etc
while(index < string_length-4){ // while(16<17){
memmove(&Read_4_Bytes, &User_Name[index], 4); // Read_4_Bytes = " Tea";
strrev(Read_4_Bytes); // Read_4_Bytes = "aeT ";
EAX = StringtoHex(Read_4_Bytes); // EAX = 61655420;
ESI = ESI ^ EAX; // ESI = 44E3D4F9 ^ 61655420 = 258680D916;
index++; // index = 17;}
}
7 / printf("\nRegistration Code : %d\n",ESI);
XOR v ky fjy D; a e mu fq Hk; & v mw Jht a jz (258680D916 = 62957180110)u dkx kw fy gw , f/ 629571801
u a w mhMyanmar Cracking Team t w Gu f registration code jz p fy gw , f/
' gu a w mhkeygen t v ky fv ky fy Hkt a o ; p dw fy g/
a e mu fq Hk; t a e e JU a jy mjy c si fw mu a w mh registration routine u dk t jr Jw r f; exe z dki fx Jr Sm a & ; x m; w m
r [ kw fy gb l; / Kaspersky Internet Security 7.0 q dk& i f o lU& JU registration routine u dk lic.ppl ( w u , f
a w mh .ppl v dkU z dki ft r sdK; t p m; o w fr Sw fx m; a y r , fh .dll z dki fo mjz p fy gw , f/ ) r Sma & ; x m; jy D; Xilisoft u x kw fw Jh
a q mhz f0 Jv fa w Gr Sma w mh UILib71.dll z dki f ( o dkU) UILib8_MFCDll.dll ( o dkU) imfc0.dll z dki fr Sm a & ; x m; w m
jz p fw Jht a Mu mi f; a jy mMu m; & i f; e JU e d* Hk; c sKy fy g& a p /
., Patch _. (Beginner/Intermediate/Advanced)



tcef;(10) - Patch vkyfjcif; (Beginner/Intermediate/Advanced)
.,.. -.-.-..-.-.-. registration routine -. serial key -
... -._.. -. ... -. - . serial key - ... -.-. --. .-. . . - .
- .-. ._-. cracker .-- --. Full version (registered
version) -.... -.- patch - _ . crack _--. -. ---
_-.- patch -..-. Patch ..-..-- -. install ..- folder
..-....._. ... ....-. ,.. _.-.-.-. BookWorm -..-.- patch
.._.... _..-. -... serial .-.-. Teleport Pro .. ..-.
.-. .-. . . . _.. -. ._-. -. . . registered .._....- routine -.-
_. -.....- routine - .- _ . . . - .- - - .- _ .- _ ..-. _
"Myanmar Cracking Team proudly PRESENTS" . - .....- _ .._ . Trial Version
.-- Registered Version . - ... ...-.


,

....-. patch _.- .,._. ........_..-. ..-.-. ..
- . cracker .- . - patch _ ._.. _ . .,-.-. .-. .,
-.-. ._. cracker .- .- patch _ ._.. -.
, Beginner . patch _ . (Plain Stupid Method)
' Dac gi f; p Ofat mu fr Smaw mhv lo p fw e f; aw Gv ky fav hv ky fx &Sdw Jhpatch v ky fe n f; aw Gu dkt o Hk; jy Kjy D; crack
v ky fMu n fhr Sm jz p fy gw , f/ Patch v ky fMu n fhz dkUa&G; x m; w Jh y &dk* &r fu aw mh Exe password aq mhz f0 Jv fu dk
t o Hk; jy Kjy D; protect v ky fx m; w Jhcalculator (calc.exe) y &dk* &r fjz p fy gw , f/ Calculator y &dk* &r fu dkMicrosoft
Windows &JU system32 folder at mu fr Sm t v G, fw u law GUEdki fy gw , f/ Exe password aq mhz f0 Jv fu dkaw mh
www.salfeld.com r Sm download v ky f, lEdki fy gw , f/ Exe password aq mhz f0 Jv f[ m u dk, fr o Hk; ap c si fw Jh
y &dk* &r faw Gu dk t jc m; o law G r z Gi fhEdki fat mi f password e JU u mu G, fr Iay ; Edki fw Jh aq mhz f0 Jv fw p fc kjz p fy gw , f/
o i fht ae e JU ' Dy &dk* &r fu dkz Gi fhc si f&i f r Se fu e fw Jh password u dk &dku fx n fhEdki f&y gr , f/ au mi f; jy D? patch r v ky fc i f
y x r q Hk; v ky f&r Smu aw mh Exe password u dkz Gi fhjy D; calculator (calc.exe) y &dk* &r fu dk password ay ; z dkUy g/
y Hk( 2) /
., Patch _. (Beginner/Intermediate/Advanced)




,

,.. _.--. -.-.- calc.exe -.- "DEADBEEF" .- password .._ .
-.- . - .. . icon ..._.....-. .-.. ,

,
Password -.-...- calc.exe . - . _-_ .. . ,- . password
.-..- dialog box -.....


,
Password - . - . .. - _ . .-. ,- . _. . .

,
. -.-.-. .- password .. - . .-..-. ......_ ..._.
.-. password - . .. . ._.. ... .- patch _.-.. ........_..-
-- patch . _-...._-__-.. ,.. _.- "Password is incorrect" .....-
.. - - -. . . . - .. Olly . . calc.exe .-. ,-. _...
,
., Patch _. (Beginner/Intermediate/Advanced)
.


,.. right-click ._. Search for - All referenced text strings - .. Window
.. -. .. . .. window .. right-click ._. Search for text -.. ,-.
_...

,
,.. -.-.-.- "Password is incorrect" .....- -__. OK -..-
.,-. _...

.,
.,- hightlight _...-..- mouse ..-.- ,-. .-..

,
,- ..._-_ ,- error message -_- routine (VA 0054C8AC) - .-
.. --. .-. error message routine -...-.-. CALL calc.00435C4C - ..-. . -.
._-. VA 0054C87C - JNZ instruction - CALL calc.00435C4C - .-. . _ . . - .
,

,
., Patch _. (Beginner/Intermediate/Advanced)



,. .-. CALL calc.00435C4C -.-..-. VA 0054C873 - JE instruction
_.. -. ._-. VA 0054C86E ... . breakpoint .- . - _ . F9 - . ,- .
_. ..

,
,- textbox .. "Cracker" -_- -.-.- breakpoint .-.-..-
..- -...-... ,

,
,- VA 0054C86E ..- ..- register windows --.-_-_.. ,

,
,- _-_- EAX register .. "pFTZ^UC" ..... _ . EDX register .. "wqt}
wutt" ..... .-. .- .. --. .-. "wqt}wutt" . -. ,. . - .-.--_-
password - encrypt ..-....._..-. "pFTZ^UC" -.-. "Cracker" - encrypt ..
-. ,. ._. - VA 0054C86E - CALL routine -.-. "pFTZ^UC" "wqt}wutt" -
_ ._ .. -. --. _ error message - .-. . ... . . - .-. - patch _-_ _-
.. . -.-. CALL calc.004046A0 ... . NOP instruction ... ._ . JE SHORT
calc.0054C8D7 ... ..-. JMP SHORT calc.0054C8D7 ... .. . ... ... ..-.
- .-. . JE - JMP _ -.-. .. . - - NOP (No operation) _ -.
-.-. password ..- .....-._..-. JMP instruction -.-. error message - -.
.-..-._..-., _- .-. ,-. _...
., Patch _. (Beginner/Intermediate/Advanced)




,
,-. __..-. right-click ._. Copy to executable - All modification -._.
.- ...- Patch .._.....- .... .-._-_- ..-
password dialogbox .. _--- password - - _ - -.....
, Intermediate . patch _ .
-. . ..-. cracking - .- _ . . - . patch _ .- .. .. _-_ ..
-..-. -....- ....... .....- -.-.-. MrBills _.. -.
-. - -.- . . ...- . .-. - . - . - .. ._ ._.. . -. -. .- - .
_ .. .-. - . ..- _ . ... . - _... .- crack _ .. .._--. .- -. MrBills
- SND Team download section .. . download ..-. Lena reversing tutorial
(7) . . MrBills - -. -_ . _ . .....-. .- . .
-. ._-. .- . ... -. - Olly PEiD -.. ._-__-.. ,. ,

,

,
PEiD -.-. PE ..-.......- packer cryptor compiler ......--
......- tool -._..-. PEiD plugin -._..- Krypto Analyser - .._-_..
plugin ..-. module .- - .. . - . _ .... crypto algorithm .-- plugin - Krypto
..--.- ..._..._. ...-.
,- _-_... MrBills .- ....-. pack .._..- .- Visual C++
7.0 .......-.- .-.. MrBills version -.-. 2.1.0.1 _.. -.

,
., Patch _. (Beginner/Intermediate/Advanced)



,- Plugins . Krypto Analyser - ..- .,-. _...

.,
.,- _-_... .._..- crypto algorithm .- - .- -. CRC check
._-..- ..-......-.. .. ... .. . _.. -. .-. ._ PEiD - - - ..
,- _-_- -.-.- -.- run (F9) _-_ .. . ,- . .-
..

,
,.. _.--. -.-.- register ....-. About -.-

,
About - . - ,- . _. .. . ..-. - .-. - ..-.. . - .
-. Register -..- ,-. _...

,
., Patch _. (Beginner/Intermediate/Advanced)



,. -.-.- register ._ -.._-...-. register .
... ... - .- . - . ._.. - .-. - .. ._ . register _-__-..
,

,
-.-.- -..-..-. ,- _.-.

,
,-. -.-.- patch .... -.-. . ..- . . text string
.- - -. .. . -. ._ _ ._ .. . . -.-.--.. _...- .._
... ._-. text string .- - .._- ... - .-.. .- .-...- .-.._
-.-.--.-- ..-_-.. Olly . _...- ,

,
Text string .- - .. ,. . rightclick .- _. Search for - All referenced
text strings - ..- . text string window .. . .. Text string window . .
rightclick ._. -.-.-.- text - ... , .... .-..-.-.-. text
string window .. . ..- .. scroll _.. rightclick . .

,
. -.-.- ..- text - ..-_ ,

,
., Patch _. (Beginner/Intermediate/Advanced)



._-. text . VA 004299BD ..- ..-.- ,-. _...

,
,- VA 004299BD -. "You have entered an ..." - messagebox .....
_ . .-. ..- - scroll _._.._._-_- .,-. _...

.,
-.-.--._.- VA 004299F3 . . VA 004299BD - BadBoy message _.. _ .
VA 004299F3 -.-. GoodBoy message _.. -. ,- JNZ -. VA 004299F1 . jump
_.. ..-..- -. - .- . ..-. JNZ -. VA 004299F1 . jump ._..-. ._-.
"You have entered an invalid email ..." .- BadBoy message - _. -. --. JNZ
.... JMP ._. . .. . .........

,
,- TEST AL, AL - _-_- AL -. GoodBoy .. BadBoy ...-. .._.-
-. AL - VA 004299AD - CALL function . . .- . - ..-. _.. .-. -.._-.
..-. -.-.... CALL function ......-- .-.--.-. _..-...
-. registration .....- _..-. .... .--_-.-.-. -.-.-.
CALL function .. AL - -..-.-....-.- ......._.-.-
._-. VA 004299AD ..- breakpoint .- . - - .. .- - _-..
- .-. - . serial -. . - _ . . .. ...- - .- ..-. TEST AL, AL
- - CALL . . - .- . - .. . . AL -. - . .- . . ...-. - . .
..-.... -.- register . Goodboy message . VA 004299F1 - ..-...
..--.-. jump ._.. . . Badboy message ..
. . JNZ ._-. register .-- AL -. . _ _ . .- .
VA 004299AD .- scroll _._...- ._-_-_-.. ,

,
,- text .- -. - .-. - - - -.. ...- . About box . . .- ...-
Registration - _ run _-_-_-.. CALL .. -..-..-. ... VA
004299AD . . breakpoint .- . - ..-.
. - - Plain stupid method ._ BadBoy - .-.... conditional jump ..... patch
_ ..._.. ._ ........_. _.._ .......- register - - ..- _ .
. .
., Patch _. (Beginner/Intermediate/Advanced)



._-. . . . - .-. - . CALL - ..- _ . register _.. ._..
.._.-- AL - patch . _-......
-.-.- ,-. register _-_-_-.. F9 -.

,
"Register Now" button - . - - . . - - .-. - breakpoint .- . - - -
VA 004299AD ..- ..-.-. ,

,
F7 - ._. CALL _-__-.. . -.-.- CALL ..-._ ,

,
..- -..- _.. . . -. . .. .-. F8 - ._-.. .... AL -..._..
...-..-- ..._-_.-._-.. ._... ,

,
._-. . . .._- .-..- - .- .-. . . ,- VA 0040715A ... . TEST AL, AL
- .- ...

,
., Patch _. (Beginner/Intermediate/Advanced)



_..-. VA 0040715E - [5076A0] ..- VA 00407163 - JNZ VA 00407170 -
TEST AL, AL VA 00407174 - [5076A0] VA 00407155 - CALL - ..._-_
-.....- _. . AL - VA 00407155 - CALL .. .-.-_....-. ._-.
CALL . . -..- _.. . . -. . . . Enter key - .- .-....- Enter key -
. _ ..._. - .- - ._. . -. ... - .- - .-. run .. .---. -.-- run
... - CALL ..- --_-_-. .-. ._-. instruction pointer -_ .
.- Enter key .-- VA . . . . ,

,
VA 00407155 - CALL .... Enter key - .-- ,- . _. -.

,
_-_-_-.. VA 00407007 - MOV BL, AL VA 00407011 - MOV AL, BL
AL - BL -- . ..- _ . -. .. . AL -- . .- BL . ...-. VA 00407009
- CALL -. BL (& AL) . -.. - ..- ..- . . -. . . .._ . . ... AL
-..- VA 00406FF9 - CALL . . . ._.- ..-. .-. ._ AL - VA 00406FF9 -
CALL 00406F4B .. .-.-..-.. CALL ..- breakpoint .- . - - _-..
.- _. .- . . - .-. - -. CALL .- ..._- ..- .-.- ..- . -
... .- - .-. - -. CALL . . -. -. . -.. . . CALL ... . Enter key - .-.
.-.- AL - VA 00406FF9 - CALL .. .-.-..... ...... -.-.- break-
point .-.-..- .....-.. F9 -... . -.-.- breakpoint .- . - ..-
..- ..- ._ .,

.,
..- . - .._ . . - - . ..._- .-.
, AL -..- .-...
, AL -..- .-.--. ...- CALL - execute .._..-.
, CALL - F7 .
, AL -.-- --.-- .
., Patch _. (Beginner/Intermediate/Advanced)




,
,.. _.--...-. AL -. ._._..-. ._-. TEST AL, AL -
-..-. _-.. AL -. . _._.. . -. CALL - run . F8 -. AL -..
._.....-.- .-.. ,

,
._-. VA 00406FF9 - CALL .. AL - . .- . _ .- . - - -.
Registration .. _. _ . . - . -..- .- _.. . . .. F8 - .
..- . - . .- ..- . .- . . AL BL - . ..- -. ._. .. ... . -.
-

,
,- MOV BL, AL - execute - BL - . .-._ . . __.. . ... . -.
..-. AL - . __.. . ,

,

,
,- VA 00407009 ..- CALL - execute _....-. AL - . .-. 1
._. .. ..-. .- -. VA 00407011 - MOV AL, BL - _-_ BL --.- -. AL
. . ...-.
INFO: : --. -.-. EAX register - ... . .-..- _..
register .. ...........
- .-. ..- -. _- . ._ ... . .. .. -. -.-..-
..- .... ._.. -.
., Patch _. (Beginner/Intermediate/Advanced)




,
,. ..-. AL -..-. BL ._-. . __ _.. . ..-. ._-. VA 00407009 -
CALL -. AL BL . -..-..-.. .-.._.- -.-. .-.--.--. .._
. AL ._.- .- . - -.-. VA 00406FF9 - CALL . . ..- . .. - .-.
- CALL Enter key - .. CALL - . -.,. . ... . F8 ., F7 -.-
,-. _....

,
TEST AL, AL - _ . . . AL -..-. ._._..-. .-.. JNZ ._
register _._..._..,
.... AL -.-._.. . . -. . . - _-.. F8 - . - - AL - . .-.
._ _...-. ,
AL - pointer [5076A0], ..- . ..-.

,
Pointer - . .-. . __.. ....-. , Register ......-. jump ._..
.-.
.-.._ Register .._..- VA 0040715E - pointer [5076A0], . . .
. . ...-. . -. .._ ... ..- VA 00407174 - pointer [5076A0], . ...
,
VA 0040716B - CALL -. - .-. - register ....... .-.
.-. unregistered string .--_.- CALL _.. . -. F8 - .- . _-_ .. VA 0040
715E - AL - .- - .- - ..- .-. .- _-.. ..- VA 00407174 -
AL - ..
._.-.-. . - - . ......-. .... .-...-. cracking
_ .. .. - .- . ._-- .. - ..- - - ...... .. ._-. .-
...- -.-.. ....-.........-. ... .-...- -... .._
_ . .- ..- . ..-. ..- ... . ....- . . - .-. . _. . ... -- _-.
F8 - ..

,
., Patch _. (Beginner/Intermediate/Advanced)
.


,- JMP - .-. ... -. JMP ..- F8 .... ,-. _.
-.

.,
VA 00407076 . . ..- pointer [5076A1], -. .- -. Pointer .- ._-. .
... -. VA 0040707D - JNZ -. - .-. - register . .. jump _.. ..
.-. ._ F8 -.... -.-.- .._... register ._. . ,...-
-.

,
.-.._ -.-.--. -. BadBoy . ..- .. . -. .. . , VA
004299B9 - JNZ -. jump ._.. - . ,

,
._-. register ._..-. -..-_....-. .-_-__-..

,
. ,- . _. -. .. -.-.- ..- CALL - ._
.-.._ ,.. OK - . ._ . Olly - ..- -. _- . _ . - .- _. .- breakpoint
window .. VA 004299AD - breakpoint -.-_... .. -.- run F9, - _.
, -. register . ,- . - .-. - .- . - ..- ..- - ...- .
..

,
-.-.-. .-- CALL - ... F7 -._. VA 004299AD - CALL -
..
., Patch _. (Beginner/Intermediate/Advanced)




,
VA 00407155 - CALL - - -.-.- ..--. .-.. VA 00407155
..- F7 - . ,-. _...

,
VA 00406FF9 - CALL ..-._ F8 - ..

,
,- MOV BL, AL - .-...-. ...-. VA 00406FF9 - CALL -.
-.-.- ..... CALL . ._.- ..-. ._-. F7 -._. CALL ..
,- . _. ..

,
AL - -... .-.-....-. ._-_.. ..-- scroll .. -.-
.-. .-. ......- .- -. .. ._- . _.. .. .......-. - . - .-. .
serial . . .. ...- ..-. - . .. . -. ... - ..- .-. ._... .-.
AL - patch . _- ...... --. .-. - .-. . - .- - -. .- - .. ...
.. - Advanced Level Patching .-.

,
.-. VA 00406FC5 - BL - ._. .. _- ...... .,
., Patch _. (Beginner/Intermediate/Advanced)




.,
. -.-. _..-. _.. .. . . .. VA 00406FC5 ... . - .-. - MOV
AL, 1 ., INC AL ._. .. - . .. . . .. . ..
... . - .-. ._.. -. .- - .. . ..-- - execute -.
... -. -. AL == 1 .--. register .., --._..-. -.-
--. register .._.. -.-. unregister _....-. ._-. -.-.-
-.-. VA 004299AD - JNZ .... JMP ._.... -.-. -...
register _....._. ..--. -.- _... unregister _.. . .._ . _.. -.
..-..._-.-- .-.- ......-.
MOV AL, 1 . ,
MOV BL, 1 ., NOP
...-.-. -.- register _.. .. . .. -. _.. _.. .- .. .- ..._ ...
..._- ....- . ..- . ..- _- .. ... . . ..-. - .-. - MOV BL, 1 -
assemble -. . . - _-..
- .-. - . BL - -. ... . .- . - ... . -. . .. VA 00406FBC -
CALL - _ .. .. -. ... ...... .-. ..- .-. _-.-.
,

,
F9 - ._. -..-_....-. _-_.. ,
,
,- OK - .- ,- [Unregistered] .-..... ..-...-. .-..
,
,-_-_ ..--._-. register ....-.-. .-..
,
..-. intermediate . patch _.-.-. .._... _......_ Patch
_ ..... - . . .- .._ . . . -
., Patch _. (Beginner/Intermediate/Advanced)



, Advanced . patch _ .
y Hkr Se ft m; jz i fhaw mhplain stupid patch v ky fw Jhe n f; ? intermediate patch v ky fw Jhe n f; aw Ge JU register
v ky fw m t q i fajy Edki fay r , fht jr Jw r f; aw mhr jz p fEdki fy gb l; / ' gaMu mi fh' Dw p fc gr Sm advanced t q i fhpatch v ky f
Mu n fhMu r Smjz p fy gw , f/
INFO: : Plain stupid patch u aw mh JE w dkUv dk conditional jump aw Gu dk t jr Jw r f; jump jz p fap at mi f
v ky fw Jhe n f; jz p fy gw , f/ Intermediate patch u aw mhCALL x Ju AL w e fz dk; u dk1 jz p fat mi fv ky fjy D; jy e fx Gu f
v mc sde fr Sm register jz p fap w my g/ Plain stupid method u dk &dk; &Si f; p Gm b mo mjy e f&r , fq dk&i faw mh ]Register
r jz p fao mfv n f; BadBoy u dkau smfv Tm; jc i f; } jz p fy gw , f/
INFO: : Intermediate patch u aw mh MOV AL, BYTE PTR DS:[EAX+24] w dkUv dku k' faw Gu dkaw GU&i f
MOV AL, 0 v dkUajy mi f; r Smjz p fjy D; o lUu dk b mo mjy e f&r , fq dk&i faw mh ]v dkt y fw Jht y dki f; t w Gu f register jz p fap
jc i f; } jz p fy gw , f/
INFO: : Advanced patch u aw mh b , fae &mr Sm pointer w e fz dk; u dk o w fr Sw fo v Jq dkw mu kd x Jx J0 i f0 i f
av hv mw mjz p fjy D; pointer t w Gu f setting u kdo m patch v ky fw mjz p fy gw , f/
' Do i fc e f; p mt w Gu f av hv mz dkU&n f&G, fx m; w Jh y &dk* &r fu aw mh Noah's Ark Deluxe 1.1 jz p fjy D;
www.popcap.com r Sm t c r Jh download v ky f, lEdki fy gw , f/ y &dk* &r f ( WinNoah.exe) u dk z Gi fhv dku f&i faw mh
y Hk( 6 3 ) t w dki f; jr i f&r Smy g/

y Hk( 6 3 )
u p m; c Gi fho u fw r f; u ke fo Gm; jy Djz p fw Jht w Gu f register v ky f&aw mhr Smy g/ Register v ky fMu n fh&i faw mh
y Hk( 6 4 ) t w dki f; jr i f&y gw , f/

y Hk( 6 4 )
., Patch _. (Beginner/Intermediate/Advanced)



y &dk* &r f&JUo ab mo b m0 u dko do Gm; jy Dr dkUOlly r Smu k' faw Gu dkz Gi fhMu n fh&at mi f/ y Hk( 6 5 ) /

y Hk( 6 5 )
y Hk( 6 5 ) u aw mh WinNoah.exe &JU EP &Sd&mjz p fy gw , f/ y Hk( 6 4 ) u Badboy message u dk&SmMu n fh&
at mi f/ y Hk( 6 6 ) /

y Hk( 6 6 )
Search u ae text string (Badboy message) aw Gu dk&Smw Jht c g y Hk( 6 6 ) t w dki f; jr i f&y gw , f/ ' Dae &m
aw Gr Sm breakpoint o w fr Sw fjy D; double-click ESdy fv dku fy g/ y Hk( 6 7 ) /

y Hk( 6 7 )
y Hk( 6 7 ) r Smjr i f&w mu aw mh BadBoy u dkac : o Hk; w Jh CALL &JUt p jz p fjy D; VA 0041A315 e JU VA
0041E853 w dkUu ae ' DCALL u dk ac : o Hk; Mu w mjz p fy gw , f/ VA 0041A315 e JU VA 0041E853 &Sd&mu dk
Mu n fhv dku fMu &at mi f/ y Hk( 6 8 ) /

y Hk( 6 8 )
y Hk( 6 8 ) u dk ao c smMu n fhr , fq dk&i f BadBoy CALL aw Gq Dr a&mu fc i fr Sm CALL DWORD PTR
DS:[EAX+40]; q Dt &i fo Gm; jy D; registeration v ky faq mi fc su fat mi fjr i fjc i f; &Sd^ r &Sd p p faq ; w maw GU&y gw , f/
p p fv mv dkU&w Jh&v ' fu dk AL r Smo dr f; y gw , f/ jy D; &i f BadBoy u dkau smfjc i f; &Sd^ r &Sdp p fy gw , f/ ' gq dk BadBoy u dk
au smfEdki fz dkU JNZ ae &mr Sm JMP v dkUajy mi f; Mu n fhy gr , f/ jy D; &i faw mh jy i fx m; w Jhu k' fu dk o dr f; q n f; v dku fjy D; y &dk
* &r fu dk jy e fz Gi fhMu n fhv dku fy g/ ESp fo u f&mt r n fe JU ESp fo u f&mu k' fu dk &dku fx n hfv dku f&i f ' D* dr f; u dk u p m; v dkU&w m
aw GU&y gw , f/ ' gay r , fh ' D* dr f; [ m register v ky fw Jht c sde fr Smy J registered jz p fy gw , f/ t jr Jw r f; registered
jz p fjc i f; r &Sdy gb l; / ' gq dk&i f ae mu fx y fx y fjy i fz dkUv dkt y fae y gjy D/ Olly r Smae mu fx y f&Smv dku fMu &at mi f/ y Hk( 6 9 ) /
., Patch _. (Beginner/Intermediate/Advanced)




y Hk( 6 9 )
y Hk( 6 9 ) u string aw G&Sd&mu dkMu n fhv dku fMu &at mi f/ y Hk( 7 0 ) /

y Hk( 7 0 )
y Hk( 7 0 ) u aw mh register v ky fx m; jc i f; &Sd^ r &Sdp p fw Jh CALL &JUt p jz p fjy D; o lUu dk ac : o Hk; w Jh VA aw Gu
aw mh 41A158? 41A479? 41D469 e JU 420431 w dkUjz p fy gw , f/ ' Dae &maw Gr Sm breakpoint o w fr Sw fjy D;
y &dk* &r fu dk run (F9) Mu n fhv dku fy g/ y Hk( 6 3 ) t w dki f; jr i f&y gr , f/ y Hk( 6 3 ) u Click Here to Register Now.
u dka&G; v dku f&i f y Hk( 7 1 ) t w dki f; jr i f&y gw , f/

y Hk( 7 1 )
y Hk( 7 1 ) r Smjr i f&w mu aw mh u Re faw mfw dkUae mu fq Hk; o w fr Sw fv dku fw Jh breakpoint av ; c kx Ju w p fc kr Sm
v m&y fw mjz p fy gw , f/ ' Dae &mu dkregister v ky fr So ma&mu fr Smjz p fy gw , f/ Registered jz p fx m; w Jho lw p fa, mu f
[ m ae mu fx y f register v ky fz dkUr v dkaw mhw Jht w Gu f ' Dae &mr Sm Click Here to Register Now. t p m; Click
Here to Play. jz p fae &r Smy g/ ' Dae &mu dk au smfEdki fr , fq dk&i f register v ky fp &mr v kdaw mhb l; v dkU x i fy gw , f/
' gaMu mi fhy Hk( 7 1 ) u JE ae &mw dki f; r Sm JMP v dkUjy i fjy D; y &dk* &r fu dko dr f; v dku fy g/ o dr f; x m; w Jhy &dk* &r fu dkz Gi fhMu n hf
&i faw mh y Hk( 6 3 ) t w dki f; jr i fae &OD; r Smjz p fjy D; registered r jz p fy gb l; / ' gaMu mi fhr dkUv J conditional jump aw Gu dk
jump v ky fw dki f; v Jregistered r jz p fb l; v dkUu Re faw mfajy mc Jhw my g/
au mi f; jy D/ y Hk( 7 1 ) u VA 4203E7 (CALL DWORD PTR DS:[EDX+10]) ae &mr Sm breakpoint
o w fr Sw fjy D; b , f CALL u dkac : o Hk; w , fq dkw m Mu n fhMu &at mi f/ y Hk( 7 2) /

y Hk( 7 2)
MOV ECX, DWORD PTR DS:[ESI+50]; // ECX= DS[00B78E70] = VA 49C518
CMP BYTE PTD DS:[ECX+328], BL; // DS[49C518+328] = 49C840, BL = 0
VA 00498C40 &JUdata window r Sm b mw e fz dk; &Sdo v Jq dkw m Mu n hfv kdu fMu &at mi f/ y Hk( 7 3 ) /
., Patch _. (Beginner/Intermediate/Advanced)




y Hk( 7 3 )
y Hk( 7 3 ) r Smjr i f&w Jht w dki f; DS[49C840] u byte w e fz dk; e JUBL &JUw e fz dk; u dkEdIi f; , SOfw Jht c g n Dc Jh&i f VA
420416 u dka&mu fv mr Smjz p fy gw , f/ y Hk( 7 4 ) /

y Hk( 7 4 )
VA 420419: CMP BYTE PTD DS:[ECX+328], BL; // DS[49C518+328] = 49C840, BL = 0
VA 420419 u DS[49C840] u byte w e fz dk; e JU BL &JUw e fz dk; u dk ae mu fw p fMu dr fEdIi f; , SOfw Jht c g
n Dc Jh&i f VA 420424 u dka&mu fv mr Smjz p fy gw , f/ ' Dv kde JUEdIi f; , SOfv mw Jht c gr Sm VA 00420431 u CALL u dk
au smfo Gm; Edki fw m aw GU&y gw , f/ ' gq dkb maMu mi fh* dr f; u dku p m; v dkUr &w my gv J/ w u , faw mhVA 00420431 u
CALL au smfEdki fjc i f; [ m t jr Jw r f; r [ kw fv dkUy g/ jy D; &i f BL &JUw e fz dk; u dkdump window &JUVA 00420431 u
byte w e fz dk; e JU ESp fMu dr fEdIi f; , SOfw m aw GU&y gw , f/ ' gaMu mi fh ' Dae &mr Sm o kn t p m; 1 v dkUajy mi f; jy D; y &dk* &r fu dk
run (F9) Mu n fhy g/ y Hk( 7 5 ) /

y Hk( 7 5 )
F9 u dkESdy fjy D; Mu n fhr , fq dk&i faw mhy Hk( 7 6 ) t w dki f; w e fz dk; aw Gajy mi f; v Jo Gm; w maw GU&y gw , f/

y Hk( 7 6 )
y Hk( 7 4 ) u VA 4203E7 r Sm&Sdw Jhbrekapoint u dkjz Kw fjy D; F9 u dkEdSy fv dku fy g/

y Hk( 7 7 )
., Patch _. (Beginner/Intermediate/Advanced)



F9 u dkESdy fv dku fw Jht c gr Smaw mh y Hk( 7 7 ) t w dki f; jr i f&r Smjz p fy gw , f/ ' gq dk dump window &JU VA
0049C840 r Sm 1 v dkUjy i fz dkUq Hk; jz w fc Jhw m r Se fo Gm; y gw , f/ y &dk* &r fu dk Ctrl+F2 (restart) ESdy fjy D; jy e fz Gi fhv dku fy g/
Dump window &JUVA 0049C840 r Sm 1 v dkUjy i fv dku fy g/ jy D; &i faw mhdump window r Sm right-click ESdy fjy D;
Copy to executable file u dka&G; w Jht c g y Hk( 7 8 ) t w dki f; jr i f&y gr , f/

y Hk( 7 8 )
y Hk( 7 8 ) r Sm right-click ESdy fjy D; ESp fo u f&mt r n fe JU z dki fu dko dr f; v dku fy g/ jy D; &i f u Re faw mfw dkU o dr f; x m; w Jh
z dki fu dkjy e fz Gi fhMu n fhv dku fMu &at mi f/

y Hk( 7 9 )
w p fc kc kaw mh x y fr Sm; ae jy Dx i fy gw , f/ y x r t Mu dr f u k' fjy i fjy D; run w ke f; u y Hk( 7 7 ) t w dki f; jr i f&y g
w , f/ c kz dki ft ae e JUo dr f; jy D; c sde fr Smaw mh y Hk( 7 9 ) t w dki f; jr i fae &y gw , f/ ' gaMu mi fh u k' fjy i fjy D; o dr f; v dku fw Jhz dki fu dk
Olly r Sm jy e fz Gi fhMu n fhv dku fMu &at mi f/ y Hk( 8 0 ) /

y Hk( 8 0 )
Dump window &JU VA 0049C840 r Smaw mhu Re faw mfw dkU o dr f; x m; w Jht w dki f; y J&Sdy gw , f/ ' Dae &mu dk
ap mi fhMu n fhz dkUaw mhv dkae jy Dx i fy gw , f/

y Hk( 8 1 )
' gaMu mi fh ' Dae &mr Sm y Hk( 8 1 ) t w dki f; hardware breakpoint o w fr Sw fjy D; ap mi fhMu n fhy gr , f/ Dump
window r Sm right-click ESdy fjy D; Breakpoint u Hardware, on write Byte u dka&G; v dku fy g/ jy D; &i faw mh
F9 u dkESdy fjy D; b maw Gajy mi f; v Jo Gm; o v Jq dkw m ap mi fhMu n fhv dkU&y gjy D/
., Patch _. (Beginner/Intermediate/Advanced)



y Hk( 8 2)
w &m; c Haw mhaw GUy gjy D/ VA 0042ABFE u MOV BYTE PTR SS:[EBP+328], BL u dkexecute
v ky fjy D; c sde fr Sm dump window u VA 0049C840 &JUbyte w e fz dk; ajy mi f; o Gm; w mjz p fy gw , f/ F9 u kdx y fEdSy fy g/
y Hk( 8 3 )
y Hk( 8 3 ) r Smjr i f&w Jht w dki f; AL u v J o kn w e fz dk; u dk v majy mi f; y gw , f/ au mi f; jy D ' Dae &mESp fc kr Sm 1
v dkUjy i fv dku fjy D; z dki fu dko dr f; v dku fr , fq dk&i fau m/ ' gq dk&i faw mhy Hk( 8 4 ) t w dki f; jr i f&r Smjz p fy gw , f/

y Hk( 8 4 )
e d* Hk; c sKy ft ae e JUajy m&&i f Noah's Ark u dkregistered jz p fap z dkUu Re faw mfw dkUt ae e JUat mu fy gae &mESp fc k
r Sm u k' faw Gu dkjy i fay ; c Jh&y gw , f -
1 / VA 0042ABFE u MOV BYTE PTR SS:[EBP+328], BL u dkMOV BYTE PTR
SS:[EBP+328], 1?
2/ VA 0042D6B8 u MOV BYTE PTR SS:[EBP+328], AL u dkMOV BYTE PTR
SS:[EBP+328], 1/
o i fhu dk' Dv dkjy i fz dkUajy mc Jhay r , fhu Re faw mfu aw mhy Hk( 8 5 ) t w dki f; ae mu fw p fr sdK; jy i fc Jhy gw , f/ OmP f&Sdo v dk
Mu dKu fo v dkjy i fEdki fy gw , f/

y Hk( 8 5 )
., uPP _. patch . . - ._ .


tcef;(11) - uPPP jzif h patch zdkif zefwD;jcif;
' Dw p fc gr Sma w mh uPPP u dk t o Hk; jy KNy D; patch z dki fa v ; a w Gu dk z e fw D; Mu n fhy gr , f/ y x r q Hk; patch
z dki fa v ; a w G& JU o a b mo b m0 u dka v hv mMu n fhy gr , f/
- Patch z dki fa v ; a w G& JU t u sdK; a u s; Z l; u a w mh z dki fq dku fa o ; a o ; a v ; e JY a q mhz f0 Jv fu dk crack v ky fE dki fw m
jz p fy gw , f/ q dkv dkw mu crack v ky fx m; Ny D; o m; z dki fu dk upload v ky fa y ; p & m r v dkt y fw Jht w Gu f t i fw me u fr Sm
1MB a u smfw Jh crack v ky fx m; w Jh r l& i f; z dki fa w Gu dk upload v ky fa y ; p & m r v dka w mhb J 200KB a v mu fo m& Sdw Jh
patch z dki fv Sv Sa v ; a w Gu dky Jt i fw me u fr Sm w i fa y ; p & m v dky ga w mhw , f/
- Patch z dki fa w G& JU t m; e n f; c su fu a w mh r dr d b , fa e & mr Sm crack v ky fx m; o v Jq dkw mu dk developer a w G?
t jc m; cracker a w Gu t v G, fw u l & dy fr do d& Sda p E dki fw m jz p fy gw , f/ ( ' Dt c g developer a w Gu ' Da e & mu dk
crack r v ky fE dki fa t mi f u k' fa w Gu dk jy e fv n fjy i fq i fE dki fo v dk t jc m; cracker a w Go d& Sdjc i f; t m; jz i fh r dr d crack
v ky fw Jhe n f; v r f; u dkt w kc dk; E dki fy gw , f/ )
- Patch z dki f& JU u e fYo w fc su fu a w mh patch z dki fz e fw D; o l[ m t r Sm; t , Gi f; w p fp Hkw & m jy Kv ky fr dc Jh& i f crack
v ky fc H& w Jhz dki f t v ky fr v ky fw my gy J/
- Patch z dki ft a o e JY patch z dki ft & Si fq dkNy D; E Sp fr sdK; & Sdy gw , f/ Patch z dki ft a o a w Gu a w mh o w fr Sw fx m; w Jh
version u dko m patch v ky fE dki fy gw , f/ Version a jy mi f; & i f t v ky fr v ky fa w mhy gb l; /
, Internet Download Manager 6.0.x - - patch . .-._.
Patch z dki f r z e fw D; c i f uPPP u dka v hv mMu n fh& a t mi f/

y Hk( 1 )
y Hk( 1 ) r Smjr i f& w mu c & u fv ky fr , fh application e JYy w fo u fw Jh t c su ft v u fa w Gy g/ ' ghjy i f a q mhz f0 Jv f
u dkcrack v ky fo l? crack v ky fw Jha e Yp GJw dkYu dky g x n fho Gi f; E dki fy gw , f/

y Hk( 2 )
y Hk( 2 ) r Sma w mh b , fv dk patch v ky fc si fo v Jq dkw mu dk a & G; c s, fE dki fy gw , f/ Patch v ky fe n f; ( 4 ) e n f;
& Sdy gw , f/ ( ' Dt y dki f; r Sma w mhSeek & Replace pattern e JYRegistry patch w dkYu dkt o Hk; jy Kr Smjz p fy gw , f/ )
., uPP _. patch . . - ._ .
.


y Hk( 3 )
y Hk( 3 ) u a w mhu dk, fa y : a p c si fw Jhtemplate a v ; a w Ge JYq dki fy gw , f/ E Sp fo u f& m font? E Sp fo u f& m" mw fy Hk?
E Sp fo u f& mw D; v Hk; ? E Sp fo u f& m icon w dkYu dk a & G; c s, fE dki fy gw , f/ ' Da v mu fo dNy D; o Gm; Ny Dq dka w mh patch z dki fu dk
p w i fz e fw D; v dku fMu & a t mi f/
y x r q Hk; Olly r Sm patch v ky f& r , fh a e & mu dk & SmMu & a t mi f/ ( IDM 6.0.8 Build 3 e JY e r le m
jy x m; jc i f; jz p fy gw , f/ )

y Hk( 4 )
TEST EDI, EDI (85 FF) a e & mu dk XOR EDI, EDI (33 FF) e JY t p m; x dk; y gr , f/ ' gr So m EDI
w e fz dk; [ m o kn jz p fo Gm; Ny D; "Internet Download Manager has been registered with a fake Serial
Number. IDM is exiting..." q dkw JhMessageBox u dka u smfv Tm; E dki fr Sm jz p fy gw , f/ ' ga y r , fh o i fht a e e JY
r Sw fx m; & r Smu y & dk* & r fu k' fa w Gx Jr Sm TEST EDI, EDI [ m t r sm; Mu D; y gy gw , f/ u Re fa w mfw dkY a & G; c Jhw mu
Seek & Replace method jz p fw Jht w Gu f TEST EDI, EDI w dki f; u dk XOR EDI, EDO w dki f; e JY
t p m; x dk; r , fq dk& i f y & dk* & r f[ m crash jz p fy gv dr fhr , f/ ' ga Mu mi fhy dkNy D; w du sw Jht c su ft v u fa w Gu dk a y ; & y gr , f/
' ga Mu mi fh8B F8 83 C4 04 85 FF 74 0A u dk8B F8 83 C4 04 33 FF 74 0A e JYt p m; x kd; y gr , f/
a e mu fx y f patch v ky f& r , fhw p fa e & mu a w mhy Hk( 5 ) r Sm jr i f& w Jht w dki f; jz p fy gw , f/
y Hk( 5 )
., uPP _. patch . . - ._ .


IDM [ m "Internet Download Manager has been registered with a fake Serial Number.
IDM is exiting..." u dk encrypt v ky fx m; Ny D; w u , fv dkY u Re fa w mfw dkY& JU serial [ m t Ge fv dki f; u o lY& JU
database x Jr Sm r & Sdc Jh& i f nag p mw e f; a y : Ny D; y & dk* & r fu dk y dw fr Smjz p fy gw , f/ ' Da e & mu dk a u smfv Tm; & r Smjz p fy gw , f/
JE 00444532 (74 6D) a e & mu dk JMP 00444532 (EB 6D) e JYt p m; x dk; y gr , f/ PUSH 0 (6A 00) a e & mr Sm
JMP 4444C3 e JY t p m; x dk; y gr , f/ ' ga Mu mi fh 74 6D 6A 00 a e & mr Sm EB 6D EB FC e JY t p m; x dk; y gr , f/
jy D; & i fa w mhy Hk( 6 ) t w dki f; t p m; x dk; z dkYv ky f& y gr , f/
y Hk( 6 )
74 6D 6A 00 t w Gu f t p m; x dk; r , fhEB 6D EB FC t w Gu fq dk& i fv n f; y Hk( 6 ) t w dki f; v ky fNy D; Add to
list u dk a & G; a y ; & y gr , f/ ' gq dk IDMan.exe u dk patch v ky fw m Ny D; y gNy D/ Registry u dk patch v ky fz dkYy J
u se fy gw , f/
y Hk( 7 )
y Hk( 7 ) r Smjr i f& w Jht w dki f; z dki fu dk o dr f; q n f; Ny D; y Hk( 1 ) u Create Patch button u dk a & G; v dku fr , fq dk& i f
u Re fa w mfw dkYv dkc si fw JhIDM patch z dki fu dk& & SdNy Djz p fy gw , f/ y Hk( 8 ) /
y Hk( 8 )
., uPP _. patch . . - ._ .


, FlyHelp 6.1 -- patch . .-._.
' Dw p fc gr Sma w mh y x r y dki f; w ke f; u a q G; a E G; z dkY u se fc Jhw Jh File Drop e JY Offset Patch w dkYu dk a q G; a E G; r Sm
jz p fy gw , f/
y x r q Hk; t a e e JY uPPP u dkz Gi fhNy D; Project-> New v ky fNy D; v dkt y fw Jht c su ft v u fa w Gu dk
& dku fx n fhy gr , f/ ( t y dki f; ( 1 ) r Sm a q G; a E G; Ny D; jz p fv dkYx y fr Hr a q G; a E G; a w mhy gb l; )

y Hk( 9 )
' kw d, t a e e JYu dk, f patch v ky fc si fw Jht r sdK; t p m; u dka & G; y gr , f/ y Hk( 1 0 ) /

y Hk( 1 0 )
' Da e & mr Sm t o Hk; jy Kr , fh e n f; v r f; a w Gu a w mh File Drop e JY Offset Patch w dkYjz p fy gw , f/ Offset
patch u dk a & G; v dku fw Jht w Gu f patch z dki f[ m t a o jz p fo Gm; y gw , f/ q dkv dkw mu FlyHelp & JU a q mhz f0 Jv f
version a jy mi f; o Gm; & i f patch z dki fu t v ky fv ky fa w mhr Sm r [ kw fy gb l; /
w w d, t q i fht a e e JY Offset Patch button u dkE Sdy fNy D; u dk, f patch v ky fr , fh offset e JY byte a w Gu dk
E dIi f; , SOfy gr , f/ y Hk( 1 1 ) / ' Da e & mr Sm offset patch v ky fr , fh z dki fa w Gu a w mh FSWebHelpLib.dll e JY
HtmlViewEdit.dll w dkYjz p fy gw , f/

y Hk( 1 1 )
., uPP _. patch . . - ._ .


y Hk( 1 1 ) t w dki f; r E dIi f; , SOfc i fr Sm r l& i f; HtmlViewEdit.dll z dki fu dk e mr n fa jy mi f; x m; v dkY r & y gb l; /
Crack v ky fx m; Ny D; o m; HtmlViewEdit(CRACKED).dll z dki fu v n f; t o i fh& Sdx m; & y gr , f/ E dIi f; , SOfNy D; & i f
save v ky fy g/ FSWebHelpLib.dll t w Gu fv n f; t v m; w l jy Kv ky fy g/ ( ' Dw p fc g a q mhz f0 Jv fu dka w mh u dk, fw dki f
crack v ky f& r Sm jz p fy gw , f/ Crack v ky fe n f; u dka w mhr & Si f; jy a w mhy gb l; / )
a e mu fw p fq i fht a e e JY v ky f& r Smu a w mh u Re fa w mfw dkY crack v ky fx m; w Jh z dki fu dk C:\Program Files\Fly
Help z dk' ga t mu f o Gm; x m; z dkYy Jjz p fy gw , f/

y Hk( 1 2 )
o w djy K& r Smu a w mhFly_Help.exe q dkw m FlyHelp.exe u a r G; x kw fa y ; v dku fw Jhchild y & dk* & r fjz p fNy D;
' Dy & d* & r fu dk FlyHelp.exe u dkz Gi hfc sde fMu r S x kw fo Hk; w my g/ u se fw Jht c sde fr Sm jy e fz su fy gw , f/ ' ga Mu mi fh
u Re fa w mfw dkYt a e e JY crack v ky fx m; w Jh u Re fa w mfw dkY z dki fu dk r l& i f; Fly_Help.exe e JY t p m; r x dk; E dki fa t mi fv dkY
READONLY/HIDDEN/SYSTEM w dkYu dka & G; c s, fa y ; x m; & w m jz p fy gw , f/
a e mu fw p fq i fhu a w mhu dk, fMu dKu fw Jhtemplate/theme u dka & G; c s, fw Jht y dki f; jz p fy gw , f/

y Hk( 1 3 )
' gq dk& i fa w mh patch v ky fz dkY jy i fq i fw Jht y dki f; Ny D; y gNy D/ y Hk( 9 ) u Create Patch button u dk
E Sdy fv dku f& Hky gy J/ ' Dt c g y Hk( 1 4 ) r Smjr i f& w Jht w dki f; jy D; jy n fhp Hkw Jhpatch z dki fw p fc ku dk& & Sdv mr Smjz p fy gw , f/

y Hk( 1 4 )
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 162 -

tcef;(12) - Cracker rsm; owdxm;oifhaom Windows API rsm;
INFO: : API (Application Programming Interface) q dkw mu a w mh function a w Gu dkp kp n f; x m; w Jht & m
jz p fjy D; y & dk* & r fa w Ge JU OS Mu m; q u fo G, f& mr Sm t o Hk; jy Ky gw , f/ Win32 API q dkw mu a w mh function a w G
t r sm; Mu D; p kp n f; x m; w mjz p fjy D; Windows application a w Gt w Gu f low-level programming interface
jz p fy gw , f/ Microsoft u Win32 API & JU t * Fg& y fa w Gt r sm; p ky g0 i fw Jh high-level interface a w Gu dk r dw f
q u fc Jhy gw , f/ ' Dinterface a w Gx Ju t x i f& Sm; q Hk; u a w mh MFC (Microsoft Foundation Classes) jz p fjy D;
Windows e JUq u fo G, fz dkU C++ object a w Gu dkt o Hk; jy Ky gw , f/ w u , fw r f; a w mh MFC u OS u dk a c : o Hk; z dkU
Win32 API u dkt o Hk; jy K& w mjz p fy gw , f/ t c ka c w fr Sm e mr n fMu D; a e w Jh .Net Framework [ mv J OS & JU
service a w Gu dko Hk; p GJE dki fz dkU System q dkw Jh class u dko Hk; p GJw , fq dka y r , fh o l[ mv Ja e mu fq Hk; a w mh Win32 API
u dka c : o Hk; & w my gy J/ Win32 API r Sm t Mu r f; z si f; t m; jz i fh API 2 0 0 0 a u smfy g0 i fjy D; Kernel ? USER e JU GDI
q dkjy D; t ky fp k3 c kc GJE dki fy gw , f/ a e mu fw p fc ku a w mh native API y g/ Native API u a w mh Windows NT p e p f
t w Gu f interface w p fc kjz p fy gw , f/ Windows NT r Sma w mh Win32 API [ m native API & JU t a y : v Tmr Sm
& Sdy gw , f/ NT kernel r Sm GUI e JUy w fo u fjy D; b mr Sv ky fp & mr & Sdw Jht w Gu f native API r Sm graphics e JU
y w fo u fw Jh b , fv ky fi e f; r Sr y g0 i fy gb l; / ' ga Mu mi fhr dkU v ky fa q mi fc su ft & a jy m& & i f native API [ m Windows
kernel e JUc sdw fq u f& mr Sm t " du u sjy D; memory manager? I/O system? object manager? process? thread
w dkUe JU c sdw fq u ft o Hk; jy Ky gw , f/ Application y & dk* & r fa w G[ m native API a w Gu dk b , fa w mhr Sw dku f& dku fa c :
r o Hk; y gb l; / o Hk; c Jh& i fa w mh Windows 98 e JU o [ Z mw jz p fr Iu dk c sdK; a y gu fa p y gv dr fhr , f/ Microsoft u v J
native API a w Ge JUy w fo u fjy D; t c su ft v u fa w Gr Qa 0 jc i f; r & Sdw Jht w Gu f Application y & dk* & r fa w G[ m OS e JU
q u fo G, fz dkUt w Gu f Win32 API a w Gu dky J o Hk; a e & OD; r Smjz p fy gw , f/ Win32 API t w Gu f e r le m DLL z dki fa w G
u a w mh kernel32.dll? user32.dll? gdi32.dll w dkUjz p fjy D; native API t w Gu f e r le m DLL z dki fu a w mh
ntdll.dll jz p fy gw , f/ native API a w G& JU x l; jc m; c su fu a w mh o lw dkU& JU function t r n fa w Ga & SUr Sm Nt (Nt
CreateFile) e JU Zw (ZwCreateFile) p a v h& Sdjc i f; y g/

y Hk( 1 ) Win32 API r sm; kernel E Si fhy w fo u fq u fE G, fa e y Hk
Kernel API r sm; / / BASE API v dkUv Ja c : a 0 : jy D; o lw dkUa w G[ m kernel32.dll x Jr Sm& Sdy gw , f/ o lUr Sm
z dki ft o Gi f; ^ t x kw f? r Sw fOmP fp Dr Hc e fUc GJr I? object p Dr Hc e fUc GJr I? process e JU thread p Dr Hc e fUc GJr Ip w Jh GUI r y g0 i fw Jh
service a w Gt m; v Hk; y g0 i fy gw , f/ kernel32.dll [ m service t r sdK; r sdK; u dk v ky fa q mi fE dki fz dkU low-level native
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 163 -

API jz p fw Jh ntdll.dll u dka c : o Hk; y gw , f/ Kernel API a w Gu dk z dki fa w G? synchronization object a w Gp w Jh
kernel-level object a w Ge JU w GJv ky f& mr Sm? z e fw D; & mr Sm t o Hk; jy Ky gw , f/
GDI API r sm; / / GDI API a w Gu a w mh GDI32.dll x Jr Sm& Sdjy D; r sOf; w p fa Mu mi f; q GJjc i f; ? bitmap w p fc k
u dkjy o jc i f; p w Jh graphics e JUq dki fw Jh service a w Gy g0 i fy gw , f/ r lv u a w mh GDI a w Gu dk kernel module
w p fc kjz p fw JhWIN32K.sys r Sm p r f; o y fo Hk; p GJc Jhy gw , f/ Device context? brush? pen p w Jhgraphic q GJjc i f; r Sm
t o Hk; jy Kz dkU GDI [ m GDI object a w Gu dkt " du x m; y gw , f/ b ma Mu mi fhv Jq dka w mh' Dobject a w Gu dk kernel & JU
object manager u r u dki fw G, fE dki fv dkUy g/
USER API r sm; / / User32.dll r Smy g0 i fjy D; window-management? menu? dialog box? user-interface
control p w Jhhiger-level GUI service a w Gy g0 i fy gw , f/ GUI object a w Gt m; v Hk; u dk USER u GDI call
a w Go Hk; jy D; q GJw mjz p fy gw , f/ USER API a w G[ m kernel & JU object manager u r u dki fw G, fE dki fw Jhwindow
a w G? menu a w Gv dkuser interace e JUq dki fw Jhobject a w Gu dkt " du x m; u dki fw G, fy gw , f/
' Dt c e f; r Sma w mh cracking v ky f& mr Sm o w dx m; jy D; a p mi fhMu n fh& r , fh API function a w Gt a Mu mi f; u dk
a v hv mr Smjz p fy gw , f/ API function a w Gt a Mu mi f; u dk t a o ; p dw fo dx m; jc i f; t m; jz i hf crack v ky f& mr Sm v G, fu l
v mr Smjz p fy gw , f/ ' Da p mi fhMu n fh& r , fhAPI function a w Gu a w mha t mu fy gt w dki f; jz p fy gw , f -
Dialog Box r sm; E Si fhy w fo u fo n fht c g
DialogBoxParamA
GetDlgItem
GetDlgItemInt
GetDlgItemText
GetWindowText
GetWindowWord
MessageBox r sm; E Si fhy w fo u fo n fht c g
MessageBeep
MessageBoxA
MessageBoxEx
SendMessage
SendDlgItemMessage
Registry E Si fhy w fo u fo n fht c g
RegCreateKey
RegDeleteKey
RegQueryValue
RegQueryValueEx
RegCloseKey
RegOpenKey
z dki fr St c su ft v u fr sm; z w fjc i f; ^ a & ; jc i f; jy Ka o mt c g
ReadFile
WriteFile
CreateFile
INI z dki fr St c su ft v u fr sm; z w fjc i f; jy Ka o mt c g
GetPrivateProfileString
GetPrivateProfileInt
WritePrivateProfileString
t jc m; a e & mr St c su ft v u fr sm; u dkz w fjc i f; jy Ka o mt c g
LoadString
lstrcmp
MultiByteToWideChar
WideCharToMultiByte
wsprintf
t c sde f?& u fp GJw dkUE Si fhy w fo u fo n fht c g
GetFileTime
GetLocalTime
GetSystemTime
GetSystemTimeAsFileTime
SetTimer
SystemTimeToFileTime
NAG-window u dk& Smv dko n fht c g
CreateWindowEx
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 164 -

ShowWindow
UpdateWindow
MessageBox r Sp mo m; r sm; u dk& Smv dka o mt c g
SendDlgItemMessage
SendMessage
SetDlgItemText
SetWindowText
Registration e JUy w fo u fw Jhroutine a w Gu dkp p fa q ; w Jht c gr Sma w mha t mu fy g API r sm; u dkt " du x m;
& Sma z Gz dkUv dky gw , f -
GetdlgItemText
GetWindowText
lstrcmp
GetPrivateProfileString
GetPrivateProfileInt
RegQueryValueEx
WritePrivateProfileString
WritePrivateProfileInt
( 1 ) CreateProcess
CreateProcess u a w mhprocess t o p fw p fc ku dkz e fw D; w mjz p fy gw , f/ Process t o p fu o w fr Sw f
x m; w Jhexe z dki fu dkexecute v ky fw mjz p fy gw , f/
BOOL CreateProcess(
LPCTSTR lpApplicationName, // pointer to name of executable module
LPTSTR lpCommandLine, // pointer to command line string
LPSECURITY_ATTRIBUTES lpProcessAttributes, // pointer to process security attributes
LPSECURITY_ATTRIBUTES lpThreadAttributes, // pointer to thread security attributes
BOOL bInheritHandles, // handle inheritance flag
DWORD dwCreationFlags, // creation flags
LPVOID lpEnvironment, // pointer to new environment block
LPCTSTR lpCurrentDirectory, // pointer to current directory name
LPSTARTUPINFO lpStartupInfo, // pointer to STARTUPINFO
LPPROCESS_INFORMATION lpProcessInformation // pointer to PROCESS_INFORMATION
);
lpProcessInformation u a w mh process e JUo u fq dki fw Jh t c su ft v u fa w Gu dk x m; & Sd& m pointer
(Oy r m - 0x12F7C8) jz p fy gw , f/ lpCommandLine u a w mh execute v ky fr , fh command line & Sd& m
pointer (Oy r m - 0x12F758) jz p fy gw , f/
0012F7C8 = lpProcessInformation = "jexepackboot ER \"C:\\Program Files\\VisualRoute\\
VisualRoute.exe\"
0012F758 = lpCommandLine = "java -mx256m jexepackboot ER \"C:\\Program Files\\
VisualRoute\\VisualRoute.exe\" \"C:\\DOCUME~1\\MYOMYI~1\\LOCALS~1\\Temp\\
X2C123E0\" "
' De r le m API r Sm VisualRoute.exe u X2C123E0 z dk' ga t mu fu z dki fa w Gu dk execute v ky fjy D;
register v ky fx m; jc i f; & Sd^ r & Sdp p fw mjz p fy gw , f/
( 2 ) GetWindowText
GetWindowText u a w mh window & JU title bar w p fc kc ku p mo m; a w Gu dk buffer w p fc kx Ju l; x n fh
y gw , f/ w u , fv dkUo m window [ m control w p fc ko mjz p fc Jhr , fq dk& i f control & JU p mo m; a w Gu dku l; y gw , f/
Oy r mjy & & i f Textbox x Jr Sm o i f& dku fx n fhv dku fw Jhp mo m; a w Gu dkbuffer x Ju l; r Smjz p fy gw , f/
int GetWindowText(
HWND hWnd, // handle of window or control with text
LPTSTR Buffer, // address of buffer for text
int Count // maximum number of characters to copy
);
hWnd u a w mhwindow ( o dkU) control r Sm p mo m; a w Gy g^ r y g p p fy gw , f/ Buffer u a w mhp mo m; a w G
x m; r , fha e & mu dkn Te fjy y gw , f/ Count u a w mht r sm; q Hk; u l; E dki fw Jhp mv Hk; t a & t w Gu fjz p fy gw , f/
( 3 ) GetdlgItemText
GetdlgItemText u a w mh dialog box w p fc kx Jr Sm& Sdw Jh e JUy w fo u fw Jh p mo m; ( o dkU) title u dk z w fy g
w , f/
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 165 -

UINT GetDlgItemText(
HWND hDlg, // handle of dialog box
int ControlID, // identifier of control
LPTSTR Buffer, // address of buffer for text
int Count // maximum size of string
);
y Hk( 1 ) u e r le m dialog box w p fc ku dkMu n fhy gr , f/

y Hk( 1 )
y Hk( 1 ) u textbox a e & mr Sm password t jz p f "Myo Myint Htike" v dkU& dku fc Jhy gw , f/ Password
u dk& dku fx n fhjy D; & i f GetdlgItemText r Sm breakpoint o w fr Sw fv dku fy g/ jy D; & i f OK u dkE Sdy fv dku fy g/ y Hk( 2 ) /

y Hk( 2 )
y Hk( 2 ) u dkMu n fhy g/ Password textbox u t r sm; q Hk; z w fE dki fw Jh p mv Hk; t a & t w Gu f[ m 1 7 v Hk; y J & Sdy gw , f/
' gu dkResource Hacker a q mhz f0 Jv fe JUMu n fh& i f a t mu fy gt w dki f; a w GU& r Smjz p fy gw , f/
DLG_REGIS DIALOG 20, 20, 142, 81
STYLE DS_MODALFRAME | WS_VISIBLE | WS_CAPTION | WS_SYSMENU
CAPTION "Enter Password"
LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
FONT 10, "Book Antiqua"
{
CONTROL "Textbox", 1000, EDIT, ES_LEFT | ES_AUTOHSCROLL | WS_CHILD | WS_VISIBLE |
WS_BORDER | WS_TABSTOP, 45, 22, 66, 11
CONTROL "OK", 1002, BUTTON, BS_PUSHBUTTON | WS_CHILD | WS_VISIBLE | WS_TABSTOP,
18, 55, 42, 15
CONTROL "Cancel", 1003, BUTTON, BS_PUSHBUTTON | WS_CHILD | WS_VISIBLE |
WS_TABSTOP, 80, 55, 42, 15
CONTROL "Password:", -1, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 7, 23, 34,
10
}
y Hk( 3 )
y Hk( 2 ) r Sma w GU& w Jh ControlID & JUw e fz dk; 3E8h (1000d) u a w mh y Hk( 3 ) r Smjr i f& w Jht w dki f; Textbox
control u dkq dkv dkjc i f; jz p fy gw , f/ ' ga Mu mi fh o i fht a e e JU Password dialog box u dk& Smz dkU GetWindowText
r Sm breakpoint r o w fr Sw fc si f& i f PUSH 3E8h e JU& Smv dkU& y gw , f/
Buffer u a w mh o i f& dku fx n hfv dku fw Jh p mo m; u dk o Gm; x m; r , fh dump window u virtual address
a e & my g/
GetdlgItemText [ m WM_GETTEXT message u dk control q Dy dkUy gw , f/ SetdlgItemText
u a w mhGetdlgItemText e JU q e fUu si fz u fjz p fy gw , f/
( 4 ) GetDlgItem
GetDlgItem u a w mhdialog box w p fc kr Sm& Sdw Jhcontrol w p fc k& JU pointer u dkz w fy gw , f/
The GetDlgItem function retrieves the handle of a control in the specified dialog box.
HWND GetDlgItem(
HWND hDlg, // handle of dialog box
int ControlID // identifier of control
);
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 166 -

( 5 ) lstrcmp
lstrcmp u a w mhstring E Sp fc ku dk E dIi f; , SOfy gw , f/ w u , fv dkU string E Sp fc k[ m n Dc Jh& i f v ky fa q mi fc su f
a t mi fjr i fa p r Smjz p fy gw , f/
int lstrcmp(
LPCTSTR lpString1, // address of first string
LPCTSTR lpString2 // address of second string
);
string E Sp fc ku dk E dIi f; , SOf& mr Sm p mv Hk; t Mu D; ^ t a o ; u GJjy m; r I& Sdy gw , f/ y Hk( 4 ) / API a w Ga e mu fr Sm A
y gc Jh& i f ' D API [ m ANSI p mv Hk; a w Ge JUo u fq dki fjy D; W y gc Jh& i fa w mh UNICODE p mv Hk; a w Ge JU o u fq dki fy g
w , f/

y Hk( 4 )
( 6 ) GetPrivateProfileString
GetPrivateProfileString u a w mh initialization (*.ini) z dki fw p fc kx Jr Sm& Sdw Jh section u a e string
w p fc ku dk z w fy gw , f/ Win32 u dkt a jc c Hw Jhapplication a w G[ m registry x Jr Sm initialization e JYy w fo u fw Jh
t c su ft v u fa w Gu dko dr f; q n f; a v h& Sdy gw , f/
DWORD GetPrivateProfileString(
LPCTSTR lpAppName, // points to section name
LPCTSTR lpKeyName, // points to key name
LPCTSTR lpDefault, // points to default string
LPTSTR lpReturnedString, // points to destination buffer
DWORD nSize, // size of destination buffer
LPCTSTR lpFileName // points to initialization filename
);
GetPrivateProfileString [ m key w p fc kt w Gu f initialization z dki fu dk& Sma z Gw mjz p fy gw , f/ ' Dkey
[ m section heading u dko w fr Sw fw Jh lpAppName a t mu fu lpKeyName jz p fy gw , f/ w u , fv dkU key
u dka w GUc Jhr , fq dk& i f? function [ m o u fq dki f& m string u dk buffer q Du l; r Smjz p fy gw , f/ w u , fv dkU key
r & Sdc Jhb l; q dk& i fa w mhfunction [ m lpDefault u o w fr Sw fv dku fw Jhp mv Hk; u dku l; r Smy g/
Initialization z dki fw p fc kx Ju section [ m a t mu fy gy Hkp H& Sdy gw , f. . .
[section]
key = string
.
.
w u , fv dkU lpAppName r Sm A v mjz p fa e & i fa w mh GetPrivateProfileString u z dki fx Jr Sm& Sdw Jh
section t r n fa w Gt m; v Hk; u dk buffer x Ju l; y gw , f/ w u , fv dkU lpKeyName r Sm A v mjz p fa e & i fa w mh
function u section x Jr Sm& Sdw Jhkey t r n fa w Gt m; v Hk; u dkbuffer x Ju l; y gw , f/
WIN.ini z dki fx Ju string w p fc ku dk & , lv dk& i fa w mh GetProfileString u dkt o Hk; jy Ky gw , f/ w u , f
a w mh GetPrivateProfileString [ m *.ini z dki fa w Gq Du string a w Gu dkz w fr , fht p m; registry x Ju
t c su ft v u fa w Gu dkz w fw mjz p fy gw , f/
Oy r mjy & & i f
( 1 ) Registry x Jr Sm ini z dki f& JUt r n fu dkMu n fhy g/ ( Oy r m - myfile.ini )
HKEY_LOCAL_MACHINE\Software\Microsoft\
Windows NT\CurrentVersion\IniFileMapping\myfile.ini
( 2 ) lpappName u o w fr Sw fv dku fw Jh section t r n fu dk& Smy g/ ' Dt r n fu a w mh myfile.ini z dki fa t mu f ( o dkU)
myfile.ini z dki f& JU subkey w p fc ka t mu fr Sm& SdE dki fy gw , f/ ( o dkU) r & SdE dki fy gb l; /
( 3 ) lpappName u o w fr Sw fv dku fw Jh section t r n f[ m myfile.ini z dki fa t mu fr Sm w e fz dk; w p fc k& Sdc Jh& i f?
o i fht a e e JU registry x Jr Smo w fr Sw fx m; w Jhw e fz dk; a w Gu a e section t w Gu f key a w Gu dk& Sm& r Smy g/
( 4 ) w u , fv dkUo m lpappName u o w fr Sw fv dku fw Jh section t r n f[ m myfile.ini z dki f& JU subkey
w p fc kjz p fc Jhr , fq dk& i fa w mh' Dsubkey a t mu fr Sm section t w Gu f key a w Gu dk& Sm& r Smy g/
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 167 -

( 5 ) w u , fv dkU lpappName u o w fr Sw fv dku fw Jh section t r n f r & Sdc Jhb l; q dk& i f myfile.ini a t mu fr Sma w mh
t r n fr Jhw e fz dk; w p fc ka w mh & Sdy gv dr fhr , f/ ' Dw e fz dk; [ m section t w Gu f o i f& Sma e w Jh key & JUa e & m& Sdw Jh registry
x Ju default a e & mw p fc ku dko w fr Sw fy gw , f/
( 6 ) w u , fv dkU myfile.ini z dki ft w Gu f subkey v kH; 0 r & Sdc Jhb l; q dk& i f? section t r n ft w Gu f entry v Hk; 0
r & Sdb l; q dk& i f disk a y : r Sm& Sdw Jh w u , fh myfile.ini z dki fu dk& Smjy D; o lUr Smy gw Jh t c su ft v u fa w Gu dk z w f& r Smjz p fy g
w , f/
Registry x Ju w e fz dk; a w Gu dk Mu n fhw Jht c g a w GU& r , hf prefix a w G& JU t " dy m, fu a w mha t mu fy gt w dki f;
jz p fy gw , f/
! - ' Dp mv Hk; u a w mht c su ft v u fa w Gu dkregistry r Sma & m disk a y : u myfile.ini z dki fa y : r Sm a & ; r Smjz p fy gw , f/
# - ' Dp mv Hk; u a w mhWindows 3.1 .ini z dki fe JU t " du o u fq dki fy gw , f/
@ - ' Dp mv Hk; u a w mhregistry x Jr Sm v dkc si fw Jha ' w mr a w GUc Jh& i f disk a y : u .ini z dki fq Du a e a ' w ma w G
z w fw mu dkw m; q D; w my g/
USR: - o lu a w mhHKEY_CURRENT_USER u kdq dkv dkw my g/
SYS: - o lu a w mhHKEY_LOCAL_MACHINE\SOFTWARE u kdq dkv dkw my g/
( 7 ) GetPrivateProfileInt
GetPrivateProfileInt u a w mh initialization (*.ini) z dki fw p fc kx Jr Sm& Sdw Jh section u a e u de f; jy n fh
w p fc ku dkz w fy gw , f/
UINT GetPrivateProfileInt(
LPCTSTR lpAppName, // address of section name
LPCTSTR lpKeyName, // address of key name
INT nDefault, // return value if key name is not found
LPCTSTR lpFileName // address of initialization filename
);
( 8 ) RegQueryValueEx
RegQueryValueEx u a w mh registry key w p fc k& JU t r sdK; t p m; e JU w e fz dk; w dkUu dkz w fjy D; register
v ky fx m; jc i f; & Sd^ r & Sdp p fa q ; y gw , f/
LONG RegQueryValueEx(
HKEY hKey, // handle of key to query
LPTSTR lpValueName, // address of name of value to query
LPDWORD lpReserved, // reserved
LPDWORD lpType, // address of buffer for value type
LPBYTE lpData, // address of data buffer
LPDWORD lpcbData // address of data buffer size
);
( 9 ) WritePrivateProfileString
GetPrivateProfileString u a w mhWritePrivateProfileString e JUq e fUu si fb u fjz p fy gw , f/
BOOL WritePrivateProfileString(
LPCTSTR lpAppName, // pointer to section name
LPCTSTR lpKeyName, // pointer to key name
LPCTSTR lpString, // pointer to string to add
LPCTSTR lpFileName // pointer to initialization filename
);
e r le my & dk* & r fu dkcompiler r Sm run Mu n fhv dku f& i f & Si f; o Gm; r Smy g/
#include "stdafx.h" // Compiler - Visual C++ 8.0, Win32 Console Application
#include <windows.h>
#include <tchar.h>
#include <stdio.h>
int main()
{
TCHAR inBuf[80];
HKEY hKey1, hKey2;
DWORD dwDisposition;
LONG lRetCode;
TCHAR szData[] = TEXT("USR:App Name\\Section1");
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 168 -

// Create the .ini file key.
lRetCode = RegCreateKeyEx ( HKEY_LOCAL_MACHINE,
TEXT("SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\IniFileMapping\\appname.ini"),
0, NULL, REG_OPTION_NON_VOLATILE,
KEY_WRITE, NULL, &hKey1, &dwDisposition);
if (lRetCode != ERROR_SUCCESS)
{
printf ("Error in creating appname.ini key (%d).\n", lRetCode);
return (0) ;
}

// Set a section value
lRetCode = RegSetValueEx ( hKey1, TEXT("Section1"), 0,
REG_SZ, (BYTE *)szData, sizeof(szData));
if (lRetCode != ERROR_SUCCESS)
{
printf ("Error in setting Section1 value\n");
// Close the key
lRetCode = RegCloseKey( hKey1 );
if( lRetCode != ERROR_SUCCESS )
{
printf("Error in RegCloseKey (%d).\n", lRetCode);
return (0) ;
}
}
// Create an App Name key
lRetCode = RegCreateKeyEx ( HKEY_CURRENT_USER, TEXT("App Name"),
0, NULL, REG_OPTION_NON_VOLATILE,
KEY_WRITE, NULL, &hKey2, &dwDisposition);
if (lRetCode != ERROR_SUCCESS)
{
printf ("Error in creating App Name key (%d).\n", lRetCode);
// Close the key
lRetCode = RegCloseKey( hKey2 );
if( lRetCode != ERROR_SUCCESS )
{
printf("Error in RegCloseKey (%d).\n", lRetCode);
return (0) ;
}
}

// Force the system to read the mapping into shared memory
// so that future invocations of the application will see it
// without the user having to reboot the system
WritePrivateProfileStringW( NULL, NULL, NULL, L"appname.ini" );
// Write some added values
WritePrivateProfileString (TEXT("Section1"), TEXT("FirstKey"),
TEXT("It all worked out OK."), TEXT("appname.ini"));
WritePrivateProfileString (TEXT("Section1"), TEXT("SecondKey"),
TEXT("By golly, it works!"), TEXT("appname.ini"));
WritePrivateProfileString (TEXT("Section1"), TEXT("ThirdKey"),
TEXT("Another test..."), TEXT("appname.ini"));

// Test
GetPrivateProfileString (TEXT("Section1"), TEXT("FirstKey"), TEXT("Error: GPPS failed"),
inBuf, 80, TEXT("appname.ini"));
_tprintf (TEXT("Key: %s\n"), inBuf);
// Close the keys
lRetCode = RegCloseKey( hKey1 );
if( lRetCode != ERROR_SUCCESS )
{
printf("Error in RegCloseKey (%d).\n", lRetCode);
return(0);
}
lRetCode = RegCloseKey( hKey2 );
if( lRetCode != ERROR_SUCCESS )
{
printf("Error in RegCloseKey (%d).\n", lRetCode);
return(0);
}
return(1);
}
y & dk* & r f& JU t v ky fv ky fy Hku a w mh' Dv dky g . . .
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 169 -

( 1 ) HKEY_LOCAL_MACHINE r Sm appname.ini q dkw Jhkey u dkz e fw D; y gw , f/
( 2 ) RegSetValueEx() o Hk; jy D; Section1 & JUw e fz dk; u dk"USR:App Name\Section1" v dkUo w fr Sw fy gw , f/
( 3 ) HKEY_CURRENT_USER r Sm "App Name" q dkw Jhkey u dkz e fw D; y gw , f/
( 4 ) WritePrivateProfileString u dko Hk; jy D; HKEY_LOCAL_MACHINE a t mu fu appname.ini
z dki f& Sd^ r & Sdz w fy gw , f/
( 5 ) appname.ini z dki fu dk a w GUw Jht c g Section1 key u dkz w fy gw , f/ Section1 [ m HKEY_CURRENT_
USER a t mu fu App Name\Section1 u dkn Te f; w Jht w Gu f registry editor u HKCU a t mu fr Sm App
Name\Section1 subkey u dk t v dkt a v smu fz e fw D; y gw , f/ ' Dv dk z e fw D; jy D; w Jha e mu fr Sma w mh FirstKey u dk
z e fw D; jy D; "It all worked out OK." u dka & ; y gw , f/
( 6 ) appname.ini z dki fu dk a w GUw Jht c g Section1 key u dkz w fy gw , f/ Section1 [ m HKEY_CURRENT_
USER a t mu fu App Name\Section1 u dkn Te f; w Jht w Gu f registry editor u HKCU a t mu fr Sm App
Name\Section1 subkey u dk t v dkt a v smu fz e fw D; y gw , f/ ' Dv dk z e fw D; jy D; w Jha e mu fr Sma w mh SecondKey u dk
z e fw D; jy D; "By golly, it works!" u dka & ; y gw , f/
( 7 ) appname.ini z dki fu dk a w GUw Jht c g Section1 key u dkz w fy gw , f/ Section1 [ m HKEY_CURRENT_
USER a t mu fu App Name\Section1 u dkn Te f; w Jht w Gu f registry editor u HKCU a t mu fr Sm App
Name\Section1 subkey u dk t v dkt a v smu fz e fw D; y gw , f/ ' Dv dk z e fw D; jy D; w Jha e mu fr Sma w mh ThirdKey u dk
z e fw D; jy D; "Another test..." u dka & ; y gw , f/
( 8 ) a e mu fw p fc ku a w mh GetPrivateProfileString u dko Hk; jy D; HKLM a t mu fu Section1 n Te f; w Jha e & mu dk
o Gm; jy D; FirstKey u dk& Smy gw , f/ w u , fv dkU r a w GUc Jh& i fa w mh buffer x Jr Sm GetPrivateProfileString u
t v dkt a v smu f o w fr Sw fv dku fw Jh "Error: GPPS failed" p mo m; u dkjy r Smjz p fy gw , f/ FirstKey u dka w GUc Jh& i f
a w mhFirstKey r Smo dr f; x m; w Jh"It all worked out OK." p mo m; u dkjy r Smjz p fy gw , f/
r Sw f& e f/ / w u , fv dkU "USR:App Name\Section1"a e & mr Sm "!USR:App Name\Section1" v dkU jy i fv dku f
& i fa w mh C:\Windows a t mu fr Sm appname.ini z dki fu dkz e fw D; jy D; HKCU a t mu fr Sma & ; r , fhp mo m; a w Gu dk
appname.ini r Smv Ja & ; r Smjz p fy gw , f/ y Hk( 5 ) / ' gr sdK; u dka w mh z dki fw p fc k& JU registration setting a w Gu dk v lr o d?
o lr o da & ; v dkw Jht c g t o Hk; r sm; y gw , f/

y Hk( 5 )
( 1 0 ) CreateWindowEx
CreateWindowEx u a w mh overlapped ( o dkU) pop-up ( o dkU) child window a w Gr Sm p w dki fa w G
x y fa v mi f; x n fhjy D; z e fw D; a y ; w mjz p fy gw , f/ ' Dv dkr Sr [ kw f& i fa w mhCreateWindow e JUw la e r Sm jz p fy gw , f/
HWND CreateWindowEx(
DWORD ExtStyle, // extended window style
LPCTSTR ClassName, // pointer to registered class name
LPCTSTR WindowName, // pointer to window name
DWORD WindowStyle, // window style
int x, // horizontal position of window
int y, // vertical position of window
int Width, // window width
int Height, // window height
HWND hWndParent, // handle to parent or owner window
HMENU hMenu, // handle to menu, or child-window identifier
HINSTANCE hInstance, // handle to application instance
LPVOID lParam // pointer to window-creation data
);
CreateWindowEx e JUt w l ShowWindow? UpdateWindow API a w Gw GJo Hk; y gw , f/
( 1 1 ) CreateFile
CreateFile u a w mhz dki fw p fc ku dk& Sma z G? z e fw D; & mr Sm t o Hk; jy Ky gw , f/
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 170 -

HANDLE CreateFile(
LPCTSTR FileName, // pointer to name of the file
DWORD DesiredAccess, // access (read-write) mode
DWORD Mode, // share mode
LPSECURITY_ATTRIBUTES pSecurity, // pointer to security attributes
DWORD dwCreationDistribution, // how to create
DWORD Attributes, // file attributes
HANDLE hTemplateFile // handle to file with attributes to copy
);
CreateFile r Sm o w djy Ko i fhw mu a w mhMode parameter u dky g/ Mode [ m z dki fw p fc k& Sdc Jh& i f ( o dkU)
r & Sdc Jh& i f b , fv dkv ky fa q mi f& r v Jq dkw m q Hk; jz w fy gw , f/ y Hk( 6 ) /

y Hk( 6 )
Mode & JUw e fz dk; a w Gu a w mha t mu fy g 5 c kx Ju w p fc kc kjz p fE dki fy gw , f . . . -
CREATE_NEW - z dki ft o p fw p fc ku dk z e fw D; y gw , f/ w u , fv dkU z dki f[ m & Sda e c Jh& i f function [ m fail
jz p fo Gm; r Smy g/ Fail jz p fo Gm; & i f EAX & JUw e fz dk; [ m FFFFFFFF (-1) jz p fo Gm; y gr , f/ w u , fv dkU ' Dw e fz dk; u dk
jy i fc si f& i f Mode a e & mr Sm PUSH 1; v dkUjy i fv dku f& Hky g/
CREATE_ALWAYS - z dki ft o p fw p fc ku dk z e fw D; y gw , f/ w u , fv dkU z dki f[ m & Sda e c Jh& i f & Sdjy D; o m; z dki fu dk
overwrite v ky fjy D; z dki ft o p fw p fc ku dkz e fw D; r Smjz p fy gw , f/
OPEN_EXISTING - & Sdjy D; o m; z dki fu dk z Gi fhy gw , f/ z dki fr & Sdc Jh& i fa w mh function & JUv ky fa q mi fc su f a t mi fjr i fr Sm
r [ kw fy gb l; / ' gq dkEAX & JUw e fz dk; [ m FFFFFFFF (-1) jz p fo Gm; y gr , f/
OPEN_ALWAYS - z dki f& Sdc Jh& i f z dki fu dkz Gi fhy gw , f/ z dki fr & Sdc Jh& i fa w mh CREATE_NEW u dko Hk; jy D; z dki ft o p f
w p fc ku dkz e fw D; y gw , f/
TRUNCATE_EXISTING - z dki fu dk z Gi fhv dku fjy D; z dki fx Jr Sm& Sdw Jh t & mt m; v Hk; u dk z su fy p fy gw , f/ z dki fr & Sdc Jh& i f
a w mhEAX & JUw e fz dk; [ m FFFFFFFF (-1) jz p fy gr , f/
( 1 2 ) DialogBoxParamA
DialogBoxParamA u a w mh modal dialog box w p fc ku dk z e fw D; & mr Sm t o Hk; jy Ky gw , f/ Dialog
box u dkr jy c i fr Sm function [ m dialog box e JUo u fq dki fw Jhprocedure u dkinitialize v ky fy gw , f/
int DialogBoxParamA(
HINSTANCE hInst, // handle to application instance
LPCTSTR pTemplate, // identifies dialog box template
HWND hOwner, // handle to owner window
DLGPROC DlgPro, // pointer to dialog box procedure
LPARAM lParam // initialization value
);

KeygenMe w p fc k& JU dialog box w p fc ku dk Resource Hacker e JUMu n fh& i f a t mu fy gt w dki f; a w GU& y g
w , f/
1 DIALOGEX 0, 0, 225, 142
STYLE DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_VISIBLE |
WS_CAPTION | WS_SYSMENU
EXSTYLE WS_EX_STATICEDGE
CAPTION " :: Ziggy's KeyGenMe #0 ::"
LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US
FONT 7, "MS SANS SERIF"
{
CONTROL 10, -1, STATIC, SS_BITMAP | SS_REALSIZEIMAGE | SS_SUNKEN | WS_CHILD |
WS_VISIBLE, 65535, 104, 200, 200
CONTROL "Name", 1002, EDIT, ES_CENTER | WS_CHILD | WS_VISIBLE | WS_TABSTOP, 35, 30, 186, 10 ,
0x00020000
CONTROL "Serial", 1003, EDIT, ES_CENTER | WS_CHILD | WS_VISIBLE | WS_TABSTOP, 35, 47, 186, 10 ,
0x00020000
CONTROL "Register", 1005, BUTTON, BS_PUSHBUTTON | BS_CENTER | BS_VCENTER | WS_CHILD |
WS_VISIBLE | WS_TABSTOP, 59, 62, 50, 12 , 0x00020000
CONTROL "About", 1007, BUTTON, BS_PUSHBUTTON | BS_CENTER | BS_VCENTER | WS_CHILD |
WS_VISIBLE | WS_TABSTOP, 158, 62, 30, 12 , 0x00020000
t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 171 -

CONTROL "Close", 1004, BUTTON, BS_PUSHBUTTON | BS_CENTER | BS_VCENTER | WS_CHILD |
WS_VISIBLE | WS_TABSTOP, 191, 62, 30, 12 , 0x00020000
CONTROL "Appname", 1001, STATIC, SS_CENTER | SS_SUNKEN | WS_CHILD | WS_VISIBLE |
WS_GROUP, 35, 5, 186, 10 , 0x00020000
CONTROL " ", 1009, STATIC, SS_CENTER | WS_CHILD | WS_VISIBLE | WS_GROUP, 35, 19, 186, 10
CONTROL "Name", 4, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 6, 30, 26, 10
CONTROL "Serial", 5, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 6, 47, 26, 10
CONTROL 3, 1, STATIC, SS_ICON | WS_CHILD | WS_VISIBLE, 6, 4, 35, 35
CONTROL "Registered to : ", 5, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 6, 80, 50, 10
CONTROL " ", 1008, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 54, 80, 150, 10
CONTROL " ", 1010, STATIC, SS_LEFT | WS_CHILD | WS_VISIBLE | WS_GROUP, 54, 90, 180, 10
}
' gu dkOlly r SmMu n fhr , fq dk& i fa w mhy Hk( 7 ) t w dki f; jr i f& y gw , f/

y Hk( 7 )
y Hk( 7 ) r Sm DlgProc u a w mh t a & ; Mu D; q Hk; jz p fy gw , f/ b ma Mu mi fhv Jq dka w mh dialog e JUy w fo u fw Jh
procedure & Sd& m virtual address (00401032) jz p fv dkUy g/ pTemplate u a w mh dialog t r n fjz p fy gw , f/
y Hkr Se fq dk& i fa w mh API w p fc ku dk v ky fa q mi fjy D; w me JU a e mu f API u dkv ky fa q mi fr Smy g/ y Hk( 7 ) r Sma w mh 00401041
u dkv ky fa q mi fjy D; c sde fr Sm 00401046 q Da & mu fr v mb J0040104D q Da & mu fv mr Smjz p fy gw , f/
( 1 3 ) ShowWindow
ShowWindow u a w mho w fr Sw fx m; w Jhwindow u dkjy o z dkUjz p fy gw , f/
BOOL ShowWindow(
HWND hWnd, // handle of window
int nCmdShow // show state of window
);
( 1 4 ) MessageBox
MessageBox u dka w mh cracking v ky f& mr Sm r Mu mc P jr i f& r Smjz p fy gw , f/ MessageBox u
message box w p fc ku dk z e fw D; jy o r Smjz p fy gw , f/ Message box w p fc kr Sm Mu dKw i fo w fr Sw fx m; w Jh icon a w G?
button a w G? p mo m; a w Ge JU a c gi f; p Ofa w Gy g0 i fr Smjz p fy gw , f/
int MessageBoxA(
HWND hOwner // handle of owner window
LPCTSTR Text, // address of text in message box
LPCTSTR Title, // address of title of message box
UINT Style // style of message box
);
MessageBox & JU t v ky fv ky fy Hku dke m; v n fa p E dki fz dkU y Hk( 8 ) u dkMu n fhy g/

y Hk( 8 )
Style q dkw mu a w mh message box r Sm a z mfjy c si fw Jh button a w G? icon a w Gu dk q dkv dkw my g/ y Hk( 8 ) u
Oy r mt & q dk& i fa w mh message box r Sm OK button w p fc kw n f; y gr Smy g/ b m icon r Sr y gy gb l; / ( Message
Box t a Mu mi f; t a o ; p dw fu dk]t a jc c HAssembly b mo mp u m; } t c e f; r Sm t u s, fa q G; a E G; jy D; jz p fy gw , f/ )
' Da e & mr Sm o w dx m; a p v dkw mu a w mh hOwner y g/ w u , fv dkU message box w p fc ku dk z e fw D; c sde fr Sm
dialog box w p fc k[ m & Sda e c Jh& i f hOwner u dk dialog box & JU handle t a e e JU t o Hk; jy K& y gw , f/ w u , fv dkU
hOwner a e & mr Sm 1 jz p fa e & i fa w mh' Dmessage box u dkjy o E dki fr Sm r [ kw fy gb l; /

t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 172 -

( 1 5 ) SendMessage
SendMessage u a w mh message w p fc ku dk window w p fc kq D( o dkU) window a w Gq Da y ; y dkUy gw , f/
Function [ m o w fr Sw fx m; w Jhwindow t w Gu f window procedure u dka c : o Hk; jy D; window procedure u
message u dkv ky fa q mi fjy D; c sde fr Sm return jy e fjc i f; r & Sdy gb l; / PostMessage u a w mhthread w p fc k& JU message
queue q Dmessage c sx m; jy D; c su fc si f; jy e fy gw , f/
LRESULT SendMessage(
HWND hWnd, // handle of destination window
UINT Msg, // message to send
WPARAM wParam, // first message parameter
LPARAM lParam // second message parameter
);
( 1 6 ) SendDlgItemMessage
SendDlgItemMessage u a w mh dialog box w p fc kx Jr Sm& Sdw Jh control q Dmessage w p fc ku dk a y ; y dkU
y gw , f/
LONG SendDlgItemMessage(
HWND hDlg, // handle of dialog box
int nIDDlgItem, // identifier of control
UINT Msg, // message to send
WPARAM wParam, // first message parameter
LPARAM lParam // second message parameter
);
( 1 7 ) ReadFile
ReadFile u a w mh z dki fw p fc ku a e v dkc si fw Jht c su ft v u fa w Gu dk z w fy gw , f/ p z w fr , hfa e & mu dka w mh
file pointer u n Te fjy y gw , f/
BOOL ReadFile(
HANDLE hFile, // handle of file to read
LPVOID Buffer, // address of buffer that receives data
DWORD BytesToRead, // number of bytes to read
LPDWORD pBytesRead, // address of number of bytes read
LPOVERLAPPED pOverlapped // address of structure for data
);
Buffer u a w mhz w fv dku fw Jhp mv Hk; u dkx m; r , fha e & my g/ pBytesRead u a w mhz w fv dku fw Jhp mv Hk; t a &
t w Gu fy g/ BytesToRead u a w mht r sm; q Hk; z w fr , hf p mv Hk; t a & t w Gu fjz p fy gw , f/ y Hk( 9 ) /

y Hk( 9 )

( 1 8 ) WriteFile
WriteFile u a w mhz dki fx Jr Sm x m; c si fw Jht c su ft v u fa w Go Gm; a & ; y gw , f/
BOOL WriteFile(
HANDLE hFile, // handle to file to write to
LPCVOID Buffer, // pointer to data to write to file
DWORD BytesToWrite, // number of bytes to write
LPDWORD pBytesWritten, // pointer to number of bytes written
LPOVERLAPPED pOverlapped // pointer to structure needed for overlapped I/O
);
( 1 9 ) GetSystemTime
GetSystemTime u a w mh v u f& Sd OS & JU & u fp GJe JUt c sde fu dk z w fy gw , f/ t c sde fu dka w mh UTC
(Coordinated Universal Time) e JUa z mfjy y gw , f/
VOID GetSystemTime(
LPSYSTEMTIME lpSystemTime // address of system time structure
);

t c e f; ( 1 2 ) - Cracker r sm; o w dx m; o i fha o m Windows API r sm;
- 173 -

( 2 0 ) GetFileTime
GetFileTime u a w mhz dki fu dkz e fw D; c Jhw Jh? a e mu fq Hk; jy Kjy i fc Jhw Jh& u fp GJe JUt c sde fu dkz w fy gw , f/
BOOL GetFileTime(
HANDLE hFile, // identifies the file
LPFILETIME lpCreationTime, // address of creation time
LPFILETIME lpLastAccessTime, // address of last access time
LPFILETIME lpLastWriteTime // address of last write time
);
( 2 1 ) SetTimer
SetTimer u a w mho w fr Sw fx m; w Jht c sde fw p fc ky gw Jhtimer w p fc ku dko w fr Sw fw mjz p fy gw , f/
UINT SetTimer(
HWND hWnd, // handle of window for timer messages
UINT TimerID, // timer identifier
UINT Timeout, // time-out value
TIMERPROC Timerproc // address of timer procedure
);
SetTimer e r le mw p fc ku dkOlly r SmMu n fh& i f a t mu fy gt w dki f; a w GU& r Smjz p fy gw , f/ y Hk( 9 ) /

y Hk( 9 )
hWnd u a w mh timer e JUw GJz u fx m; w Jh TPUtilWindow u dka jy mw my g/ ' Dwindow u dk a c : , lo Hk; w Jh
thread u o my dki fq dki fy gw , f/ w u , fv dkU hWnd o m NULL jz p fc Jh& i f timer u b , f window e JUr Sw GJz u f
r Smr [ kw fb JTimerID u dkv Jv sp fv sL& Ir Sm jz p fy gw , f/
TimerID u a w mho kn r [ kw fw Jhtimer identifier w e fz dk; w p fc ku dko w fr Sw fy gw , f/
Timeout u a w mh time-out jz p fr , fht c sde fjz p fjy D; r Dv Dp u e fUe JU jy y gw , f/ Timerproc u a w mh
timeout jz p fw Jht c g t c su fa y ; r , fh? v ky fa q mi fr , fhfunction & Sd& mu dkjy y gw , f/
KillTimer u a w mhTimerID u dkz su fq D; w JhAPI jz p fy gw , f/
., -. resource ... ..__ crack _ .


tcef;(13) - y&dk*&rf\ resource rsm; toHk;jyK crack vkyfjcif;
.. ..-. -. resource .-- ..__. crack _-_ . ._.. -. _ .-
-.._-. . ._. . .-. crack .. . . _. .. -. crack _-_. ...
..- -. -.-. Active Desktop Calendar Version 5.95 _.. -. Active Desktop Calendar
. -.-.-. . desktop .. ,-. _- .- .. _ .... .- - . -
.... ... . -. _.. -.

,
Active Desktop Calendar - www.xemico.com -. download _. install -

,
ADC - . - - . ..-. ,- . register . ...._-. . .- . . Help menu
- About Active Desktop Calendar- .._-_-.-. ,-. .-..

., -. resource ... ..__ crack _ .


,
.-.._ Help menu - Registration -.._. register _-__-.. ,

,
,- Register button -..-.-. ,-._...

,
..-..-. _ -.- patch _-_ _-.. Patch . . . ADC -. -
Resource Hacker .... _-_.. ,

,
Resource Hacker -.-. ,-. -.-.- .._- resource .- - _...
-. -.-... .rscr section -..-. _.- ....._..-. Resource Hacker
....-. -..- resource - _- - . . .- . _ ... -. ,

., -. resource ... ..__ crack _ .


,
. - ... .-.-. Resource Hacker ....-. resource .--.. _...-.
-.-.- register .._.... ..._. .-. ._-. -.-.-. Resource
Hacker - Olly Debugger -.... ,-- _ _-_ . - .- -. dialog .-_..
-. dialog .-._-.. Resource Hacker . . .... - _-_ - _-.. ,- dialog
.....- . - .,- . _. ..

.,
.,- 100 . - .....- ..._-_ . -. dialog .__..-. -.-. dialog
function -.... dialog ._- stack .-.--.

,
,- 207 .-.....-.-. ,- registration box -...- dialog _..-.

,
,- 208 .-.....-.-. ,- BadBoy MessageBox - ...- dialog
.-. ._ ADC -. - Olly .. ... ,

,
,-. _.-.. - -.-.-_-_- dialog ._.-- Olly .. ._-_-
_-.. Olly . . right-click ._. Search for - All commands - ..- ...
registration - dialog (2007d = 00CFh)- ._-_-_-.. ,
., -. resource ... ..__ crack _ .



,
,.. Find button -..- ,-. _...

,
,.._.- command -.- breakpoint .-.-.. Breakpoint .- . - _ . F9
-._. -.- run - _. Help menu - Registration -..- ,-. .-
..

,
,- -.-.-..-.- VA 0045EEC0 ..-.-. registration dialog . CALL
VA 0045EEA0 -.-. registration dialog . CALL . CALL - -. virtual
address -....-..-. . stack window .. ..._-_- ,

,
,. .-. VA 0045EEA0 -..._. VA 00434E86 .-_.....
._...-. - - .- - . .. right-click ._. Follow in Disassembler -..- ,
-. _...

,
--. .-. VA 0045EEA0 - CALL - VA 00434E81 - .....-. ..-.
.._ ..- _ -. ,- _ _-_- ,-...-. dialog ._- stack
..- .- _ -..- _.. . . -.. .. F9 -.- ,-. _...

,
., -. resource ... ..__ crack _ .
.

,-. _..-. register ....-. ,.._.- dialog (208d = D0h)
-.. -... ,-. PUSH 0D0h - _ _ . command -.- breakpoint
.- . - .. -. .-. . ._.._.. command -. .- -. .,

.,
., VA0045F0D3 ..- JE -. register -..._...._.- .._.-_.
... _. VA 0045F239 . ..- .. . ._-. BadBoy DialogBox ..-.
-- JE ... NOP _ - .-. . -.- - _ _ register -... _. _
, . - .-. - _ - - - .- - . . .- .. ._ . . .._ . -

,
_.......-. ,-. registry editor (regedit.exe) .._-_-

,
...--.- _._. Help menu - About Active Desktop Calendar -_-_-
.-. ,- . _.- .
,
._-. dialog (2007d = 0064h) . virtual address . . breakpoint .- . - _ . run
(F9) _-_ .. -. run ..-..-.. PUSH 64 . breakpoint -... ...
..-.. breakpoint -__.- About Dialog -...- PUSH 64 breakpoint .-.,
..- breakpoint .-_.-.-. -. menu .. Help menu - About ADC -
. . -. - .-. - ..- About Dialog breakpoint ...-._ ,
., -. resource ... ..__ crack _ .



,
,- VA 00401C60 -.-. routine . _.. -. . --.- .....-.
..-. stack window .. right-click ._. Follow in disassmeble -..- ,-.
_...

,
,.._..--. VA 00401C60 - VA 00401D48 - .. .-. F9 - . -
.-. ,- . .- .. -.._-. "This is an unlicensed copy" . - ......-. . -.
. .. About DialogBox (100d) - Resource Hacker __-_- ,

,
,- _-_- ... stack .-.-- -. (1044d = 414h) -. .-..
..- .-. . -._.. . . -. .- _-_ .. PUSH 414h - ._ . breakpoint .- . -
.. _ . Olly .. -.- _._. Help menu - About ADC - . . - _ . PUSH 414h
. breakpoint ...-.. F9 . . ..- . ..-. ,- . breakpoint .- ..- .
..

,
. .-
413 = DeskLook Verson x.y
414 = This is an unlicensed copy.
., -. resource ... ..__ crack _ .
.

415 = User
416 = Registration Code
417 = This is an unlicensed copy.
3FD = Buy &Online Now!

,
,- VA 00401DE2 -. ,- VA 00401EAC F8 . . - .-. - .
VA 00401EAC - JE .. NOP ._. . - _ . . . .- .._ . - . . . - . . . -
-.- ._. Help menu - About ADC - . . - ,- . .- ..

,
..- -. . -.-. splash screen ....- "unregistered" .-.....- ..-...
VA 004013E4 - JNZ ... . JMP _-_. .-...- .,

.,
., VA 004013DD - CALL -. register _..._....- routine . -. . .
.._ .. -. .-. ._ -. - _ . _-_ - ,- . .- ..

,
., -. resource ... ..__ crack _ .
.

- . . ._. Active Desktop Calendar - .._... register ...
-.-.-. .... -.-- _-.
, VA 004013E4 - JNZ ... . JMP (Splash Screen)
, VA 00401EAC - JE .. NOP (About Dialog)
, VA0045F0D3 ..- JE .. NOP (Registration Dialog)
_ .. . - .-. .-. - . Resource Hacker -.-_-._. .--
_ -. . - ... .-.-. Delphi .......- -..-- crack ....-.
Resource Hacker ....-..__. crack .-. .-.... Delphi -..-- -.
crack ..-.- ., Delphi _. .......... -....- crack _ .'..
.... - .. ... ... ,
., Packer (Protector) ...
.

tcef;(14) - Packer (Protector) rsm;
....-. cracking ..-. . .- .... ._.. - packer (protector) .-._-..-
.. ... .. ._.. -. . . ._. .-. pack -..-. exe .- compress _ . execute
.. decompress _ _ . execution .-_.-- ....... decompression stub
- _.......- .._..-. Compress -. . -.-.-. . -. - compress
- -._...-....-._.._. exe .-... compress ..- - .- - -
decompression - .- - . .. .. -._.. -. Execute ...-. . exe --
__. unpack -. - ..- ..- . -.-. . - compress .....- exe .
-.-- Compress ..- . - .- -.-.
, . .. - . ... . _ ._ .
, . .. . . - . . .-......_...- .._._.
, Execute ..- compress . ...... - .. .-...... dexompress ._
-- -_. -_..-.
Compress ..- exe ..-. exe .-.- archive -. . _ ...
WinRAR -.... ......_. archive .._ .. ., .- -.-.-. compress ..-
.-..- - . - - exe . _.. .-.
DOS Windows _.. OS .- - - exe compressor ...._. command line .
..._..-.. GUI version . ... _ ..-. . - -.
..-- pack - -. _..- -. - ..- -.-.
, . . - -.- . . - ..- . . download .-- _... download ...
_.
, . ... . - .. - . cracker .- crack .... -.-...._. Cracker
.--. crack . ... unpack .._..-., -_..-.
.-..-.-.-. anti-virus .- -.--. Anti-virus .-..-.......-. pack
..-.- virus ., trojan _. ._--. .._. McAfee anti-virus,
Protector .-.-.-. --.-..._. ..- packer -. Protector .- -.-.
..- packer .- - .. - .- - _...._..-. Protector .- .._-.-_.
-.-. protect ..-. .... Packer .-- pack ..- ..-.....--
.... .. . . . protector .--.-. cracker .---.-..... -.-- ..
_..._--. ._-.. protect ..- . .- .... .... ...,. . . -
_- ..-..- -. ... packer .- -.-. . . . ...- _ .. . ..-
.. . -.
..- .._- .- - -.-. -. ...- -. . - malicious -.- virus
worm,-..-.. protect ..-..-- ..__--. protect ..... anti-virus
.....-- -. ....... . . _.. -. ._-. . . protector .-._-..-
..._-... . ... ._.. _ . . - - -. unpack . . -. . ... ._.. -.
Protector .- packer .- - .- . ..- . - ... .-.-. entry point (EP)
.-. pack/protect ..- -.- Olly . - .. ..- - virtual address _.. _ .
OEP (original entry point) .-.-.-. decompression stub ... _ . . ..- - . entry
point -..-._..-. unpack/unprotect . ... . . - . .- entry point -.-.,
Protector/packer .--. -.- .-... unpack _--._.. -. . . -.
. command .-.... OEP .- jump -._.. _ . . -. - . . - .-. - .
-.- dump ..._..-. dump ..- .-_... ,-.-.
, - - ._. -. F8 -._._.,
, ESP register - .._-.
, Compressor --..- exception .- - . ._-.
., Packer (Protector) ...
.



.. ..-. - .-. - . . . - packer ...._. pack ..- ..-.
-.- _........._. unpack _-_.. ._.-.-. pack ..- exe .-
unpack _. patch - _ ._.. _ . - ._ .-.-. inline-patch - _ ._.. -. ... .
-.-.-.... tool -.-. UPX 2.03 (Ultimate Packer for eXecutables) _.._.
HTUhttp://upx.sourceforge.netUTH .. ..-.
UPX ... . -. exe . .- - . ....... .. - ... . .._ _-._. .
_.- protection _....-...._. .-. -.-..- UPX -.-. Marcus Laszlo
-....- UPX ... . - ._.-. .. . UPX pack _.. unpack _-_ ..
.-.... ._. -.-.-. _. ..... . .-. .-. ......- -. packer . protect (pack)
.._... pack ..- .....-..-....-. UPX pack .._--._..
-., UPX packed ..-- unpack .- tool .-..-.......- -.- . . . . ...
- .-. - - -.._-. - _ . - . - unpack . _- ...... . . . ..
.-. . . . .. -.- . . ._-. _...- -. unpacker tool .- - . .. _-_
unpacker .--. UPX packed ..-- --. unpack .-. . ... ... exe ..-..
_....--.-- ..- ..--.-- _..--_--.
, UPX _. pack _ .
.... pack . -.-.- . ._.. -. ..-.-. Windows . . --_ ..
- calculator (calc.exe) -. .._.. -. Windows System32 folder ..-.. .--
..-. Pack ... PEiD -.._. calc.exe - -.-.-....-.. ....-..-.
_-_.. ,
,
Start menu - Run .. .... cmd - _ _ . Command prompt - . -.._-.
command prompt - . ._. . .-. UPX ... . -. command-line utility _...

,
,.._.--. command prompt .. upx calc.exe -__. Enter key .-
-.-.- -...- UPX pack _...._ -... pack ..- calc.exe . -
PEiD __..._-_.. ,
., Packer (Protector) ...
.


,
,.-. calc.exe - UPX 0.89-2.9 pack ..-. ._.-. Version
---.-. ._.._. .-. --..-. ProtectionID 6.x -.._..
, Pack ......- _........
,-_-_- .rsrc section .. . . ._ .._. .- - . _ . - - section .- ..
. ._._..--. Pack . calc.exe - PEiD section viewer _-_..-.
.-. ,-._.-. Pack _....-. .text section .data section .rsrc section .-
... UPX0 UPX1 .rsrc section .- _.. .-. Section ._.-...._....._. .rsrc
section - -. ._ .._. . - - . -. - - . - .... .-. .-. _.. . -
Windows 95 .--.- oleaut32.dll . LoadTypeLibEx function .. bug -.
-. -.-. rsrc .-.....-._. resource section - ..._..-. ._-..
--. section -._._..... error --... bug - _ . .._ ._.. ...
Windows _..-- . .. . . - - - packer .-..-.......-. .rsrc section - ._ ._. .
_ . . . _-- .
., Packer (Protector) ...
.

,
- pack ..-.- LordPE ._. pack . .....- . ..._-_...
PE header -.._....-- , -. .-.. LordPE - compare button - . ,
,
, UPX _. pack ...... .. unpack _ .
-. . ..-. pack ..-.- unpack _-_.. Pack ..-.- Olly
...... ,-. Olly - compress ..-... ......

,
,.. Yes ..- .,-. entry point .- ..-....
., Packer (Protector) ...
.


.,
UPX - - .-. - application - compress -_. decompression algorithm -
stub -.-- ....--. Application entry point ..-. stub ...
. ._. . _ . _ . stub - .-_....-. execution - UPX - . -....
unpack _ ., unpacked - - -. - .- . . entry point(OEP) .- jump
-. . - ... - stub - - .-. - application - decompress -.-. .-..._.._.
pack ..- application unpacked copy -. .-...- ._.. dump -._..
-. -._.._.. application -.-. -. run .. .--...-. -.._-...-. dump
..- . . . . section .--. file alignment - . .- . - . page boundary .--
align ..... Entry point - decompression stub - point .- . .. ._.. _ .
import directory - ....-._..--- _.. .
.-....-.-. Olly - - .-. - entry point -. ... instruction _..-
PUSHAD . . -. PUSHAD . -.-.-. "PUSH all Double" - .-._.._. CPU - stack
...- EAX -.. _ . EDI .....-- 32bit (DOWRD) register .....-.
...- ........ __-..-. ..._-_... stub -. OEP . .. .. . .
PUSHAD instruction POPAD instruction _-..-- .- - ... . ..-. .- . ..
POPAD -. stack -. register ..-....- -.-. .-.-.-. stub - ...
.- _ restore _. application - run -..- trace . - - . ..-.
...... .-. .. . instruction _..- PUSHAD ......-... ..-..
POPAD instruction - access . ..... stack . . - ... .- . - ... -.
--. - .-. - - PUSHAD .... . .- . stack ... 4bytes ....
Hardware breakpoint - .... . Olly - -_- 4bytes - POPAD - access ..
. ... ._.. -. . - .-. - entry point .- ..-.. jmp instruction . virtual
address -.-.. _..-.
._-.. ., PUSHAD instruction .-..._. F7 - . .. _ . brakpoint
.- . - . .. ESP (stack pointer) .. stack .-_ .. _. . -. ESP
.... right-click ._. Follow in Dump - . .

,
_ . stack ... DWORD ....,- .. _. right-click ._. Breakpoint -
Hardware, on access Dword -.. ,
., Packer (Protector) ...
.

,
.- . - _ .. .. .-. F9 - . . breakpoint .- ...- ... ,
,
,- _-_- PUSHAD -. POPAD -.-- ..._.-. .-..
,- VA 01020E5B - JMP ..-. - .-. - ..- - entry point .._.. -.
JMP xxx.xxxxxxxx -..-.. VA 01020E5B ... . breakpoint .-.-_. F9 -.-
,-. entry point ...- ..- .. ._.. -. OEP -. ImageBase - . .
1000000h - .-- RVA - . . 20E5Bh -. - . .- . - .. ..- .. . . .
. . ..
,
UPX - .- - - -..-. -.-. Olly CPU window ..-..-...
,-. 00 .- __.- DB -.-- .-...
,
_. ,-. JMP instruction . .- scroll .. _. virtual
address - breakpoint ..-.-_. F9 - . - .. . JMP instruction .-
..- ... ..- . ..-. F8/F7 - .... -.-.- ..- EP ..- ..-...
,
., Packer (Protector) ...
..

INFO: : .._. -_- PUSHAD/POPAD mechanism -..- _.. packer .-- OEP
-..- RET instruction -- stack ...... PUSH instruction -..__._.
OEP . jump . -. CPU -.-. -. function call -.-. _.-._. return
address - stack ..... ..-.
- .-. - . OEP - ..- - Olly plug-in -._..- OllyDump - ..__.
dump _-_ .. Olly Plugins -. OllyDump -..-_. Dump debugged process -
. - ,- . _. ..
,
.-......-..-....-- _. ,- Fix Raw Size Rebuild Import
-- ...- _.-..- _. Dump button -._. packed_dumped.exe ._ .-
...- ,
,
,- - .-. - dump _ . . . ... - . - _ . _-_ ,- . error -- .
-. _. . .
,
-. error -- .-. . .-. - .-. - dump ..-.- . icon ..- .-.
--._-. -. ....._-.. Application - LordPE ..._. section .-
.... _-_- .,
.,
., Packer (Protector) ...
.

RawOffset RawSize --...--. ....-. ._-.. application -
... section .... Raw -...-- Virtual - . ..- - _ .... RawOffset ... .
VirtualAddress -..-__. RawSize .... VirtualSize -..-_.. _.
section ....__. .-...- .-- --. OllyDump "Fix Raw size &
Offset of Dump Image" checkbox - . . - .-. - _ .. . . .- - - ., .
,- . _. _
,
... . ._ ....-. .-.-.-. packed_dumped.exe . - . - - . . . -
. - ,- . _. -.

,
.... --.._-...-. import .-- reconstruct (rebuild) . PE
header' ...._. process -.-..__. import .-- -.- -. -.
_.._.. -.-_....-. import ..- function .-..._-._. import data .-
-. - . .. ..- _ .. ..- .. -_ _ . ..._- .- . ._.. -. - ..-._..
. . - .-. - . MackT ImpRec 1.6 - .._...
ImpRec 1.6 - .._.-.... import .--... pack ..-.- process
. attach .... ..--. ...
,-. pack ..- -.- packed.exe -. Olly . . .-......,. .
OEP ... . virtual address 12475 - -_

,
., Packer (Protector) ...


_. IAT AutoSearch - . . ,- . _. .. OK -.

,
,- Get Imports button - . ,- . _. ..

,
Show Invalid button - .._. import .- . .. .. _-_ .. .. - .-.
Fix Dump button - ._. -.-.- ..-.......- packed_dumped.exe .-.
,-. _... --. _.. .-. section - . ._ .- . error -- .
..

,
-.--_. ..-......_.-- packed_dumped_.exe - . _-_ .-. ..-. .
-.- .-..
ImpRec - - .-. - dump ..- exe . - _ . _ . . . .._ . - -. --.
.- PEiD ..._._-_- unpack .._.....packed_dumped_.exe, ....-.
pack . ..calc.exe,- _-..-..-_. "makct" "newIID".- section . .
.-..- -. "makct" section .. ImpRec - import ..- .-....-- ..-.
_.. -.

,
PEiD packed_dumped_.exe .- _.._-_ ,-. .-..
., Packer (Protector) ...



,
._-.-.-. ..- packer pack ..-.- unpack _ -._.. -.
._. packer .--.-. pack .. .- protection _ .. .. .. _ - -. . .
. ._. anti-debugging anti-tampering _ .... .- - IAT -- encrypt _.
stolen bytes API redirection ..__._..-. ..-...-.. .-- ..........
, Inline-patch _ ._. patch _ .
--. pack ..- .- patch . ._.. .. .. . inline-patch _...-
..__. .- unpack . - patch -. -.-. loader - decompression stub -
... - _ . . - . . . - - _ _ . ..- . .. ..-. application - .... OEP
. .- . ...._ ._.. -. ..- -. . .._. . - . . . application - unpack . ...
_..- patch, ..--. .-.....-_._.._. ..-.....-. OEP . _ _ .-.
....- .-. _.. -.
- ........ -.-.-. pack ..- calc.xe .-
MessageBox -. - .- - - .- - _ . ..._..-. _. .-... application -.
-... unpack _ ._.. . . -. . .. .. MessageBox - OK - . - OEP
- ..-...._.._. application -..-. .. _..-.
.. . . .-.-. pack ..-. _....-- - .. - - ... .
calc.exe - hexeditor -. ..._..-. , Section -. . .- .. - .- -.
-_... .-...._.._. --. .. - .- ... . .-. - .-. - .
PE. -.. -.....__.' .-_...-. section - -. UPX
pack ..- . .- . . .. - .-. .-. .-...--. ._-. UPX pack
..-..- ....-. .-. .-. .. . .-._.. -.

,
,-. WinHex . ._ _ . packed(inline).exe . - ._ . - . ..-.. _.
Olly . . packed(inline).exe .- ... -.-.- -- Unpacked .-.....- ..
Olly Hex window .. right-click ._. Search for - Binary sting -..

.,
., Packer (Protector) ...


_. ,-. Unpacked .-.....- .-.

,
. - .-. - ..- ......-- ,-. .-..

,
Unpacked ...... virtual address -.-. 010233C0 _.. _ . Myanmar Crackers
...... virtual address -.-. 010233D0 _.. -. virtual address .-- .-...._..
-. _ . Olly - -._. VA 010233C0 .- -...._-_.. ,

,
,- highlight ..- -.--. -.-.- - _ ..- ......- _.. -. VA
010233E0 -._ . MessageBoxA - .- - _..- .- - - _ _-..
,-.-. MessageBoxA - .- - - .- - - _ _ . _. -

,
_ . Olly plugin -._..- Analyze This! -._. -.-- analyze - ,
- . ._. . . ..-. _. ..
., Packer (Protector) ...



,
,- Analyze This! analyze -.. ,.. highlight _...--. ._.
.-. . patch -- -.-. error _...

,
.-. ._ - .-. - _ .. - - .- - . . . . .._ ._-.. ,-. _..
- -.-.. highlight _. - _ . right-click ._. Copy to executable file - ..-
,- . _. . ..

,
,.. right-click ._. Save file - ..- ...-_--._ .-...._.-
_ . Olly ---_. -.-.- ...._.-- .- .- --. -..
._... . - . -.._-...-. -.-.-. MessageBoxA .- __....-
Olly .. ..-.......-.- .- -._. VA 01020E5B .- -...._-_
.. ,

,
,- JMP 01012475 ... . - .-. - MessageBoxA . virtual address _.. -
010233E0 - -_.... ,

,
., Packer (Protector) ...


_ . _- - - ._ . - . . . - Olly - --_. .- run _-_ ,-.
_.... OK - . - .-. calculator -.. ..-..... _..-.
.,
- .-. ._ -.-.-. unpack . - pack ..-... -.-- __.
(inline-patching) ._-.._..-. MessageBox ..- _ . -.._-. ..- - .
. . . . .. . -. Pack . ..- . .- . . - . - . . . -. Message
Box ...- entry point address ._. ... - _ . . . .- .. - .- ..._- .
-. .-. MessageBox .._. textbox -. password .- .. - .... .. ..
- .- - . .-. Inline-patching _..- MessageBox .- -...-.. .
entrypoint - VA 01020CD0 ... VA 010233E0 ._.._-_- .,- MessageBox
.-. ... ... calculator -.- ...---. -.._-. UPX decom-
pression stub - .-. .... _.. -.
UPX - .- - . ...-.-. ..- . . unpacking -.-- .
.- _...._..-_ -. - .-. . unpacking - .- _ . . . ..
... ._. packer .-._-.. .._.... ActiveMARK ._-..- _._.-......
..
, ActiveMark 5.0 _. pack ........ unpack _.
Trymedia -. RealNetworks . - .-. _.. _ . ActiveMark .-.-.-. Trymedia
pack/protect - _ ._.-. _.. -. Trygames -.-. Trymedia -. . - -. ._.. _ .
Trymedia - . ..- - download ...-. trial . .- . .. ._ .- . - - ...
-.
PopCap Games (HTUwww.popcap.comUTH) - ...--..... Infogrames (HTUwww.infogrames.
comUTH) - .. .- - . ..-. .-. ......-. ActiveMARK protect .._--._.. -. Active
MARK protect ..- -...-.. registration .-. -.._-...-. -...--. .-
.-.-..--... full version . -....- demo - . ..- _.. . .- . - -
. .. .-. -... .-. . ..- - - . -... _-- ........_. .-. . . _..
-. ....-- Monopoly 3 - unpack . .. .. ..... -. -.._-. . .-.
Monopoly 3 -.-- crack .- -.-.. ..-. Share ....- crack ..--
._--. ... ......- 258Mbytes _....-. .. -.--.
download .-.-. ._-.. PopCap Games -...- Zuma deluxe -
unpack . . .. - .-. -. Zuma - HTUwww.popcap.comUTH -. download ._. install

_ . zuma.exe - PEiD .. ..._-_ ,

,
., Packer (Protector) ...


,. .-. zuma.exe -. ActiveMARK 5.x protect ..-....-.
-. ..-..-.- .... .. Zuma - ._-_- ,

,
.-. ._ - .-. - Zuma - unpack _-_ _-..
, ActiveMark 5.0 _. pack ........ dump _ .
... zuma.exe - . .. Olly - . Open menu - Attach - ...

,
..- ,.. _.--. zuma.exe - Attach

,
Attach _. .-.. ,.. _.--. VA 7C901231 . . . ... . --. .-.
ntdll.dll . DbgBreakPoint API function ._-. ...-. DbgBreakPoint -. Win32 API
.----- help ... .-.-_. -..._.... .---.
., Packer (Protector) ...



,
Olly . . Alt+M -._. memory map - _-_.. ,

,
,- highlight _...-..-.-. second layer entry point ... ... . right-
click ._. View in disassembler - ..- ., Enter key -. ,-. _...

,
,- highlight _...-.. VA 005AE000,. . right-click ._. Search for - All
intermodular calls - ... ,-. _...
,
,- . _. - . . getversion -_ GetVersion function - .-.
GetVersion API - .-- right-click ._. Follow in disassembler - . . ,- . _.
..

,
., Packer (Protector) ...


,- PUSH EBP ... . right-click ._. Breakpoint - Hardware, on execution
- . . _ . Olly - -._. zuma.exe - --
Olly Option menu -. Debugging options -..- .,-. _...

.,
.,.. _.--. Break on new module (DLL) - .... _. OK -.
-. . ..-. zuma.exe - attach ..-.-. Olly -. -. -_ . . .. ,

,
,-.-. zuma.exe entry point .. _ . .-. - .-. - .- . - ..-
hardware breakpoint ....-.. F9 - .. -. module .-- .-.
. -. ,- . _. . . ..

,
F9 - .---..-. ..-...-. ,-. -.-.- .-.-..- breakpoint
..- ..-.-. _-._.-.-.-. -.-- analyze ... Analyze ....
. VA 00696E58 - PUSH EBP ... . DB 00 ... .

,
,- VA 00696E58 -. - .-. - ..- OEP _.. -. - .-. - debug
..- process - dump . _-...._-.. Olly plug-in -._..- OllyDump -
..- ,
., Packer (Protector) ...
.


,
,- dump button -.._. .- dumped.exe .-._ ...- UPX .. dump
-.- dumped.exe .-.- .. .---. ._-. ImpREC - ._.
import .-- _.. ImpREC (Import Reconstruction) - ..-._-...-.-. dumped
...- ..-.- function .-- .._....._. _..-. .-- .__-
.-. . dump .-. .-- PE ._..... .---.

,
, ..... ...-.--.-.
Olly ...- zuma.exe - active process . attach
Olly .. ._-_-.- .-- OEP (VA 00696E58) - . . -. ImpREC . ..- -
imagebase (VA 00400000) - .-_..- 296E58) -..- OEP - - . . - _
., Packer (Protector) ...


OEP -..- -__.- IAT AutoSearch - .. ,-. _...

,
,- OK .._ . Get Imports button -.
Import function .- ... .... Show Invalid button - . _ ._-_ ... ..-.
.. .. .-. .- -.
._-.. -.-.- dump ..- dumped.exe . zuma.exe .-..._. import
.-- ...... Fix Dump button - .. ,-. -......- dumped_.exe
.-._ .- ...._....-. .-..

,
. - .-. - dump .- _.-._...._ _..--- ImpREC - - - _ .
dumped_.exe .- ._-_ -. error .._.-.. dumped_.exe - -. ..-
- . UPX - unpack - .- . _ .- . . unpack --. _...._ ActiveMARK
...-. .... ._-. WinHex - . _ .- .- - _ _-..
WinHex .. dump _._..- dumped_.exe . pack ..- . zuma.exe .-
. Exe .- overlay data .- .. . byte -- ..-.--. -.- - .-. -
.. . TMSAMVOH . - ASCII string - .- _ .-.-. . . . . . . .
-... zuma.exe - LordPE ..._. section .-- _-_-_-.. ,

,
,- highlight _. ..- - ..- - _-_ - -. - .-. - executable .
..-.. section - - ..- _.. -. . - - Raw offset Raw size . .._--.
Windows loader - exe .- .-. -.--.-. RawOffset (0012BA00) RawSize
(00000200) . . - - . ._.. - 0012BC00h .._.. -. Zuma.exe . address .-
. ..- data block -..--.._. dumped_.exe . . .. . paste . .. . ._..
-. . .. dumped_.exe -. . . . _.. -.
WinHex Position menu - Go To Offset -.._. -.-.- ...- offset
0012BC00 - -_.. ,
., Packer (Protector) ...



,
0012BC00 - -__. OK - . - .,- . _. . .

.,
.,.. _.- ........ right-click ._. Beginning of block - .. ,

,
_ . . ..- . . ..- .. scroll . _ . ,. ..- --. ..-.......
right-click ._. End of block - ...

,
. ,-. Hex -.....- ..._...._

,
., Packer (Protector) ...


.....- Hex - . ..- - - .. _-.. Right-click ._. Edit - . .. _ .
,.. _.--. UCUopy Block - UHUex Values - ...

,
..-.-. -...- Hex - . ..- - paste . _.. -. WinHex dumped_
.exe tab -.._. ...-... ..- . ... . ... . right-click ._. Edit -...
_ . ,. . _..- - . ClipUbUoard Data - UPUaste - ...

,
.. ,-. paste .... ......

,
Yes button - ..--.. zuma.exe - Hex - . ..- dumped_.exe .- ..-.
. .. dumped_.exe .-..._. WinHex -. - -
dumped_.exe - .- ,-. _... ..-._-. - ..
..._.-.-., ..-. -.-.- dump -.. .._..._......_
... -.---.-. ....._. ....-. ._-. patch . _-....
...
, Dump ........ patch _ .
Dump ..-.- patch .-- dumped_.exe - Olly .. . ,

,
,-._.- right-click ._. Search for - All referenced text string -..
..-...-. ,.. _..--. browser .- .....- ...
., Packer (Protector) ...



,
,- OK ..- ,-. .-..

,
, highlight _...-.... right-click ._. Follow in disassembler - ..-
.,- . _. . . -. browser ...- routine . .._..-.

.,
.,- VA 005F41A8 .. right-click ._. Copy - To clipboard - .._. notepad
.-... paste 005F41A8 MOV EAX,dumped_.006A691C ... 005F41A8 browser
retn4 ._. . _ . ,-. dialog timer timeout ......- - ._ . browse .....-.-
. routine . virtual address .-- .-....... .-- .,.. .-
_..-.- breakpoint .- . - . .- - - . _. .... _..-.,
._..-.-.-. LoadStatePool ..... .....- .-.-.-. . .- . ... ..
......- breakpoint .-.-_. -.- _.-. .-. dumped_.exe - Olly
_.-.. -.-.- .-.-..- breakpoint ....- ,- . _. -.

,
-...- ,-. stack window -..._. highlight _...-.... right-click
_ . Follow in disassembler - .... ,-. _...

,
,- highlight _.. .- .. virtual address - . - ..

,
., Packer (Protector) ...


. browser dialog timer timeout LoadStatePool - -.-- virtual address
...-_ virtual address .- . . -..- _ . . -.-.-. ,- . _.. -.

,
,- virtual address .- . . retn 4 retn 0c retn ....- .... _. patch
..- . - _- - - ._ . . . - . - .-. - Zuma Deluxe 1.0 - _--...-
. -... _
, Pack ..... ._.. . .. unpack _ .
-. . ..-. Fish Packer 1.04 pack ..- calc(Fish).exe .-.- unpack
_-_ .. - .-. - . - -. pack ... . -. PEiD .. _-_ .. ,
,
,.._.--. PEiD - ._.... _ . . - . CFF Explorer ...-. -.
-.-.-.- Fish Packer 1.04 pack .. .. Fish Packer pack ..-
....-. .-.._ .- unpack _-_ .. Unpack .. calc(Fish).exe .- Olly
...- Protection ID . .-. Fish Packer 1.04 pack ..._-.._.._.._.
Protection ID .. .....- .- -. . .. -. ... Protection ID -. protect/pack
..- . .- - .. .. ......- .._.--.,

,
Olly - ,.._.--. PE . .- - - . ._..-.

,
,- OK button -..-- ,-. _.-.
., Packer (Protector) ...


. .._. Olly . entry point .-..-..... ntdll.dll module ..- .-.
.- .. . - .- - .-.-.. _...-. Alt+M -._. Memory Map -
. - ,

,
,- highlight _...- PE header ......... ..-.-_. PE signature .-
. .._-_ - ,

,
,. . - .-. - . - ...-.-.-. entry point . address (10257D7) address
-- Olly Disassembler window .. Ctrl+G ._. entry point(10257D7) .-...-
.,

.,
.,- VA 10257D7 .... breakpoint .-.-_. F9 (Run) - . -
breakpoint .- - ...- . . .. ,

,
- ... . . unpack . . .-._.. -. - .-. -.-. _ .- ._- -
-. ._-. Olly Advanced plugin - .._.. .,

.,
.,-. Plugins menuOlly AdvancedKill NumOfRva Bug -...._. -.-
Olly _.-... ,-. .,..- - . ... .-. - ,. - - - ..- .
. ..
., Packer (Protector) ...


,-. _... Alt + M (memory map) - . _-_ - , .- -. .-
.. .,

.,
.,- _-_ calc(Fish).exe . . section ...-..-.. ,..-.-.-. ._.
- . .MCTeam -.-. compress ..-- import .- resource .-- section
-. _.. _ . -.-. Fish Packer - uncompress .._....-.-..... .._.
- .-. - dump .. code section _.. -. . - UPX pack ..-
. .- . .. UPX0 -. code .- ..... code section _.._. UPX1 -.-. compress
..- - .- . SFX section _..-.,
.,- .... right-click ._. Set breakpoint-on-access (F2) -.. _. F9
-. .,-._...

.,
.,. ._. -.-.-. Fish Packer -. compress ..- - .- - section
. ....._ . - .- ..- _ .,- . _. - F8 -..
0100018B 74 1A JE SHORT calc(Fish).010001A7 ; Decompression Stub
0100018D 8A07 MOV AL,BYTE PTR DS:[EDI]
0100018F 47 INC EDI
01000190 2C E8 SUB AL,0E8
01000192 3C 01 CMP AL,1
01000194 77 F7 JA SHORT calc(Fish).0100018D
01000196 8B07 MOV EAX,DWORD PTR DS:[EDI]
01000198 38D0 CMP AL,DL
0100019A 75 F1 JNZ SHORT calc(Fish).0100018D
0100019C 32C0 XOR AL,AL
0100019E 0FC8 BSWAP EAX
010001A0 01E8 ADD EAX,EBP
010001A2 29F8 SUB EAX,EDI
010001A4 AB STOS DWORD PTR ES:[EDI]
010001A5 E2 E6 LOOPD SHORT calc(Fish).0100018D
010001A7 AD LODS DWORD PTR DS:[ESI]
010001A8 85C0 TEST EAX,EAX
010001AA 74 37 JE SHORT calc(Fish).010001E3
010001AC 89C7 MOV EDI,EAX
010001AE 033B ADD EDI,DWORD PTR DS:[EBX]
010001B0 56 PUSH ESI ; module name (eg., kernel32.dll)
010001B1 FF53 0C CALL DWORD PTR DS:[EBX+C] ; kernel32.LoadLibraryA
010001B4 89C5 MOV EBP,EAX
010001B6 AC LODS BYTE PTR DS:[ESI]
010001B7 84C0 TEST AL,AL
010001B9 75 FB JNZ SHORT calc(Fish).010001B6
010001BB AD LODS DWORD PTR DS:[ESI]
010001BC 85C0 TEST EAX,EAX
010001BE 74 E7 JE SHORT calc(Fish).010001A7
010001C0 83EE 04 SUB ESI,4
010001C3 AD LODS DWORD PTR DS:[ESI]
010001C4 A9 00000080 TEST EAX,80000000
010001C9 75 0B JNZ SHORT calc(Fish).010001D6
010001CB 83EE 04 SUB ESI,4
010001CE 56 PUSH ESI ; module name (eg., kernel32.dll)
010001CF 55 PUSH EBP ; function name (eg., GetVersion())
010001D0 FF53 10 CALL DWORD PTR DS:[EBX+10] ; kernel32.GetProcAddress
010001D3 AB STOS DWORD PTR ES:[EDI]
., Packer (Protector) ...


010001D4 EB E0 JMP SHORT calc(Fish).010001B6
010001D6 25 FFFFFF7F AND EAX,7FFFFFFF
010001DB 50 PUSH EAX
010001DC 55 PUSH EBP
010001DD FF53 10 CALL DWORD PTR DS:[EBX+10] ; kernel32.GetProcAddress
010001E0 AB STOS DWORD PTR ES:[EDI]
010001E1 EB D8 JMP SHORT calc(Fish).010001BB
010001E3 5F POP EDI ; POP ESP, so calc(Fish).010257DF
010001E4 C70361EBF600 MOV DWORD PTR DS:[EBX], 0F6EB61 ; POPAD & JMP , EBX = 010257DF
010001EA 66:C743F89068 MOV WORD PTR DS:[EBX-8], 6890
010001F0 66:C743FEC390 MOV WORD PTR DS:[EBX-2], 90C3
010001F6 C3 RETN
.,
.,...-. .... - - _..-. .. . decompresion stub -..__.
-.-- decompress -. _..-. LoadLibraryA() -..__. import .. DLL
..-- .-. GetProcAddress -.._. import function .- address -.-. ..-
...-. EBX - 0F6EB61 opcode .- ...-. 61 -.-. POPAD _.._. EBF6 -.-.
JMP xxx _.. -. Endian .-. .-_, POP -.-. ESP -.-..- - _ -
.-. Stack .. ..-.._...-.-.-. EBX - .- - .-..- ._-. VA
010001F6 (RETN) - ..._... VA 010257DF - .. .... ._.. -. .,
.,
.,-._.- F8 . . . - .,- ._. ..
.,
.,-. _.-...-. EBX -.._-. 0F6EB61 6890 90C3 - - ._ -.
. -. .._ ..- _ -. PUSH + RETN -. JMP _-.._-. .,.. F8 .
-.-.-- OEP . ..- _ _.. -. .,

.,
.,-. _..-. dump _ _.. -. .,

.,
., IAT . API Redirection


tcef;(15) - IAT ES if h API Redirection



....-. pack ..- . .- - unpack .. . ._.. .._- .- .. IAT (Import
Address Table) ._-. .- .. ... .. ._.. -. _ . - .. .- .- IAT ._-. .- ... ... ._..
- IAT .--_... ImpRec 1.7 -..__._-. ..-... IAT .- -.- . .. ..
IAT .- ._-. .- _ . ... ... .. . ._.- -._.. -.
Info: : Microsoft Windows .- -. -. -. .- _ _-. . - API function .-..
.-_- address .-_--. -.._-...-. DLL . .- .- _ - -_ ...- ._-.
Application -..-.. ... function .- .. . .. .-. -. -. . - .-.-.
application .-.-. .---. function .-- import .- .._ . . - -.
operating system DLL . . . -. ... application -.-. -. ... . . . -.
.. .- . Win32 exe ._..- application -... IAT . -. -. IAT -. -. . .
-. Application -. - Windows API function -.-...-.. IAT - lookup
table _...._-. ._-. -. . -. - .. .. .- - IAT -.-
-_...-..-- Windows loader -. API .... address . .. .- .. ._.. -.
-. .- . ..-. API -. - .. . IAT . ._-_ _ . DLL ....-
address - -....-. exe .-.- pack .. protect .... cracker .--.
.- unpack -. unpack ..-.- ..-._.. .. .. -.._-.
..-. packer/protector .-. .-. ......- IAT - .- . _- ._-. . exe . -
.-. .. . . .. .-. IAT - _-_...-. __.-. Import .--
_ _ -_ ...- -.-. IAT - _ _ -_ ...- -._.. -. IAT -__-_...-.
-- IAT ._-..- ....-.. ._
Info: : exe .-.- ... -.---.. Windows loader -. ...- PE structure
- .- . executable image - .-..-.-. -.-. Application -.._- DLL
.- .. .- - .- -._.. _ . . - - process .. - .- _.. ....-._.. -. exe
.-. DLL ....-- function .-...- ..._.-. Function address .- -.
...---.._-. run . . . compile ..--.-...- ._....- variable
.--._.....- mechanism -. -. - IAT . .__ . ._. .. -. IAT
. -.-.-. DLL . .- - - .- .. . . Windows loader - _._.-- function pointer
.- ...-. _.. -. Application -.- ... compile .- IAT - . _. . -.
_..--- -. API CALL .--. -.........- --- address .-- ...__-.
.. function pointer --. _--. pointer table - _...... ..
-. . ..._. .-. CALL [pointer address] -.- - - ... _ ..-. . JMP thunk table
. ... _ ..-. ._.. -. Pointer table -..__..._. loader -. API call -.._.
- -..- ...-...-_ . . .-. - . . -.-.-. pointer - table -
..-. . . . ....
Info: : Pack ..- exe ..-... .-.--. .-....... IAT .- - _. -. . . .
.... ..-. -. cracker .-- unpack ..-..-. Pack ..-
-..-- ._...-.-..- compiler .--_--._.._. _..- mechanism -
... . _..-. --. packer -.-. import table mechanism - .- . ..
.-.- packer/protector -. -.-.. DLL function .- . pointer .-- -.....
... . -.- - - - . ._.. -. , . -. . -.-. decompression stub -..._.
routine .-- restore _ . . . . ...._..-. .-..- import table
-.- -. restore . . -.- .._ . . - .-. - . import table - -. ..
... Windows loader - - parse . -..- _ . . -.- . ... -.
.... IAT - .- _ . . ._.. -. ..-.-. Lena151 ....,- Reverse
Me.exe -._..-. www.tuts4you.com .. download . -
,
., IAT . API Redirection
.

,-.-. ReverseMe.exe - Olly . .. _ .- _. - VA 00401002 -.-. API
. CALL - .. .-. CALL -.-. kernel32.dll ..- GetModuleHandleA function
- .. .-._.. -.

,
,-_-_- ..- CALL .- .- . . VA 0040104D - kernel32.dll -
ExitProcess function -...- CALL _.. -.

,
ExitProcess function ..... ..-.-.-. ,- ..- . . . - _-_ -.
- _.. CALL .- Olly -.-. -. API -.- ......-. _...--
. . .. VA 0040104D ..- . ._ . Enter key (Follow Call) -.- ,-.
_...

,
. ,-. jump (thunk) table ....-._ ._-.. Olly - VA
0040104D -. API CALL -. - ... . _- CALL -. _.. ._-. . . -. Application
-....... ExitProcess API - .. . -. . address (0040104D) - .._..
_.. -. . .. Windows loader - .-- address -.-. .-.... . VA
0040120E -.-. -. instruction -..-..-..... .... Enter key
-.- ,-._...

,
--. .-. loader - data segment - DWORD - . .-. . - jump . ..-.
_..-. ._-.. -..-.... DWORD - . .- ._. _-_ .. Dump window
.. Ctrl+G ._. ..---.... VA 402004 - _ _ . OK - . . - .-. ,
-. _...

,
., IAT . API Redirection


,-.-. .-.. DLL ...- API .- address .--.- IAT .-.
.. - .-. - . ...-.-.-. ExitProcess API -

,
._-.. VA 00402004 - _-_ - ,- ._. .-. Highlight ..-
..-.-. - .-. - API ... 7C81CAA2 -.-. API . address Endian _ .
. -.. - , . ..- . ..-. DWORD - . .-. . _.- , - - .-..- . . . _.-
..- - DWORD -...--.-. ..- DLL - API .--__.-. DLL -.
user32.dll _.. -. DWORD - . ..- - _-_ - 7xxxxxxx .- .-. .- ... . . _ .
. ... .- - IAT .._-_-_-.. ,- _-_ - kernel32.dll .-
API ..- import ..-..- . . . - ... .-.-. IAT imports table - -. .- - .
.-.-
Info: : Imports table .. .-.-- API .-- link -... Windows - --
- .- .. . -. Imports table .. ..- structure -.-. Import
..- DLL ....-- header -..-. .-..- . -...... .._-.
- -.. . - -. ...-. Header ..... ..-. DLL - - - - .- .. .
-. ReverseMe.exe -.--..-. user32.dll kernel32.dll - API .--
import .. . . . header - ..- . . -. -.-. kernel32.dll --_.._. -.
-.-. user32.dll --_..-. -.-.-. imports table ..- .-...._..-.
Windows loader -. header ....-. --.--.-_. --.-- IAT
_._.-....._-. IAT .-.-.-. DLL ....-- IAT .-.._...-.- ._.-.
DLL . .. .- - header -.-. IMPORT_IMAGE_DIRECTORY .-. IMAGE
. - .-.. .-.-. . - . . . - - . .- - _ _ .-._.. _ . offset .-...-. RVA .-
_.. -. . . . ..- structure -.
IMAGE_IMPORT_DESCRIPTOR:
OriginalFirstThunk
TimeDateStamp
ForwarderChain
Name
FirstThunk
Info: : Windows loader - IMPORT_IMAGE_DESCRIPTOR - .- . . . -. DLL -
.....-. ..-... loader -. DLL - -.--._.._. IAT --_...-. .--.
- -_ ...- -.-. _ ._ ... - -. Loader - .. . OriginalFirstThunk -
.. ...-._.. ... - - .- - _.._-. .. . ._-._.. -. ..- -. -.-.
FirstThunk -_ _- ._ . .. .- - . -. pointer - API address ....-. _..
-. --. ...._-. ..- API -...-.-. OriginalFirstThunk ...._.
-. - - .- . . _- ....-. ..-.._...._- ..-. crash _..
-. ._-. .-... FirstThunk - pointer .-..... API .-._.-.-
RVA .- ... - DLL -. API .- - _ .- address .- .-. . - ... .-.-.
. - . . . exe - ...._ .- ..- . ..-. IAT -_ ...- _ .-. _ .. ._
Info: : Loader -. FirstThunk - API ._ . .. .- .- _ . . address -...-.
--. address -..- ._.... address ... . - _ . . .- - .-.
OriginalFirstThunk ...._. _-....-. ._-.. OriginalFirstThunk -. FirstThunk
backup -._.._. _.._--.. .._-. FirstThunk -.-. - .-. - import .
- API .- ._ - .- - pointer .-- array -._..-. --. -.-
-- process -. .-.. ._..-. FirstThunk .- pointer .-...-.
., IAT . API Redirection


API .- address .- overwrite -. _ . address .--.-. IAT .-. -. -
CALL .-...-. IAT .. redirect _.-. Loader - IAT _.. .......-
address .- _.. . -.-.-.
, API --. address
, API . jump .
, push RVA API
Info: : Import table - __.-....--
, RVA import table - . ...-. import .- - - data directory -. .-.-
_ . .. -. . .- - .-. Windows -. .-..._.._. IAT - ._-.._-.....
.---.
, DLL ....- IMAGE_IMPORT_DESCRIPTOR -. ._-_. Import table -
.-...--....-
, IMAGE_IMPORT_DESCRIPTOR . . OriginalFirstThunk FirstThunk Name -.-....
.. TimeDateStamp ForwarderChain - -.-. . __.. .. -. OriginalFirst
Thunk - . __.. ... -.
. .- - .- - - ._.- - - . . . ....- _ -. ._-.
_ ..._ . ... ReverseMe.exe -_-_-_-.. ReverseMe.exe - Olly .. ...
Windows loader - .. ..- -.-.-. -. header - IAT --_...-.
-- RVA 3C (400000 +3C = 40003C) .....--. .,

.,
.,. .-. PE header ...-. VA 004000C0 _.. -. VA 004000C0 .-
. .. - .-. ,- . _. . ._.. -.

,
IAT RVA -..-.-. PE header . address -.... 80h . ._ . .- - . .
VA 400140 ... . . . ..._ ._.. -. exe - .- - ... ._. -. , ,

,
,. .-. import table -.-.-. RVA 2050 ..
Info: : Import Table Address .-.-.-. import table ...- ... address - IAT
.... ... . - . . -. .- _.._....-.
., IAT . API Redirection


. - Import Table Address - Olly ...-.-.-. -._....-. Olly -. header
- .- _ .- - __ . - ..-. --. -. . . . . .- Import Table
Address -.. -._.._.. ._-..._. -.-..-..-.- ...-. .-....
-.-.._.--- ....-._.-.
.-.._. Import Table Address .-_-_-_-.. ,

,
- .-. - ... .- ..- ..- IAT .- ...- . . Import Table Address .-.
.- -. Disassembler window VA 00402050 -...- ,

,
,.._.-.-.-. -.-.-- - -.. ._... ._.. ..- . Analyze This! -.._.
analyze - ,

,
,.._.-.-.-. IMAGE_IMPORT_DESCRIPTOR array . ._.. -. .
-.-.-. DLL . .. .- - IMAGE_IMPORT_DESCRIPTOR .- _.. -. -- .
._..- -.-. . ..- IMAGE_IMPORT_DESCRIPTOR _.. -. IMAGE_IMPORT_
DESCRIPTOR -... DWORD -.. ._--.
,...-- ... DWORD (00002098) -.-. OriginalFirstThunk _.. -.
.-. loader - - DLL -. import .. API .-._.-- -.........-
- - .- ..-. --. IMAGE_BASE + 2098 .-...... -.-.-
. import .. API ._ .- - .- . . ..- .- _-_ ,
- . DWORD (00000000) -.-. TimeDateStamp _.._. -.-.--- ...
. - . ........_. .-. .. .-. . _.- _.. .-- -.
-- . DWORD (00000000) -.-. ForwarderChain _.._. -.-.--- ...
. - . ........_. .-. .. .-. . _.- _.. .-- -.
.-- DWORD (000021D8) -.-. IMAGE_IMPORT_DESCRIPTOR .-.-
DLL ._. RVA _.. -. - .-. - . . -. . ..-. 4021D8 .. user32.dll
-..-.. ._-..-..,
..-.. DWORD (0000200C) -.-. FirstThunk _.. -. Import ..- function
.-...-- address .-...- ...-- IAT .- _ _-. Disk ...
.--... -._-... exe .- .-. -.-_....-. ---.,
- .-. - . . -. . ..-. . . user32.dll -. import ..- API .-
-- IAT ..- address .-...- .-....-. ,-_-_ 40200C -..-.
.- ..
., IAT . API Redirection



,
,. .-. API function - ..._-. . .- -. -.._-. ._.. -.
..-. 7xxxxxxx .- address .- -.._..- DLL (kernel32.dll) -- _.
-.

,
IAT . . - address .- -. ,- . 402000 -..-. .- ..

,
..- . .-. DWORD - . . .-.-. . _.- _ ._.. .-. .- _. . . ,

,
Dump window .._-_-.-. .,-. .-..

.,
Import table - . .-.-. DWORD .- array .-_..-. ,

,
DWORD .- array .--.-. IMAGE_IMPORT_DESCRIPTOR .- OriginalFirst
Thunk .- - point -._..-. array .- DWORD ....-. import ..-
function -. .- . -. DWORD .- array .-- ._....-. ...-..-.
-.-. ._.-__.- DWORD -. -_.. -.
,. ._. -.-.-. import table --....-...,_..-.

,
., IAT . API Redirection


,.._.- ......- BeginPaint,.. , -.-. import ..- function .- DLL
.- _.. -. . . ..-. .. - .. . ..-. .- - - . DLL ._ -. function .-..-- .,
. -. -._.. . -.
4021D8 .. user32.dll -..-......- ._.-. ,

,
--..-. -.. ..-.....-_...-..- IAT -.-.-. ,

,
,- _-_ - .. . kernel32.dll -. import ..- API .. user32.dll -.
import ..- API .- _-... . DWORD -..-. ._...._ . . .. ..-. . _.-
DWORD - . .-. - ._....-..- -.

,
,- _-_ Import ..- function .-...._..-.. DLL ._.-
. ..- ..-. .- . .
..- . import .- - - . - _ -_ ...- . ._...-_ -.
-. _.. _.. .- ..-. .-. -.-. import .- - ..- _ -_ ...- ... - tool .-..
.- -. . - - --. .-. ... . .- - DLL ._..- _.... .-. API .- ._..-_...-
import .. .. . import .-- -.-__-_...--.-. .-. _-.. _ .
. - .. .-. . -. Tool .-- .._....-. -.-.-. API .....-
_ recover ... ...-. unpack ..- . - -. _ _-. . -.
_-_-_-..
.-.._ FSG2.0 pack ..- . -. - unpack _-_ .. . . . -
unpack -. . .-. Lena151 . ...,- download . . .- - .-.
. . .- . . -. - FSG pack _-_- ..-.-.. .-.-. - - ,
,
., IAT . API Redirection


UnpackMe_FSG2.0.exe .- Olly ...- ,-. .--. ,-_-_
- entry point .-. _ ._ ... .-..- -. exe .-. entry point -. _. -. .
401000 -..-. ._...-. . - ... -. . . 400154 -..-. . address
-. PE header ..- .-. ...-.
FSG - trace -_._. unpack -. --. . . ..- - _ ._ ...
scroll ._._-_... unpack - stub - . .- .- . .. --. . . trace
- _-_ - _ .- - . - ._ .-. .- _. . .. ._-.. . ..-. - -. . -
-.. jump . ..-. .- . .. ..._-_ .. . .-. jump -. - stub -
. .-. - . ..-..- . . _-_ - _-..

,
,-. VA 004001D1 .... breakpoint .-.-_-_-.. _. F9 (Run)
-.- Breakpoint ...-.... ,

,
,.._.--. JMP -. -. OEP (VA 00404000) .. jump . ._.. -.
,

,
,.. right-click ._. Analysis - Remove analysis from module -..-
.,-. .-..

.,
.,-._..-. -.-.- .- dump .. Right-click ._. Dump
debugged process -..- ,-. _...
- .-. - . . _ .. .- . dump -. -._.._.. ,...-.
"Rebuild Import" - uncheck ..-. ... -.._-. FSG -. import .--
.- . - -._.. _ . Ollydump plugin - . ._- . - -.. . .. ._-. -.-.-
. __-..-. . .. . . checkbox -.....-. -. ...
dump . - . ..-. .- - - . --. . ._ .- ..- . ..-. - .. ..
..
., IAT . API Redirection



,
,- "Rebuild Import" checkbox -_.--_. Dump button -.. _. dump.exe
._ .-...._.-
--..-. _.. tool .- dump -. .. LordPE PE Tools ,

,
-. _.. _.. dump ..- . . . . .-.-. ...--- . -.._-. . .-.
FSG - import .-- .-.. ._-.. import .- _ -_ ...- . ._ Import
.-- _-_...-.- tool .- ..._- . ... - .-. . ImpRec 1.7 - ....
ImpRec -._. process (UnpackMe_FSG2.0.exe) - attach

,
UnpackMe_FSG2.0.exe .- attach _....-. OEP - . .- _ . -. ImpRec
- - process EP -...-. ._-. OEP ... . 4000 _- _..-.
AutoSearch button -..-

,
IAT .- .-..-. . .__ ,- RVA ... . 11E8 - .._ . dump ..
. .-. . _ ..- dump .-. ...---. -.-.--.. ..
.-. . . .. --. .-. .. .. _ .. .. RVA - ....-.._-_-_-
.. Olly dump window . . 4011E8 -__. -..-..-._-_-_-..
,
., IAT . API Redirection



,
--. .-. VA 4011E8 . . -..- -.-. DLL -. import .- .- scroll
_ ._ .. _ ._-_ - ..- import .--.-... ,

,
- .-. - . DLL (user32.dll/kernel32.dll) ... import .--...-.
VA 4011E8 . DLL (kernel32.dll) .-. import (API) .-- ImpRec - ..- . .
--. .-. ImpRec -. _...--. ._-.. VA 4011E8 .... VA 401198
_ . -. . .. ImpRec - user32.dll . import .-- ..-..

,
,-. RVA -_-_. Get Imports button - . - ,- . .- ..
Size - 100 _ - .-. ... . .. ImpRec - _ .. .. . . .,

,
ImpRec - Thunk . . - .- -. -. _.. _.. . . . .-. . ...-. -..- . ...
-..-.... ....--..-..- ....-...--.-. RVA 2118 ..
,-__-_- RVA 2118 .. FFFFFFFF - .- . . ..- -. -.-. RVA 11B8 . .
,

,
., IAT . API Redirection


--. .-. ,. . _. - address .--. --..-. FSG - cracker .--
. -. _ . ...-. ._-..- address .-- .--..-.

.,
.,-. .- thunk .- . . right-click ._. Cut thunk(s) -..- _.
..-....-.-. dump ..-.- _.

,
,- Fix Dump button -._. Olly . . dump _......- dump.exe .-....
ImpRec - dump_.exe .-._.- ........ ,

,
dump_.exe . - . - .-. ,-. .-..

,
dump_.exe .- Olly ..._._-_- ,-. _....

,

., IAT . API Redirection
.

, API Redirection
. import .-- -._-_...-..-. _-......_._ ...
._. packer .-- unpack . ..-. ..- . . ..- .-. - . IAT .- -.
--. _ -_ ...- . ._ -.._-. . .-. .... -.-.-- import table -
_ _ -_ ...- -.-. ...-. .- IAT - __.-.. ._-.. pack ..-
.-.- unpack _. API redirection ._-. .- . ._-.. ... . -. packer
-..__. pack ..-..-..-. ......-.-. Pack ..-.- Lena151
....,.. download . . -.
INFO: : API redirection . -.-.-. packerprotector .... - IAT ..-- import table,-
-. . - -. .. . .- - .,.- . .. - - ... - -. _.. ... IAT .. redirect
- API ... . .-..-.- pointer -.- ..--. .-.-.-.
packer -. packprotect ..--.-- system DLL .- - API address -...
. .- ... ._.. -. API redirection ..- -..-..-.......-. anti-virus ....
.- _..-- . -.- .-. . - ... ._.. -.
, Pack ......- unpack _.
Pack ..-. API Redirection Tutorial.exe, - Olly ..._-_-.-. ,
-. .-.._..-.

,
,.._.-.-.-. pack ..-..- -..._....-. VA 0044CB
59 ....-.. F8 (Step over) -.- VA 0044CB59 ..- Register window -
_-_- ,

,
,- ESP register . . right-click ._. Follow in Dump -..- ,-. _.
..

,
,- highlight .- DWORD (38 07 91 7C) .. right-click ._. breakpoint -
Hardware on access Dword - . . - ,

,
., IAT . API Redirection


,-. breakpoint .- . - _ .. .. .-. F9 (Run) -.- ,-. hardware
breakpoint .- ..-.....

,
CALL EAX . F8 (Step over) ..._. CALL EAX ...- - F7 (Step into)-
. - .-. .,- . OEP .- ..-.....

.,
..-. -.- unpack . Dump debugged process -..- ,

,
,- Rebuild Import checkbox -_.-- Dump button -.._. dump.exe ._
. . . - _ . . . .. dump.exe - . _-_ - -.. ...- .
. Import .- - .- _ . _..-. -- .-..-. ...._ ._-. . ImpRec
1.7 -._. dump.exe -_. _-...._-_.. ,

,
., IAT . API Redirection


,- _. -. .. . -. . .._ . ._.. -.
, API Redirection Tutorial.exe - attach
, OEP - . .- - _ _ . IAT AutoSearch button -.
, Get Imports button -... Import ..- function .- - 618 -..- ..
, Show Invalid button -.._. invalid _...- function .--_-_-.-. ,-._.
..

,
,.._.--. ImpRec -. IAT - API - . address .- - ...- - .
._-. . ... ..-.- - -.- API .-...- ...-- dump -.-. - ..
- . Dump ..-.-. crash _....., ........_..-. pointer .--. .-
- .- . _ ._--._.. -. ._.. .. .. .-. - .-. - . Cut thunk(s) -
. . - . ._. ..-..- -. packer .--. cracker .-- .-.... -
_.... .- address .-- -._.._--.,
... -. ,.._.- address (00458C35) -.-. - .- . ._.. .-. _..
invalid .- API - _-_ - --. .- address .- _.. .-. ._-. ,-
00458C35 ..- right-click ._. Disassemble/ Hex View -..- ,

,
,-_-_- 00458C35 .-. --. - .- ..._.. .-. Olly memory
map . ._-_ - packer SFX section ...-..--. ,

,
Olly . . 00458C35 .-_-_- ,-._.-.

,
., IAT . API Redirection


,--.--.-. API address (FindClose function) ---..-._..-. ...
- . . - . - .-. - . section .. .- dump .. . API address .----..-
- .- .. ._.. -. - - .--... ..._-__-.. Olly - Ctrl+F2(Restart)._.
_.-
, Redirection - .. .._ .
API Redirection Tutorial.exe - Olly .._.-_. VA 00458C35 .- . .._-_ -
,

,
,.._.--. VA 00458C35 .... -...-.
INFO: : --..-. -. run .... unpacking stub - .... redirect .. - -
...-._.. -. ._-. OEP - ..-. dump - .- ... . redirect ..-
- .- ..- . API .- ..- . ..-._.. -. dump ..- -. - .-. ..-. .
.. .---.
.-.._ ImpRec -__-_.. ,

,
,- _-_ API .- redirect - -.-. 00458C35 . ._.. _ . address -
RVA 00438040 . ..- . - - -._.. -. ,

,
,. ._. - - . VA 00438040 - DWORD -..-_-_- IAT - ... .
-_ ...- -._.. ... - - API .--.-. .. packer .-.- redirect ._-
-. .. 206C8BA9, ._-.. IAT - -. -..... -..-._. -...
..-.... ,- ..._-__-.. - _ . - - --._. .-. _.. redirect
..- API .- ..-.
INFO: : -.-.-. exe - import .-...-...-- API ....-. API
. . -.-. LoadLibraryA GetProcAddress - _.. -. Win32.hlp . . ._..-.-.-.
LoadLibray() function -. exe module -...- process address ..-.. ..
..-.
HINSTANCE LoadLibrary (
LPCTSTR lpLibFileName
);
., IAT . API Redirection


... ..-. lpLibFileName - exe module . ._ address _.. -. --. ..
function -. .. _. . . ... . .-. return _--..-. module .- handle -.
_.. -.
GetProcAddress() function -.-. export ..- DLL function address - return
_ -.
FARPROC GetProcAddress(
HMODULE hModule,
LPCSTR lpProcName
);
... ..-. hModule - DLL module .- handle _.. _ . lpProcName -.-.
function .__..-. --. function -. .._........-. return _-
-..-. DLL export ..- function address _..-.
..- -. . . ._ .-. .. . LoadLibrary - DLL . -. - - .- . .. ._ ...-
...-. _- handle -- ....- import ..- API . .. . address -.
-.
.-.._ VA 00438040 - DWORD - . .... .-..- _.. . .-...._-_. .,
-. breakpoint .-.-_-..

.,
_ . .-. F9(Run) -._. VA 00438040 ..- ... _-_ ,

,
,- _-_ VA 00451B38 ..- .-. DWORD (84B3D4CF) - . .._. .. ..-..-
.. ... -..- -.-.-.-...--...---. F9 - . VA 00451B56 -
DWORD (3963D4CF) -..- .-....-. ..- F9 -. VA 0045BC2A -
DWORD (00040EDC) - . .- . - .......-. ._ - . ..- F9 -.-.-.
,- ._. ..

,
,- DWORD (7C80EFD7)- .-. . - ...-. Registers window -_-_-

,
., IAT . API Redirection


,- EAX register . . FindClose() API . address -..- ..-

,
,-.-. DWORD (7C80EFD7) - . .._. .. ..- .. hardware breakpoint .-.-
..-..,- ..-.-. -._.._.. packer -. IAT - API -- .-- address
- .. ...... -. ..- .. ..-. address - . .-. ._. . . ..-. -. ... .
._. . -. . -.. .. F8 - . .
INFO: : ,-_-_ VA 0043803C .. DWORD (7C80BAF1) - . .-. .- . - ..-.
.- . . --. packer - ...... _-_ .. . packer - -. . .
DLL . -. - ...- _ . .. . IAT - . - - API address -.._. API -. redirect
.._.......-._.. -. _ .. .. ..- DLL -.-_. _.-......-._..-.
-. _.. _.. ,- VA 00438040 ..- .-. _-_.._. F8 - . . ,
,
,-_-_- VA 004536F5 - CALL 00453E90 - ... _ .-. DWORD
(00458C35) - . .._. .. ..-. ...-.-.-. CALL 00453E90 .. API address -
packer -. redirect - -._.. -. ._-. CALL - _-_ - _-..
-.- Olly .._.- (Ctrl+F2) _..-. ,- VA 4536A6 ....-.. F9 -
_-...- ..-...-. ,- VA 4536F0 . CALL . F8 - . . - CALL
...-.-. F7 (Step into) -.- ,-. _. .. . - ... .- , VA
4536DF - JE 4536F8 -. CALL 00453E90 - .-. ... -. . -.- ,

,
., IAT . API Redirection


,-.-. API address - redirect .._....- CALL .- _.. -.
00438040 - DWORD -..-..._-_.. ,

,
00438040 - DWORD (7C80EFD7) - . .- ... _-_ .. . F8 ..

,
,.._.--. VA 00453EF4 - ..- -. 00438040 - DWORD (00458C35)
- . .._. .. ..-. .- -. --. .-. - . .._. .... packer - VirtualProtect() API
-.._-.

,
_..-. page access - .-..-.-.. VirtualProtect -._. .._-.
INFO: : VirtualProtect() function -. .. . ._.- process virtual address ..--
page .- . . -. .- access protection - ._. . ..-. function -. Virtual-
ProtectEx .-..--. VirtualProtectEx -.-. -. process access protection -..
._. . ... -. . . -.-. access protection -..- page .....-.... .-.-
. -. --. .- . - ..- . . - .. . - -. page .- .. ._..- - ... -
.._ .. .-. function -. .. _. . . ... . _ .. - page .- access protection -
__._..- return _ .. ._.. -. VirtualProtect function -. ...._.- process
..- .-. access protection - ._..-._.._. VirtualProtectEx function -.-.
.-.-..- process ..- .-. access protection - ._. . -._.. -.

.,
.,- _-_ VA 00453ED5 - PUSH EAX ... . -..- ._. . . ... 438040
-. page . . base address access _..-.
., IAT . API Redirection


-..- .._.-. __.... VA 00453F02 ..- VirtualProtect() API -
... - -._.. -. VA 00453ED0 - PUSH 4 -_-_ 4 bytes _..-.
..- . . . .-. .._ . .._ . .. - - - - .-. . redirection
--._.- ._-_-. Conditional jump .--_-_ ,

,
,.._.- VA 00453EC8 - JE 00453F0F -. VirtualProtect() function ...-
.-. ... -. .- _. ... ... . JMP 00453F0F _ - .. .
--. _ _ . assemble - .. . API -. packer -. redirect .-.
...--... address -.-. IAT . . . .. . ... _.._ .. ..- ...- - -
- ..- . ._. ._-_ _-.. ,-. F8 - . . VirtualProtect() -.
.-..- -._ restore ...-. _..
VA 453EF7 - PUSH ECX -.-. . access ....- - address PUSH EDX
-.-. characteristics ,

,
40 -.-. initialized data PUSH 4 -.-. 4 bytes PUSH EAX -.-. VA 438040
. ._.. -. F8 - .- . . .... . ,- ..- . .

,
,.._.--. F8 - . . .... . .-. -. - JMP 45363B -..-- .
_ -- . .._ . ..- API -. address ---.. ..- API -. -.-. lstrcmpi() function
_.. -. ,- _-_ .. . lstrcmpi() function -.-...-. API address - ._. . _ .
. -..- -. ,- _-_ .. . VA 4536DF - JE 004536F8 -. redirection CALL -
.-....-..--.
., IAT . API Redirection



,
Redirection _..- ._...-- -.-.-. _ .. . - . ._. -.
._ .. .-.-. ,- VA 4536DF ... . JMP 4536F8 ._. .. ._.. _ . - ._ .-
.-. VA 4536F0 ... . NOP ._. .. ._.. -.
._-.. VA 4536DF .. right-click ._. Breakpoint - Hardware, on execution -
. .

,
..- . .-.-. - .-. - -. OEP . VA 4331B8 -..._. ,-.
Breakpoint (Hardware, on execution) -.-.-. _..-. -.-.-.-.--
hardware breakpoint .-- .-- . ,- . .. .- . - - - hardware break-
point . . - .-. ..

,
-.- Olly .._.-_. F9 - . - ,- ._. ..

,
,-._.- VA 4536DF - JE 4536F8 ... . JMP 4536F8 _ _ . VA
4536DF . ..- . - ..- hardware breakpoint -_.-- ..-. OEP . ..- . - ..-
hardware breakpoint -...-.-..._..-. _. F9 - . - ,. ._. - - .
-. OEP .- ..- . ... ._.. -.
., IAT . API Redirection



,
.. Dump window -_-_- ,-._...

,
,- API .- --. address .-- _.-.-.-. .-. ..... . .-.
,- Disassembly window .. right-click ._. Dump debugged process - . . .,

.,
Dump button -.._. -.- Redirection_Fix.exe ._...- -....-.
Rebuild Import checkbox -....-. ...--.- _._-_- ,-.
_...

,
Redirection_Fix.exe .- .-...-.. ... .....- _._..._-.
.-..- -. ._-. . . - section .-- ....... LordPE -._. section
.--.-._ .,
., IAT . API Redirection
.


.,
.,.._.--. wipe section header -.._. section (4/5/6) -.-.- .,

.,
_. .-...-_. PEiD .. .- .,

.,
PEiD plug-in -._..- Rebuild PE -.._. .,- Rebuild button - . . - .-.
-.-. 72.65% ..... ........_..-. .,

.,
. .-. pack ..- exe .- unpack ... _-.-- API redirection _..
- ._. . _ .. .. .._ _.. -.




., Visual Basic _. .......... -. ...- crack _ .


tcef;(16) - Visual Basic jzifh a&;om;xm;aom y&dk*&rfrsm;udk crack vkyfjcif;
-. . ..-. VB .......- -. .- - crack _-_ . ._.. -. _. .. -. ..
.- .......- -. .-. .-. ......-. VB .......-._.. -. ... . crack .
. .. ..- . . -. -.-. PC to Answering Machine 2.0.8.2 _.. -. . ._.. tool
.- -.-. OllyDebug SmartCheck - _.. -. Olly -.-. .. ._ ...._.. -.. .._.
... SmartCheck . - ... . ._-. .- .-. _ .. . - .- .. -. NuMega
Technologies' SmartCheck .- ....-.- .. Compuware - . -.
Compuware -. SmartCheck - ....-.. development -. ..- .- -
_ .. .-. - . SmartCheck - shareware _.. .. . -. . ..-. -.- . .
freeware _...-.-. Google - ..__. ..-. -.-....-.-.-. 6.20
_.. -.
(1) y&dk*&r f\ o ab mo b m0
PC to Answering Machine -.- Olly .... PEiD . . . - ,

,

,
._. - .-. . -. .- - . -. - -. ..... -. pack
....-.... PEiD .. . . . -. . . RDG Packer ., CFF
Explorer - ..-.,
,.. highlight . _. -.-.-. -. EP ,-.-. -.- Visual Basic
....._-. ._-. - .-. ._. -.-.-. Visual Basic ._-..
INFO: : Visual Basic .-. DOS .-...-.- .- BASIC -....-..-. . - .-
highlevel language-. BASIC _ .-.- -.-. Beginners' Allpurpose Symbolic
Instruction Code _.. -. Visual Basic -. visual _.._. events driven -.-....-..
_.. -. -. ....._ .- visual environment . .- . -. -. ...- -. object
.-- _--. click .-. ...-event,.-- -_..-- object ....-
. . .....-. ._-. . Visual Basic -. -. subprogram ._..- _.... . . ._ ...
_ . _.. -. Subprogram -. . . . . - - . - .- -. Subprogram .--. .._...
. -. _ . -. -_ .. . . - .- -. . . -.-.._.-.
INFO: : Visual Basic application .--. __... compiled ..- application .- _.....
. - _. .- - OllyDbg .-- ....-. OllyDbg -. compiled language
., Visual Basic _. .......... -. ...- crack _ .


.- - - debugger _..... VB - - - . . .. ..-. . .......-. C/C++ - -
..-. .-..-. .--. VB -. -....-..... _ ..-. . -. ...- _. . .
... _ ..-. . .-. .. . .-. -.
INFO: : VB -..--. external DLL VB 6.0 . ..-. MSVBVM60.dll _..-. _..
version .- ..- . .- . .. , . .. . . .-. DLL .-. API event
...- --.-. ._-.. VB API ...-. DLL . . _ . ... .. .-.
Exe --. ... -... .-. -. cracking .. ..
_- . -. Call stack -. Olly ...-. --.- _-.-._- -_ -.._-...-.
application -. .-.- ..- .. VB --- DLL ... . .-....._..-.
application -. ........_. .-. event handler .-_.._. event .- message .-- ._-..
_ . DLL . callback .-_.. ..__--. VB application --.-.-. resource
.- variable .- eventhandler .- .-...._- function .- _..-.
INFO: : VB -. stackbased _.. -. . -.- . -. . ...-...-- system
stack - .._ -. register - .._- function call ...- ...-.--
stack - . -... ._- _..-....-...- .- _ - - _.. -. VB . - ...-
application .--. interpreted ., pcode executable _.. compile -. Run . . .
instruction .-- runtime DLL - translate ., interpret -. --. . ._
pcode engine -. opcode .-- process - .. machine .._.. -. P-code instruction
.-- .._- operand ...-.-. stack . . . . .._ ...-.
. . Olly .. call stack - _-_-.. AltK, - ._. _-_-. ,
-.-. system, stack

,
INFO: : DLL (dynamic link library) -. -.....-- .._..._. _..-. .--
-. -. . . . -.- -.. ...-. ........_..-. exe
..-- device .- - .- . ..-. .. print - - . . printer - .- ..
-.,
INFO: : ..-._ . harddisk . . .. - - .. -..--. parameter
.-__- function call function - DLL . - .. . .. . -. DLL . . .
- function .- - ..... .-. - - - exe ..--. ..... .....-.
INFO: : DLL . .- -. exe ..- - RAM - -.-...--- RAM .. ...
-.. -. DLL - .. .. .. RAM ...- .. . _.. -. .._.. .
. . Microsoft Word .. .....- .-.. printer -.-- DLL .-.
.. .---. Print --... printer - .- - DLL .- .......
INFO: : _ _-_ .-. DLL . -. executable . -. _.. -. ... . -. . -_ ..
.-. -. . . - . EXE . .- - .. .. .. -. ._-. exe ..-.. -.
DLL - .....-. parameter .- ._-_.... -.
. ..-. . . VB -. - - . . . - .. -....-.. .-..
. . .. --. .-. . .-. .-. -.-.-.. ..- tool .-
-. ..- .. . - ._.. -. _.. _.. Olly - VB - .- _ . -.. . .. - . .-.
. - --. -. .. ..-. -....-... .. .-. assembly _.. translate -.
-. ..-..-.- .. ... ... -.-. . -. - .- _ . . - - _
..-.-.-. -. - install _ . .. ._- . -. .- . . -. -. . - -.
- - -..- - - - - _ . key -.- --.-.---. -. . .. ...
., Visual Basic _. .......... -. ...- crack _ .


-.-.-- .-....-..- hint - ..-. .-.- -.-. -- -.-. .-
. - - -. .. harddisk ID, _ . - - -. .... . . . . . .. . .. -. -
.- . . register .._. . .....
, Serial - ..._.
-.-. ..--.... register .._. . ...... -. VB . ..-.
DLL - API .. __--. .... .._-.-..--.-.
, __vbaVarTstEq
, __vbaVarTstNe
, __vbaVarCmpEq
, __vbaStrCmp
, __vbaStrComp
, __vbaStCompVar
. - . ,- .-. _ . . ....-. ._-. .. . API _..- __vbaVarTstEq -
.. ._-_ - _-..

,
,.. _..-.-.-. entry point .. Name module - _.. CtrlN -
. - , _ . .-. _. .. keyboard -. vbavartst -- vbaVarTstEq
.. - ...- . . ..
,
,- _-_... - .-. - ..- API .- -. MSVBVM60.dll ....-.
.-_... vbaVarTstEq - BP .- . - _-.. vbaVarTstEq - rightclick ._. Set
breakpoint on every reference - ..- Olly - breakpoint 88 .-. .- . - - -.

,
_ . run (F9) - .

,
., Visual Basic _. .......... -. ...- crack _ .


Olly -. ....-- vbaVarTstEq BP .. . . . .. - . ..-. -.. .. ..
. -. .- -. -. ..-..-.- . . .. F8 - . _ . . ._-_ ..

.,
VA 005BBD58 - CMP DI,SI -. .-.... .-..-. ... -..-_....-.
... jump _-_ ..

,
,- VA 005BBFC0 .. _.- oeiu564oqei97 -. -.-.- ..- serial ..
. .. -. _ ._ ...- .- _-_ .. ,

,
oeiu564oqei97 - ..._-_-_-.. Breakpoint .-...- ... ....-
Ctrl + N -._. Remove all breakpoints - ..,
, Register __.
Breakpoint .. .- .. .._ . -. - run F9, - ,-. _...

,
,.. register .-- ._..-..-. --- key -... -. key -
-. install . - .--_ .- - - - .- . - _ . _.. -. Register _-_..

,
., Visual Basic _. .......... -. ...- crack _ .


oeiu564oqei97- -__. OK - .-

,
,-. registration .._.._-.. _.-. - -. . -. - - _ .
_ ._-_ - _-..
, Registration .. .. .. _ .
-. - _ .. Olly . . Ctrl+F2 - .- _. F9 - . -. -.--.
.. -. nagscreen -. ._..-.-. Help menu - About - ..-.-. .._...
_ ,

,
._-. -.- SmartCheck .. ....._-__-..
, SmartCheck setting .. _ _ .
-. .-. Numega SmartCheck - .. ._-_ _-.. SmartCheck - VB -. .-
crack . debug . ._ ..-. ... . setting - .-. _ .. _
.... SmartCheck .. PC to Answering Machine 2.0.8.2 - .- ._....
Program menu - Settings - ..- ,

,
., Visual Basic _. .......... -. ...- crack _ .


,- Leaks - uncheck - Save these settings - .. _. Advanced
- . . -

,
,.. _.--. ....

,
..- . .. .... .- ,- . _.. -. . setting - _.-. _._ PC to
Answering Machine 2.0.8.2 - SmartCheck .. run _-_.. Run _....- View menu
-. Event Summary - ..- .,

.,
Event Summary window - - .-. - - . . - --.- ..-.
., Visual Basic _. .......... -. ...- crack _ .



,
View menu - Specific Events - -.-.-- ...-. events -_.. ...
....-.

,
,- .-...... Sequence Numbers - - .-. . ...-. ..-.
.-. .-. .. . . -. ..- .. . - .- .. _ . _-_ .. . .. - _ ..-.
.- . ..
--. - .- .. .- _-_ -. . .-. View menu - Show All Events -
. . -
, SmartCheck - serial - ._.
- .-. - . SmartCheck setting - __._..-. serial ._.- .-
- _-.. Event .-- _-_--.. -.-.-- - . .. - - .- - ....-.
.--. ,-. ..-- _._... scroll ._. _-_-_-..

,
--.- .--.-.-. ,..
,
,- _-_ - event .. 24734 .-. -..--. -.-. end program
.... ..- .. .-. event . . . ...- .-. - . . .. ......
-.-.----.- PC to Answering Machine 2.0.8.2 -. .. - ._.
.
., Visual Basic _. .......... -. ...- crack _ .



,
,- ..._-. . - - _-_ .. . ..._-. ..- - ._...-. .- ... . . -
-. . .-. - .-. - - Show Errors and Specific Events - ....

,
Show Errors and Specific Events - ..-... ,-. _... -.-.-
. ..-.- -. .- - _ .. . - -- key -.- ..-..-.- - .... API
.... ._-_-.. ,

,
,-. .... ,-. .-..

,
,.. _.--. ....-- API - ..- .-. ... . - .-. - .
API .-- ....-.... .---. ..- .-. . ... . .. ...-. .-.-
..._-. .. 2549 ..

,
._-. .... - _-_ .. . . ..- ._. _-_-. ... -....
_..- . ..._-. .. 2549 - ..-._. Details window . . _-_ - . ..-. .,- .
_. -.

.,
., Visual Basic _. .......... -. ...- crack _ .


.,. . _. -.-.-. - .-. - ..- serial SmartCheck -. ... registration
key - .-.....-. ...--. .--.
INFO: : VB -. .- . . antiSmartCheck _ ..- _ . ...-..- -. . - .-
-. ........_. NuMega SmartCheck . - .....- .. ...-. _.. -. - .-. . . ..-.
_...-. -...-. -.-.- Repair 0.6 -.._. SmartCheck - _ ..
Repair 0.6 - -- tool .-- _.-.
. PC to Answering Machine 2.0.8.2 - crack -.-... _. . . _ .. .. .._
_ . serial .-.- serial fishing .-. - .-. ._-.- .. .-..
.-...._..... .---. -.._-...-. serial fishing _.-. -.-- _-....
...._. debugger - - ..- serial --.-.._..-. Serial - -.-...-.
- - - . -. .- - -. . ..-. VB -..-- ._._. crack _-_ _-..
Crack .....- -..--.-. ReverseMe -. . . registration _ . -.- . ..
- freeware -.-._..- CrackersConvert 1.0 ....- ..-.. -. -
SND Team website -. download . SND Team -.- ..- ..- .- - . .
... _..-. SND Team download -_- Lena's Reversing Tutorial - 10 .- download
. ... --.-.._.. . ...- -. ... _..-. .
-.-. Lena151 . ...- -..._ _ . _.. -. Crack ... - tool .- -.-.
OllyDebug SmartCheck VB Decompiler Veoveo - _.. -. VB Decompiler -.-.
freeware _.._. www.vb-decompiler.org . . download . . -.
.-. ._ - .-. - crack _.- .-_-..
, ReverseMe1
... crack _-_ . .- ReverseMe1 -. _.. -. SmartCheck .. Tut.Reverse
Me1.exe .-._. run - ,-. _...

,
,.. _.-.-.-. nag screen _..-. - -........-. ..-.
._.. ...-.-. ReverseMe -.- -. register ..-. ..._-_..

,
,. . _. - Form1_Load -. .._- .-. MessageBox -. ,- nag
screen - _....-..-. .-_.... Registration ... - -. Form1_Load _ .
..-... ,- OK - . - ,- . _. ..
,
., Visual Basic _. .......... -. ...- crack _ .
.

,- Regcode textbox ... . 123456 - _ _-_ .. . ,- . _. . .


,
_ ,.... ,-. event .. - ..-.

,
- .-. - . View - Show All Events - ..- event ...- _...
Show All Events - ..... -._-_- event - . ....... . .- - event
.- ... .- - - - . . - event - ..-... .---. ........_..-. xxxxxx_
click .... xxxxxx -. button ._- .-. ...-. -. ...- -.-. button
.- ._ - ._. .. . - . commandX ..... -. X -.-. - _.. _ . -. -
. .- . -.
,- Command1_Click .... serial .....-.- .._... ._-. .
.- ......_-_-_-.. .......-. Tut.ReverseMe1.exe -.- ..-.-
- - - .. - _-.. .-.... ._. ,- -.-.-_..-.-. event -.
... _.. -.
,- Command1_Click -..-- ....- .- ,

,
,- -.-.-- ..----.- ...-. MsgBox .-.....- ..
-.-. ,-. _...

,
,-.-. BadBoy .-.._ ,- Text1.Text - ..-.-. -..
.-. -.. ._. - . View menu - Show All Events , - ..- . ,-. _.
..

,
--. .-. -.. .- - . - .-. - . .. .- _. .-.
., Visual Basic _. .......... -. ...- crack _ .


__vbaStrCmp - string .- ....-- ..-.
.. __vbaStrCmp(String: "xxxxxx", String: "yyyyyy") returns DWORD:0
... ,...-. DWORD - . .-. FFFFFFFF _...-. -...-.
string . . -. .- _ ,- Regcode textbox .... -.-.- 123456 -_
. -.-.--_- serial -- -. ...-. ,

,
.-. ._ 123456 ...-.-.-. I'mlena151
- I'mlena151 -. BadBoy Message .. . . . .. -. _.. -. .-. ._ Serial
-. -. . -. . _ .. ..- ..-.. -.-.-. serial - ..._-_-_-..

.,
.,-. I'mlena151 -_-- registration .._.-._-.. ._.-
messagebox ..-. .-....._. -.-.- -_-- serial -. -.---..
.- . -- .-.
- .-. - . nag screen - .....-. SmartCheck -. VB .. ....-
serial - ..--.-. .-..-. ... nag - .....--.-. -.-.-.. -
.-..- tool .- -. VB decompiler tool .- _.. -. ..._. VB Decompiler
Lite ., Pro - .-. -.-. VB Decompiler Pro 5.0 - ..-.
.-. ._ VB Decompiler - .-_-..

,
-.-. VB Decompiler .. -.-.- Tut.ReverseMe1.exe -.- decompile
..-. _.. -.
INFO: : Compiler .-.-.-. ..-.-- exe - _.. ._. . ..- -. Decompiler
-.-. exe - .- - . _ . . .- _.. _ _ ._. ...-. Decompiler -. ._..-
disassembler -..... _..-. Disassembler - exe -.-- assembley -_.. ._....
.. decompiler .--.-. -.-- highlevel -....-.._..- C/C++ ., VB -....-..
_.. ._. ...-.
,- _-_- VB Decompiler -. . - . .-. ..-. . .._
-.
., Visual Basic _. .......... -. ...- crack _ .


-.-.-. -.-- .._-_.. , Form1 .-...- . .
..- .-

,
- .-. _. .-. -. -..-.. -. .- . - . .-. .._ .. -.
,.. _.- mnuabout - About box mnuexit -.-. Exit Command2 -.-. Nag
button - .-...-. Form_Load -.-. nag Command1 -.-. Register button
- . - . . .-. . nag - ...- routine -. VA -. . . ... _-_ _-..
Form_Load . ..-. Command2 . . nag -. VA 402C17 .. ..-. ...-. --
.- - . . - . _ . _-_ -. Form_Load - double click .

,
, ..-. nag screen - .. .-...-..-.-.-. ..._ -..
.-. "Get rid of all Nags and find .." .- .....- .-

,
,-.-. nag screen . . VA 402C17 -.-. nag routine . .-.._
Tut.Reverse Me1.exe - -.-.- debugger .. .-_-.. ,

,
_. -.-.- ...- VA - -...-... tool bar - - .
,-. _...

,
., Visual Basic _. .......... -. ...- crack _ .


VA 402C17 - -- ,-. _...

,
,.. _.-.-.-. nag screen . VA 402C17 .. breakpoint .- . - -
_ . run (F9) - .

,
,.. nag screen _ . -. - ..- .. . -. _.-. VA 402C17 - PUSH
EBP ... . RET _-.. . -.-.- nag .... . .- ..- ..
_.. . .... _ . run F9, - .

,
Nag ..- ,.. ..-. ..... ,- Nag? - ._-_.. -..
...- . Nag screen ..-..._
., CrackersConvert
-. . .. .-.-. CrackersConvert -. _.. -. -. _- . . ..-. - .-. .
-. ..-..-..- - . ...-... .---. .-... SmartCheck . _ . . ...
. ._.. -. - .-. -.-. About . - .. ... . _.. -. About -. register button -
. .,-. registration box _...

., Visual Basic _. .......... -. ...- crack _ .


.,
_ register button - .--.. ,- . _. -.

,
INFO: : .. _--- registration code - _...-. - .-. -. 47806
-..-..-. _..-.. _..... .-.._ ........_. -..--. registration
code - ...... hex code _.. ._...-. 47806 - hex code . ._. . -
BABE _.. . ..-. . - . -..

,
.,- Validate - .- ,-. _... - .-. - . - .-. - ..
-.- .-__..--- CrackersConvert -.- --..

,
.......-. -.-.-. -.-- ... Overview window - ,-.
_-_-..
Len(String: "rhythm") returns LONG:6
. .- "rhythm" string ......--,._ ._..._
Mid(VARIANT:String:"abcdefg",long:1,VARIANT:Integer:1)
. .- "abcdefg" .. .... .- _ . ... .- . ._
Mid(VARIANT:String:"rhythm",long:1,VARIANT:Integer:5)
. .- ... ..-. .. ...-. .. . ... -. "rhyth",
Asc(String:"T") returns Integer:84
. .- "T" ..-.._..... 84 - .._
Asc(String:"r") returns Integer:114
. .- .....-. "r" .. - . ._.. ... 114 - .-.
Len(String: "47806") returns LONG:5
. .- "47806" string ......--, ._ ._..._
, ..- . ...._-. .-.-. BadBoy
., Visual Basic _. .......... -. ...- crack _ .


Len(String: "47806") returns LONG:5 .- ..._-..-. serial ....--
.. ...-. .- ... ... -.._-. serial - ..... -.-.-. BadBoy
...- serial - -. . .. .. . . -. ._-.. LenString: "47806", returns
LONG:5 - . . - _ . Show all events , - .- ,-. _...

,
,- _-_ --..-. -...--.
__vbaVarMul(VARIANT:String:''114", VARIANT:Integer:20) returns DWORD:13F474
- -.-..._ ....- ._..--.
__vbaVarMul(VARIANT:String:''1", VARIANT: String:''2") returns ..
. .- - _. ._. .- ._
__vbaVarMove(VARIANT:Double:2280,VARIANT:Empty) returns DWORD:13F48C
-.-. 2280 _.. -.
__vbaVarCat(VARIANT:String:"REG"VARIANT:Double:2280) returns DWORD:13F474
_ . REG2280 _..... REG . .-.
__vbaVarCat(VARIANT:String:"REG2280"VARIANT:String:"CODE") returns
DWORD:13F464
_ . REG2280CODE _.. ... CODE . .-.
__vbaVarTstEq(VARIANT:String:"47806",VARIANT:String:"REG2280CODE") returns
DWORD:0
_.. -.-.- -_-- serial ...-.
__vbaVarTstEq(VARIANT:****,VARIANT:****) returns DWORD:0
. .- __vbaVarTstEq - variants .- .... .._-. --. . - .- -.
_ DWORD - . .-. . __.. _ . ._ .-. FFFFFFFF _.. .. ._-. EAX -.
FFFFFFFF _.. -. __vbaVarCmpEq . -.
. -.-.-- serial -_ User name - rhythm _.._. serial -.-.
REG2280CODE _.. -.

,
,- Validate - .-

,
., Visual Basic _. .......... -. ...- crack _ .


. -.-.- register -. .._._ ,
INFO: : -.-. registration .-..-- cconv.$$$ . cconv.ccc ... ..-. _.
-. .- . . - - .- - - _ ._ .. -.
.-. ._ ..- ReverseMe -.-.- .._-_..
, ReverseMe2

,
ReverseMe2 - Olly .. ...-. ,.. .-.. .. SmartCheck .. ..-
Olly .. -.._-....-. ... . .. . -.-. ReverseMe2 - SmartCheck . .
. -. ... . .- . SmartCheck -.-. ReverseMe2 - .--.
- . ..-. ._-. -._..-..-. ... Olly . . .. -. ReverseMe2 -...
AntiSmartCheck _ .... ..... ..... . ReverseMe2 -. SmartCheck -
.- _. - -. SmartCheck - - . - . _- .... -. ._....-. _-_-_-
..
Debugger window .. rightclick ._. Search for . All reference text strings -
. . - ,- . _. .. ReverseMe2 -. SmartCheck - .-. - - .- - _-_ -
_-..

,
,- VA 00404525 .. NuMega SmartCheck .-.....- .--. VA
00404525 - double click ._. -- .._-_-.. ,

,
ReverseMe -. NuMega SmartCheck .-.....-.-. ._-.. ....
- .-. - . _.......- ._. ... .-.._.- _.. Debugger window -
VA 00404525 .. rightclick ._. Follow in Dump - Immediate constant - ..-

.,
.,-. _.- -.._. . - .. .- . ._ . keyboard - -._--- .....-
_
., Visual Basic _. .......... -. ...- crack _ .



,
.,- 4D (M) ..- ...._. keyboard - B - .-- ,-. _.-.

,
,.. OK - . - - ,- . _. -. ..- 43(C) .- .......
_..... ......
,
_ . rightclick ._. Copy to executable file - .. ,- _...
,
,.. rightclick ._. Save file - ..- _..-. -. _- - - ._ . - . . .
- -. .-. - .-.- ...--.- SmartCheck .. ._ -._... .-.
, -. _._

,
antianti _._.- SmartCheck _ _.. tool .-_..- Olly ImpRec LordPE
- . . . ._. -. ReverseMe2 - register _-__-..

,
., Visual Basic _. .......... -. ...- crack _ .


- .-. - . User name Registration code - -_... Register button -.
disable _...-. ._-. -.-.- register . _...-. ReverseMe -. -.
-..- ...-...- ... -......-. ,

,
._-. - .-. - . -.- _-_ . .. ,- ....- .._-_..

,
... . -. - .. . - - - - .-. .- -. ... ,- Text2.Text
- . ._-_ .-. -.. ..- - .

,
. ,- ....._-_-_-.. ReverseMe -.- -. .-.. register
. ......_-. . . -.

.,
.,- Text3.Text "UNREGISTERED" (String) - ....- .._-_..
AppActivate(VARIANT:String:"NuSega S...", VARIANT:Missing) fails .- .....-
.-. NuSega S... .-.....- ...--. .-. _. "Text3.Text "UNREGISTER-
ED" (String) .- .....- _-_-_-.. -.-. - ... _ . .. -. UNREGIS-
TERED string .-.._.....-. .. .._ .... -.
., Visual Basic _. .......... -. ...- crack _ .



,
,- _-_- __vbaVarTstEq(..) - -.- .... __vbaVarTstEq(..)
- . . - - ,- . _. ..

,
. . ....- . .... - . ._-_ ..

,
,- Dir(VARIANT:String:"reginfo....",FLAGS:00000000) - ..- ,-.
_...

,
ReverseMe -. reginfo.key .-.- ...-. __vbaVarTstEq(..) -. reginfo.key
..- ....-. . UNREGISTERED .- .....- main window . .__ . register
.- . . -.- - .-. - . reginfo.key .- .-. ._-. reginfo.
key . - . - . - .. Notepad -._. .- reginfo.key ._ . . . - _ . Reverse
Me2 .- SmartCheck .. _..._-_

,
. ,- . _. .. Register _-_..
., Visual Basic _. .......... -. ...- crack _ .
.


,
.-. ._ .-. register ....- . SmartCheck .. -..-...._.....
. _-__-..

,
,- UNREGISTERED . - ........ . Key File found .-.....-..-. .-..
.-. ._ -. serial - .. - - .- - _ . ._-_ ..

,
Left(VARIANT:String:"rhythm",long:1)
. .- ._ .. ... .- . -.
Asc(String:"r") returns Integer:114
. .- ASCII "r" - -.__-.. 114 _.. ._. . -.
Mid(VARIANT:String:"rhythm", long:2, VARIANT:Integer:1)
. .- ._ -....- .-.
Asc(String:"h") returns Integer:104
. .- ASCII "h" - -.__-.. 104 _.. ._. . -.
_ ..-. -- ..- .. . .._. ._. . -. _ ..-. - - ..- .. .-
. . - -. 114 + 104 + ..
Mid(VARIANT:String:"11410412...", long:2, VARIANT:Integer:10)
-. event ...- _-__-_.. Show all events ( ) - ..-
., Visual Basic _. .......... -. ...- crack _ .



,
,. . - - ..- .. .-.- .- .-. .._- .-.- Mid(VARIANT:
String:"11410412...", long:2, VARIANT:Integer:10) ..._-.. -. -. - ... .-.
.._..- ..... .-. . ...-..-- 1410412111 .. _.. -.

.,
_ . .,- .- _-_
__vbaVarSub(..) -.-. -. - . - -. _ . __vbaVarTstEq(..) --.- ...
-. ._-. - .-. - . .... - _-_ . ._ . . ..- . -

,
,- _-_-.-. __vbaVarSub(..) -. __vbaVarTstEq(..) -.. .. -. .-
-.

.,
... ,- __vbaVarTstEq(..) .. --. serial ..- ....-- double.dbval
_.. ._. . - -. .- -. --. .-. 1410412111 - ....-- ._..--.
._-. --. serial .. -.

.,
-.-. -.-.- -_--._ ... .- ASCII _.. ._. .-.
_ . .. ..- - _ .- -. ..- serial . - .. .- ..- .. . .._..- -. .
._..- .-. - serial - _-...._-_-_-..
., Visual Basic _. .......... -. ...- crack _ .



.,
-.-.- serial -. .....-. -...-. Register button -. enable _ _..
.

.,
.,- Register button - . . - - . . .,- . _. -. Register -.
.._...._
-. VB Decompiler - .- -.._-...-. VB Decompiler decompile
. . ._ - _

.,
.,- . . _....- ReverseMe2 ..-..-.- . . .. Form_Load -
..-._. scroll _-_ .,-. _...

.,
Command1_Click - ..-._. scroll _-_ .,
.,
., Visual Basic _. .......... -. ...- crack _ .


... . - .-. . Veoveo -. - . - .- -. tool -. -. button -..
enable/disable .-. _-_

.,
Register button -. disable _.. .-. Veoveo -.- .-

..,
..,-. Veoveo - right-click ._. Enable Buttons auto, - ..-

.,
.,- _-_- Register button -. enable _.. ._ -. ..- . . . -.
.- . . --. .-. Register button -. enable _.. -.-.- register . . .- - - .
-. . .-. serial . .. - -. - ..
(10) VB P-code y&dk*&r fr sm;u dkcrack v kyfjci f;
INFO: : P-code .-.-.-. execution ... interpret - -_..-. P-code
.- - - .-. - . - - .- ...- - -...._ . - low-level - .- _.. _. . -.
Java -. .- ... virtual machine . VB p-code .- ... virtual
machine -. Virtual machine ... .- p-code .-- native code .- _.. ._. . ..
. . ._.. -. VB . ..-. . virtual machine -. MSVBVM50.DLL MSVBVM60.DLL
. .- . . ._--. DLL ..-.. VB application .-- .._.- API .. . -.
.._ Windows API MessageBox() ...--- rtcMsgBox .._-.-
function .- .._.- function .-- p-code . compile ._. ._-....-
function .--.-. native code . compile . -. P-code - .._ _.-.
.... -. ...--.-. ....-...-. P-code .--. ........_. stack ...
. -. ._-. instruction ....-. stack -. . - operand .--._.
.- result - stack .. ...-. C/C++ -. .- . ..-. p-code . compile
#pragma - . .__ . link . . exe . 9KB ..- - run-time engine ..
-. - _ . ... - -. debugger .--. p-code - debug ..- .._.-
-.
., Visual Basic _. .......... -. ...- crack _ .


P-code ._-..- ....-...-- p-code pack ..- Engineering Power
Tools - crack _-_ _-.. Engineering Power Tools 2.0.4 - http://www.pwr-tools.com/
-. download _. install - _. ept-2002.exe - Olly ._-_

yHk(90)
,. . _. - - .. Olly - p-code ..-- debug ... ._...--
._-..- . . -- . -. ._. ,- ThunRTMain .-. VB main() function -
. -._.. -. --. VB . .- - packer -. pack .. . . ThunRT
Main -._. -. dump . . ._.. -.
ept-2002.exe .- Olly ... P32Dasm 2.5 . .. _-_ ,- . _. ..
File: C:\Program Files\Engineering Power Tools - Plus Edition v2.0.4\ept-2002(ori).exe
P32Dasm v2.5
VB6 Application detected ... PCode

MAINFORM Events:
191. plus_options_show
192. plus_options_hide
193. plus_options_enable

Page_Setup Events:
2. Setup_calc

Pneumatic_cylinders Events:
11. metric_calc
12. inch_loader
13. metric_loader

Shear_Keys Events:
24. option_set

Volumes_of_Solids Events:
52. sphere_calc
53. spherical_sector_calc
54. spherical_segment_calc
55. spherical_zone_calc
56. spherical_wedge_calc
57. hollow_cylinder_calc
58. hollow_sphere_calc
59. torus_calc

Hydraulic_cylinders Events:
12. metric_calc
13. inch_loader
14. metric_loader

Splash Events:
37. pchk

shape_generator Events:
1. generate_rectangular_tubing
2. generate_circle
8. generate_hollow_circle

GearCalc Events:
17. metric_gear_calc

Beam_Calc Events:
9. Selector
10. selector_SI

Psychro_2 Events:
1. log10
., Visual Basic _. .......... -. ...- crack _ .


2. calc_vapor_pressure
3. calc_vapor_pressure_2
4. calc_dewpoint
5. calc_enthalpy
6. calc_relative_humidity
7. calc_specific_volume
8. calc_humidity_ratio
9. calc_humidity_ratio_2
10. calc_atmospheric_pressure
11. calc_wet_bulb
15. calc_rh
17. calc_dp

Structural_Tubing Events:
12. combo_loader

Enclosure_Cooling Events:
15. Solve_Open_SI
16. Solve_Closed_SI

Duct_Size Events:
26. calc3

Plate_Deflection Events:
10. solve_SI
yHk(91)
-. ..-..-.- . . .. ept-2002.exe -.- ,

yHk(92)
,. ._. -.-.-. UNREGISTERED .-..-._..-. ..-.-.- ,
- ._. ..

yHk(93)
,. . .- _. - .-. - .-. - . Standard Edition ., Plus Edition -
.._... .-. ,- OK .. - .-. ,- . _. ..
., Visual Basic _. .......... -. ...- crack _ .



yHk(94)
,-.-. -.-.- - _ - - .. - . ._.-.

yHk(95)
._-. ,.._.--. function .-- ..._.-. -. ..-.
.-.- ...._. P32Dasm -_..._-.. P32Dasm - References Procedures -..
- ,

yHk(96)
,.._.-.-.-. -...- procedures .. .

yHk(97)
Engineering Power Tool -... splash screen .. register _..._..- .....-. .-
_. ... ._-. ,- 73.22 Form.Load() - . . - .,. ..- . . ..
Splash 73.22 Form.Load()
0016DF88: 6C ILdRf param_8
0016DFF4: 1B LitStr: "http://www.pwr-tools.com"
0016DFF7: 21 FLdPrThis
0016E18C: 1B LitStr: "\pwrtools.ini"
0016E18F: 2A ConcatStr
0016E21D: 1B LitStr: "USER NAME = "
0016E220: FB30 EqStr =
0016E26F: 23 FStStrNoPop var_108
0016E272: 1B LitStr: "REGISTRATION = "
0016E275: FB30 EqStr =
0016E277: C4 AndI4 And
0016E2C7: 1B LitStr: "REGISTRATION CODE = "
0016E2CA: FB30 EqStr =
0016E319: 23 FStStrNoPop var_108
0016E31C: 1B LitStr: "PASSWORD = "
0016E31F: FB30 EqStr =
0016E371: 1B LitStr: "SOFTWARE KEY = "
0016E374: FB30 EqStr =
., Visual Basic _. .......... -. ...- crack _ .


0016E3BA: 3A LitVarStr: "<No Value>"
0016E3BF: 25 PopAdLdVar
0016E3C0: 1B LitStr: "User Name"
0016E3C3: 1B LitStr: "Settings"
0016E3C6: 1B LitStr: "EPTools"
0016E3C9: 0B ImpAdCallI2 GetSetting()
0016E3CE: FDB7 ImpAdStStr
0016E3D2: 3A LitVarStr: "<No Value>"
0016E3D7: 25 PopAdLdVar
0016E3D8: 1B LitStr: "Registration Code"
0016E3DB: 1B LitStr: "Settings"
0016E3DE: 1B LitStr: "EPTools"
0016E3E1: 0B ImpAdCallI2 GetSetting()
0016E3E6: FDB7 ImpAdStStr
0016E3EA: 3A LitVarStr: "<No Value>"
0016E3EF: 25 PopAdLdVar
0016E3F0: 1B LitStr: "Software Key"
0016E3F3: 1B LitStr: "Settings"
0016E3F6: 1B LitStr: "EPTools"
0016E3F9: 0B ImpAdCallI2 GetSetting()
0016E449: 7A ImpAdStI2 param_26
0016E44C: 1B LitStr: "Registered to: "
0016E44F: 76 ImpAdLdI4
0016E567: 04 FLdRfVar var_18C
0016E56A: FC22 CI4Var
0016E56C: 05 ImpAdLdRf
0016E56F: 4D CVarRef: var_AC
0016E574: 04 FLdRfVar var_98
0016E577: 0A ImpAdCallFPR4 Left()
0016E57C: 04 FLdRfVar var_98
0016E57F: FCF6 FStVar var_19C
0016E583: 04 FLdRfVar var_17C
0016E586: 04 FLdRfVar var_19C
0016E589: FB33 EqVarBool =
0016E58B: 1C BranchF 0016E60C
0016E58E: F4 LitI2_Byte: 255 0xFF (True)
0016E590: 7A ImpAdStI2 param_53
0016E593: 1B LitStr: "Show"
0016E596: 1B LitStr: "Plus Options"
0016E599: 1B LitStr: "Settings"
0016E59C: 1B LitStr: "EPTools"
0016E59F: 0A ImpAdCallFPR4 SaveSetting()
0016E5A4: F4 LitI2_Byte: 255 0xFF (True)
0016E5A6: 7A ImpAdStI2 param_26
0016E5A9: 1B LitStr: "Registered to: "
0016E5AC: 76 ImpAdLdI4
0016E5AF: 2A ConcatStr
0016E5B0: 23 FStStrNoPop var_108
0016E5B3: 21 FLdPrThis
0016E5B4: 0F VCallAd
0016E5B7: 19 FStAdFunc var_88
0016E5BA: 08 FLdPr var_88
0016E5F6: 0F VCallAd
0016E5F9: 19 FStAdFunc var_88
0016E5FC: 08 FLdPr var_88
0016E5FF: 0D VCallHresult PictureBox.Set_Visible()
0016E604: 1A FFree1Ad var_88
0016E607: 10 ThisVCallHresult
0016E60C: loc_0016E58B
0016E60C: loc_0016E4C7
0016E60C: loc_0016E4AF
0016E60C: 75 ImpAdLdI2
0016E60F: F4 LitI2_Byte: 0 0x0 (False)
0016E611: C6 EqI2 =
0016E612: 1C BranchF 0016E963
0016E615: F3 LitI2: 3800 0xED8
0016E618: EB CR8I2 Int(number)
0016E619: 37 PopFPR4
0016E963: loc_0016E612
0016E963: 13 ExitProcHresult
yHk(98)
.,-- .- - .. ..._-_ .. - .-- _.... _.-..-.
., Visual Basic _. .......... -. ...- crack _ .


0016E589: EqVarBool = var_17C . var_19C - _ ._ .. ...._ CMP . - ._
0016E58B: BranchF 0016E60C = _ 0016E60C ....._ BranchF (1C) ._ JE
. - ._ BranchT (1D) ._ JNE . - ._ Branch (1E) ._ JMP . - ._
.,-- .- - _ . . . . .. . .. VB Decompiler . ... _-_ - -
,- . _. ..
If ((Len(MemVar_5C103C) > 1) And (Len(MemVar_5C1038) > 1)) Then '56E60C
For var_168 = 1 To CVar(Len(MemVar_5C1040)): var_148 = var_168 'Variant
loc_56E4F8: var_110 = Mid$(MemVar_5C1040, CLng(var_148), 1)
If (var_110 <> "-") Then '56E513
loc_56E510: var_138 = var_138 & var_110
End If
Next var_168 'Variant
loc_56E534: MemVar_5C10C4 = Unknown_503BF8(MemVar_5C1038)
loc_56E53C: MemVar_5C10C4 = Unknown_4FD768()
loc_56E555: var_17C = CVar(Unknown_516920(Unknown_50507C(var_138))) 'Variant
If (var_17C = Left(MemVar_5C103C, CLng(Len(var_17C)))) Then '56E60C
loc_56E590: MemVar_5C1046 = &HFF
loc_56E59F: SaveSetting("EPTools","Settings","Plus Options","Show")
loc_56E5A6: MemVar_5C1044 = &HFF
loc_56E5BD: regbox.Text = "Registered to: " & MemVar_5C1038
loc_56E5D7: regbox.Forecolor = 0
loc_56E5EB: regbox.Fontbold = 0
loc_56E5FF: regpanel.Visible = 0
loc_56E607: Call Unknown_5000EC(MemVar_5C1044)
loc_56E60C: ' Referenced from: 56E4AF
End If
End If
yHk(99)
P-code -.-- prefix -.-. ..- - ._.. -. ,
Ad Address
I# Integer
Imp Import
Ld Load
Lit Literal (ie Hi, 2,8)
Mem Memory
R# Real
Rf Reference
St Store
Str String
V Virtual
DOC Duplicate Opcode (Redirect to another opcode)
yHk(100)
--. .-. EPT - - .-. - register .....- registry -..-_. .....
-. Register ... offset 0016E60C . .-. . ... ._.. -.
._-. -.-.-. conditional jump .-- NOP ..... ._ NOP
.... . VA 56E589 ...- Olly ..._-_.. ,

yHk(101)
,.. hightlight _...-...-- NOP ... ... P-code ...-. NOP --
opcode - 90 .- - - . 21 (FLdPrThis) _..-. ,

yHk(102)
,-.__..-. -.-.- patch -.- ...__..-. _.
-.-.- patch ...- run _-_ ,-. _...
., Visual Basic _. .......... -. ...- crack _ .



yHk(103)
-.-.-.-. regname.reg ... , -.__. registry - merge -
-. -.._-._..-.-.-. .,--- _-_- ...
REGEDIT4
[HKEY_CURRENT_USER\Software\VB and VBA Program Settings\EPTools\Settings]
"User Name"="Myanmar Cracking Team"
"Registration Code"="Don't Hate the Crackers! Hate the C0dez."
yHk(104)
. .-. ,- . .- . ._.. -.

yHk(105)
- .-. ._ -.-.-. key ..- -..._ register _ . Key . -. .
.-. . - . - .. .. _-_ . _- .. -.


., Delphi _. .......... -....- crack _ .
.

tcef;(17) - Delphi jzifh a&;om;xm;aom y&dk*&rfrsm;udk crack vkyfjcif;



_ . - .. .- .- Visual Basic .......- -. .- - -. crack ..-.
._ -. -. . ..-. Delphi -. .- .- _ - _-.. ... . .- .-. .-. ...
...- Visual C++ Borland Delphi Visual Dot.net -.......-._-.. ._...-.
.- ._-.. Delphi -..-- -. crack . . -. - .-. . ._.
._ --. .-. Delphi -..--. Visual C++ -. .- ..-.-..
.. -. ,
-. crack . . .. ..- -. -.-. File Recovery Angel 1.13 _.. -.
... . -. . .- . - - . .- - _ _ ... .. . ..- - _.. ..- -. -. _.. _ .
. ._-.- . - -. www.filerecoveryangel.com .. . download ..
-.
.-. ._ - .-. - . -. - crack . -. ..-..-....- .
.. File Recovery Angel -.-

,
File Recovery Angel -._. Help menu - About -..-- ,-. _.
-. - .- . -. - recovery . _- ....- ,- ._. -.

,
..-..._-.- recovery . _- .....-. ,- . _. _ -.

,
MessageBox .--.-. .....-- . . .. . .....- MessageBox .-
.-. ._ -. - -. ......-. .._-__-.. ,

,
., Delphi _. .......... -....- crack _ .



,-. PEiD .. ...- .- -.-.-. -. - Delphi 4.0 ., Delphi 5.0
.......-. . - ._-. . Version ---.-. Delphi -....-. linker version
- _-_ _ . _... . .. - .-. - - - -.-. _-. .. .. _
FileRecoveryAngel.exe .- Olly ..._._-_.-. entry point - ,-. .-
..

,
- ....... F9 (Run) - . - _ . Option menu - Register(R)
- . ._ . register ._. ,

,
,-. Registration Name Registration Key - - - _ - _ . Register button
-..- ,-. _...

,
,- "Register False" . - .....- . - .._ . Olly . . text string ..- _.
text string .- .- .,

.,
.,- _-_ - BadBoy message . VA 00488FEA . jump -.- .-...
..- .-. .- . . ...... .-. jump - ....- ,-. _.-.. F12
(Pause) -._. -.-.- .- _. Alt+K (Call Stack) -._. Call
.- - -. -... ... . -. _-_- ,

,
., Delphi _. .......... -....- crack _ .


,.._.. Olly -. Call .--.-_.--- --.-..._. .-.
._-.. -.-.-. System Stack -_-__. ,- error MessageBox - -. -.
.. .-. . -. _-_ . ._.. -. Delphi -..-- crack .. . Call Stack - System
Stack - _...-. Delphi -..-- crack ... .....- ..-_...
-.-. FindWindowA API - .-. -.._-. . .-. Delphi -..--. --- class
._ ., title .- window -..,

,
,-.-. ,- pause ...... System Stack . . _. - ...
INFO: : Delphi -.-- Olly . . disassemble - _. - ...-.-. _ ._ ...
.. ..-. Comment info .- - _ ..-..- . ., -.._-. . .-. Olly - call
.- backtrace ._ Call Stack . . -..- . ._.. ._ . - - _ .. - ..
...-. ._-.. Delphi -..-.. routine -.- -. call -... .-. .
System Stack - .._-. System Stack -. return address -_-__. call .-
-.-.- .-..-._-.-. .._.. - . _.._ .. .-. .-. ._
-.._-...-. Olly - routine --- address .- ._.
INFO: : Delphi -. global variable .- local variable .-- pointer _.. reference -.
Global variable .--- [REG+Constant] -.._. local variable .--- [REG-Constant]
-.._-. REG -.-. register - . -. . -.-.-. Olly -. CALL DWORD
PTR DS:[EBX+100] . backtrace ..-. ._-.. EBX -..._..-.. pointer
---..-.._....._. Olly - call - backtrace .-.-. -. Delphi -.
.- _- - . . --. _...- _.. -. _..-....-...- . . . . _- .- . ...
Delphi ....- ..--.
INFO: : -. _ .. .-. . . . ...-. .-. - .-. - - .-. .- - -.-. Delphi
-- tool -. .. tool -.-. DaFixer DeDe DeDe -. Borland Delphi
-..--- .-...- disassembler -. _.. -. DeDe -. DelphiBuilder -
compile ..- exe ..-- analyze ... _.- -. -. _.. _ . . dfm
..-...- _...-. dfm . .- - Delphi . . . _ .-_ ._.- . -. DeDe -.
string .- import ..- function call .- classes methods call .- unit - component
.- Try-Except Try-Finally block .- reference ..- -.-...- - ...-.
. . dfm . pas . dpr ..-- Delphi project . -. - . - .. -. Tool
-... .._.--. DeDe -. debugger .- - - - - DeDe .. patch ..-. ._..
. - . -. _.. _.. Olly - . . .-. -. DeDe 3.50.04 build 1635 - download
DOI DSF . .- .. DeDe - .- - ... ...- -.-. DeDe dede_doc directory
..- . . -. DSF = = DeDe Symbol File, DOI == DeDe Offset Information File,
INFO: : DeDe configuration - .- _ . .._- .- - -.-. exe .-.- process
... .-- symbol ..-- load -..-.... DOI/DSF ..-. DeDe -.
.... call sequence .-- ._..... .-.._.... DOI/DSF . .- - ..
_- .-.

,
., Delphi _. .......... -....- crack _ .


,-. DeDe Options menu - Symbols -.._. Delphi 5.0 .- vcl5.dsf
.-...- Delphi 7.0 -..-- analyze ....-. vcl7.dsf . - . .. .
DOI tab -._. D5.doi .-... _..-. ,- Process button -.
,
,- Process button - . - .-. ,- . MessageBox .- .. . ..

,
No button ....- ,-. _...

,
,- Procedures tab -.- . File Recovery Angel -.._- procedure
.- - _. .. TFrmMain -.-. -. .--.. Main menu . procedure
TFrmAbout -.-. About menu -.--_... Form (dialog box) TFrmRegister
-.-. - .-. - ..- Registration Form TFrmRegister - . . - _..- . ._. -.
-.-. Olly .. -..._..- routine ..- ImgRegistereClick -..- ,
-. .-..

,
VA 00488E34 -.-. Registration routine ._.. -. ..- - _ ._ ...- scroll
._-_-.-. ,-. _...
,
., Delphi _. .......... -....- crack _ .


,-.-. registration key -.....-..- _.- Bad message _.. -.
TFrmAbout -.-. . .-... .._-_ --..-. DeDe -.-- -.-.
--. ,..--_.- _.._ -.._-...-. registration routine address
.- .- - Registration routine address ._..- VA 00488E34 - . - .._ . Olly ..
Ctrl+G ._. -_- ,

,
. DeDe - - _ ,- . registration routine .-..--..
registration key -..-..- _-_-_-.. VA 00488E34 .... breakpoint .-.-_.
register _-_ .,

.,
.,.. Register button -..-.-. -.-.- breakpoint .- . - ..- VA
00488E34 ..- ..- ... ,- VA 00488EFA - ..- - F8 (Step Over)
-..

,
,- VA 00488EFA -. registration key --..- routine -. _.. -.
Registration form Registration name - -- "Myanmar Cracking Team" -- -
"CA75FC30F7AD6E7C969032F175560906F79B9EE94E93D2D4302B92" .- key - - ..
_. EAX . .. . .-. VA 00488F13 ..- CALL -.-. EAX - key EDX . .. . ...-
"4.10.1979" -- ...-. ..-. registry "IsRegister" .. "On" . _ .. . .... .
_.. -. . .. .-. .- . ... ._.. _ . VA 00488F3F ..- BadBoy ("Register False!")
. . .... .. . .. . ._.. -. ..- . .-. . . -..- . . -. . ..- _
-.
., Delphi _. .......... -....- crack _ .


Olly --_. File Recovery Angel - ....- _. Option menu - Register
(R) -.._. register - ,

,
,- Register button - . - .-. ,- ._. . .

,
Help menu - About -..-.-. ,-._... --..-. File Recovery
Angel -.-. registration name .... ...-...--__ .-...-.
._-.. "Myanmar Cracking Team" ... "Myanmar Crac"_-.

,
. - ... .-.-. . - - key - . - _ VA 00488F46 - BadBoy . . ..- JE -
NOP _ .. . register ... _ . -... .. _. .. -.._-. . .-. -. -.
.--.. registry - "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\
Windows\CurrentVersion\Frareg" "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\
Windows\CurrentVersion\Unicode" ... . ..- - Name Unicodekey --.-_. ...
--.. ....-..-. ,- TFrmMain -._. _-_.-.

,
,- FormCreate -. Main menu -.-... ........-. Virtual
address (00491A00) .-_-. -.-...-. .._-_
., Delphi _. .......... -....- crack _ .


-. . ..-. - .-. . _--..-. _ -. Teleport Pro 1.61 . ...
- .- . . keygen .....-.- .-... Keygen routine -..-. .-...
--..-...-.._-. .- - -. - .-. . -.-. keygen ..-.
....-. . -. -. ._-. keygen ...- key - ..- - ... -
_--.. .- _.-.

,
,- ..._-_ VA 00488EFA . . . - _ - - user ._--_. serial
- - .. - -. serial - stack segment .......-._..-. _..-. stack -.
EAX . ._. .. - _ . EDX . . - . - _ - - serial ...-._..-. Serial
. . -. ._ .-. Badboy .. ..-....._..-. ,

,
,-_-_ VA 00489184 - "Register False!" .-.....- EAX - ._ - _ .
serial .....-.._ Badboy message - _.-._.. -. ,

,
"Register False!" . - ........ - .-. - - _ - - user name - .- - serial
- _. .. . ..-. .- ...
.-. ._ _.. . _._._-...._-_.. ,- VA 488FFB ... . MOV
EAX, 489184 ... MOV EAX, DWORD PTR SS:[EBP-C] __. .-...._.-
.-- --. serial ...- stack .......-._-.. ._. -.. - , - .-
-__....--.- ._. register _-_- ,

,
-. .-. rhythm . - ._ register _-_..

.,
., Delphi _. .......... -....- crack _ .


rhythm . - ._ register _-_- .,-._.-.
..- . .-. . . . ..-_-. .,.._.- key (0415BFA8C..)
-.-. rhythm . - user name - - -. -- - - _ . - .. - - serial key _.. -.
key -.-.._. ..--._-. register -.. -_- registration ..._...
_........ ,

,
,- register button -.- ,-. _...

,
Help menu - About -..- ,-. _.-.

,

t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 266 -

tcef;(18) - Java jzifh a&;om;xm;aom y&dk*&rfrsm;udk crack vkyfjcif;
' Dw p fc gr Sma w mh Java e JUa & ; x m; w Jh y & dk* & r fa w Gu dk crack Mu n fhy gr , f/ Java y & dk* & r fa w Gu dk crack & m
r Sm t jc m; y & dk* & r fa w Ge JU o a b mw & m; c si f; r w ln Dw Jht w Gu f x n fho Gi f; a q G; a E G; & jc i f; jz p fy gw , f/ Java y & dk* & r f
a w Gu dkcrack r v ky fc i f Java Virtual Machine (JVM) t a Mu mi f; t e n f; i , fa w mho dx m; z dkU v dky gv dr fhr , f/
( 1 ) Java Virtual Machine (JVM)
Java b mo mp u m; r Sma w mh u k' fa w Gt q i fa jy a p r Iu dk t " du x m; y gw , f/ Java source u k' fa w G[ m
b , f OS r Smr q dk t w lw ljz p fjy D; javac command u dkt o Hk; jy Kjy D; compile v ky fy gw , f/ Java source u k' fa w G
( .java extension y ga o m & dk; & dk; p mo m; z dki f) u dk bytecode v dkUa c : w Jh intermediate language (IL) b mo m
p u m; t jz p f compile v ky fw Jht c gr Sm .class extension y gw Jhz dki fw p fc ku dk & & Sdr Smjz p fy gw , f/ ' Dx Gu fv mw Jhbyte
code ( o dkU) class z dki fr Sm JVM instruction a w G? o a u Fw Z , m; w p fc ke JU t jc m; t c su ft v u fa w G y g0 i fr Sm
jz p fy gw , f/
Bytecode a w Gu a w mh OS w dki f; t w Gu f w ln Da e r Smjz p fjy D; JVM & JUt v ky fv ky fy Hku a w mh a t mu fy g
t w dki f; jz p fy gw , f

y Hk( 1 )
JVM & JU architecture u dka w mha t mu fy gt w dki f; & Ijr i fE dki fy gw , f

y Hk( 2 )
JVM w dki f; r Sma w mh class loader subsystem w p fc kp D& Sdjy D; o l[ m class a w Ge JU interface a w Gu dk
u l; w i fz kdUt w Gu f mechanism w p fc kjz p fy gw , f/

Input File
.java
Compiler
(javac)
Output File
.class
JVM
CPU
Software Developing
Software Execution
Copyright White Cracker (Myanmar Cracking Team)
Class loader
subsystem
Execution
Engine
Class files
Method area Heap Java stacks PC registers
Runtime data areas
Native
method stack
Native method
interface
Native method libraries
Copyright White Cracker (Myanmar Cracking Team)
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 267 -

JVM w dki f; r Sm execution engine w p fc kp Dv J& SdMu jy D; u l; w i fv dku fw Jh class a w G& JU Method a w Gx Jr Sm
y gw Jh instruction a w Gu dk execute v ky fa y ; w Jh mechanism w p fc ky g/ Execution engine x Ju dk a & mu f& Sd
v mc sde fr Sma w mho u fq dki f& m CPU u e m; v n fE dki fw Jhbytecode a w Gt jz p f a jy mi f; v Ja y ; r Smjz p fy gw , f/
CPU a w Gv dky JJVM r Smv Jregister t c sdKU& SdMu y gw , f/ t m; v Hk; [ m 32-bits a w Gjz p fMu y gw , f/
pc Program counter jz p fjy D; execute v ky fr , fhbytecode u dkn Te fjy y gw , f/
optop Operands stack & JUx dy fy dki f; e JUq dki fw Jh pointer w p fc kjz p fjy D; o c sFmq dki f& ma z mfjy c su fr sm; u dk
w Gu fc su fz dkUt o Hk; jy Ky gw , f/
frame v u f& Sdexecute v ky fx m; w JhMethod & JU execution environment e JUq dki fw Jhpointer/
vars Execution w Gi f v u f& SdMethod & JU y x r q Hk; local variable e JUq dki fw Jhpointer/
JVM jz p fp Ofw dki f; r Sma w mh Method area w p fc ke JU heap w p fc k& SdMu y gw , f/ ' Darea a w Gu dka w mh VM
x Jr Sm run a e Mu w Jh thread a w Gt m; v Hk; u r Qa 0 o Hk; p GJMu w mjz p fy gw , f/ Thread t o D; o D; r Sm personal stack
w p fc kp D& SdMu jy D; ? ' Darea u dka w mhy & dk* & r ft v ky fv ky f& mr Sm t o Hk; jy Kw Jhparameter a w Gt m; v Hk; u dk PUSH v ky fz dkUe JU
POP v ky fz dkU t o Hk; jy Kw mjz p fy gw , f/
JVM & JUv ky fa q mi fc su fa w G[ m stack u dkt a jc c Hw mjz p fy gw , f/ Bytecode a w Ge JU Method a w Gq D
parameter a w Gu dko Gi f; z dkUt w Gu f o lUu dkt o Hk; jy Kw mjz p fy gw , f/ x Gu f& Sdv mw Jh& v ' fu dka w mh o lw dkU& JUa e mu fq Hk;
w p fc ku a e c sdw f, l& & Sdw mjz p fy gw , f/
Java stack & JU stack frame u a w mh Method w p fc ke JUq dki fw Jh w p fc kw n f; a o m call & JU t a jc t a e u dk
reflect v ky fy gw , f/ i Hkx m; w Jh call a w Gt x Ju frame a w G[ m ' Dframe & JU x dy fy dki f; r Sm stack v ky fc Hv m& y g
w , f/
Stack & JU frame w dki f; r Sma w mharea o Hk; c ky g0 i fy gw , f
Method call t w Gu f local call
Method t w Gu f execution environment
Operands stack
Local variable a w Gu dka w mh vars register u index v ky fw Jh 32-bit array w p fc kr Sm o dr f; q n f; w m
jz p fy gw , f/
a ' w mt r sdK; t p m; a w mfa w mfr sm; r sm; u dka w mh array & JU cell w p fc ko mo Hk; w mjz p fjy D; long e JU double
t r sdK; t p m; u a w mhcell E Sp fc kv dkt y fy gw , f/
v u f& Sd stack & JUt c su ft v u fu dk x de f; o dr f; z dkU frame w p fc kx Jr Sm& Sdw Jh execution environment
u dkt o Hk; jy Kw mjz p fy gw , f/ o lUr Sm jy D; c Jhw Jhstack frame e JUq dki fw Jhpointer w p fc k? Method & JU call a w Ge JUq dki fw Jh
pointer w p fc k? t jc m; pointer E Sp fc k( w p fc ku a w mh stack frame & JU a t mu fy dki f; e JUq dki fjy D; a e mu fw p fc ku a w mh
v u f& Sdstack frame & JU t a y : y dki f; e JUq dki fy gw , f/ ) & Sdy gw , f/
Object a w Gt m; v Hk; u dka w mh heap memory area t a e e JUo dr f; q n f; w mjz p fjy D; run a e c sde fr Sm o G, f0 dku f
addressing u dkt o Hk; jy Kjy D; handle w p fc ku a e w p fq i fh point v ky fw mjz p fy gw , f/ JVM u dk t " du t m; jz i fh
stack r Smo ma w GUE dki fw ma Mu mi fhw e fz dk; a w Gu dk o dr f; q n f; z dkU t c sdKU register a w Gu dk t o Hk; r jy Ky gb l; / ' ga Mu mi fhv J
bytecode a w Gu dkt o Hk; jy K& w m[ m & dk; & Si f; jy D; t q i fa c sma p w my g/
JVM u dk' Dx u fy dkjy D; a v hv mr , fq dk& i fa w mha t mu fy gw dkUu dka w GU& E dki fy gw , f
Primitive t r sdK; t p m; r sm;
- byte - 8 bits - 128 + 127
- short - 16 bits - 32768 + 32767
- int - 32 bits - 2147483648 + 2147483647
- long - 64 bits - 9223372036854775808 + 9223372036854775807
- float - 32 bits 1.402398546E-45 3.40282347E+8
- double - 64 bits 4.94065645841246544E-324 1.79769313486231570E+308
Reference t r sdK; t p m; r sm; ( t o Hk; jy Ka o m object)
- class
- interface
- array
( 2 ) Java Cracking Tools
Java y & dk* & r fa w Gu dkcrack & mr Sm t o Hk; jy Kw Jhtool a w Gu a w mh
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 268 -

CCK (Class Construction Kit) (http://bcel.sourceforge.net/cck.html)
DJ Java Decompiler (http://www.neshkov.com/)
JAD Decompiler (http://www.kpdus.com/jad.html)
Java Decompiler (http://java.decompiler.free.fr)
JDebugtool (http://www.debugtools.com/)
Jode Decompiler (http://jode.sourceforge.net/) e JU
IDA Pro (http://www.datarescue.com/) w dkUjz p fy gw , f/
Java y & dk* & r fa w Gu dk crack v ky fz dkU& mt w Gu f Java Development Kit 1.3.x e JUt x u f? Java
Runtime Environment 1.6.x e JUt x u f w dkU& Sdx m; & r Smjz p fy gw , f/
( u ) CCK
CCK u a w mh Java class z dki fa w Gu dk jy Kjy i fz e fw D; & mr Sm t o Hk; jy Kw Jh tool w p fc kjz p fjy D; BCEL e JU
SWING w dkUu dk t o Hk; jy Kp r f; o y fx m; w mjz p fy gw , f/ Beta version jz p fw Jht w Gu f bug t c sdKUa w mh & Sdy ga o ;
w , f/
( c ) DJ Java Decompiler
Atanas Neshkov & JU DJ Java Decompiler u a w mh Java class z dki fa w Gu dk p mo m; z dki f ( o dkU) t jc m;
z dki fa w Gt a e e JU decompile v ky fa y ; E dki fy gw , f/ Oy r mjy & & i f Java applet e JUa & ; x m; w Jhbinary class z dki fa w Gu dk
r l& i f; source u k' fz dki ft a e e JU jy e fa jy mi f; a y ; E dki fy gw , f/ DJ Java Decompiler u dkt o Hk; jy Kr , fq dk& i f Java
& Sdp & m r v dky gb l; / Java z dki fa w Gu dkdecompile v ky f& mr Sm t a u mi f; q Hk; tool w p fc kjz p fy gw , f/
( * ) JDebugtool
Stand-alone debugger w p fc kjz p fjy D; Java e JUa & ; o m; x m; w mjz p fy gw , f/ ' ga Mu mi fh Jdebugtool
u dkt o Hk; jy Kr , fq dk& i f JDK 1.6(Java 6) u dk install v ky fx m; z dkUv dky gw , f/ JPDA (Java Platform Debugger
Architecture) p Hu dke r le mx m; jy D; a & ; o m; x m; y gw , f/ Java y & dk* & r fa w Gu dk debug v ky f& mr Sma w mh t a u mi f;
q Hk; tool w p fc kjz p fy gw , f/
( C ) JAD
Java class z dki fa w Gu dk decompile v ky fw Jh command-line tool w p fc kjz p fjy D; t o Hk; & r , fhy Hkp Hu a w mh
a t mu fy gt w dki f; jz p fy gw , f
jad example.class
' D command u dk& dku fx n fhr , fq dk& i fa w mh example1.jad q dkw Jhz dki fu dk v u f& Sd directory a t mu fr Sm
z e fw D; a y ; r Smjz p fy gw , f/
( i ) JODE
JODE u a w mh Java Optimizer and Decompiler & JUt w dka u mu fy g/ Decompiler u a w mh .class
z dki fa w Gu dkz w fjy D; r lv .java z dki ft jz p fx kw fa y ; w my g/ Comment a w Ge JU local variable a w G& Ju t r n fu dka w mh
x kw fa y ; E dki fjc i f; r & Sdy gb l; / Optimizer u a w mh .class z dki fa w Gt jz p f e n f; v r f; t r sdK; r sdK; e JU a t mu fy gt w dki f;
a jy mi f; v Ja y ; E dki fy gw , f
- Class? Method? field e JU local t r n fa w Gu dkobfuscate v ky fa y ; jc i f; /
- Debugging E Si fho u fq dki fa o mt c su ft v u fr sm; z , f& Sm; a y ; jc i f; /
- Dead u k' fr sm; ( class? field? Method) ? constant field r sm; u dkz , f& Sm; jc i f; /
- Local variable r sm; \ allocation u dkoptimize v ky fjc i f; /
( p ) Java Decompiler
Emmanuel Dupuy & JU Java Decompiler u a w mh .class z dki fa w G? .jar z dki fa w Gu dk decompile
v ky fa y ; E dki fw Jha q hmz f0 Jv fw p fc kjz p fjy D; .java source z dki ft a e e JU o dr f; a y ; E dki fy gw , f/
( 3 ) VisualRoute t m; a v hv mjc i f;
Java y & dk* & r fa w Gx Ju crack v ky fz dkU a & G; c s, fx m; w Jhy & dk* & r fu a w mhVisualRoute 2007 jz p fy gw , f/
u dk www.visualroute.com r Sm download v ky f, lE dki fy gw , f/ VisualRoute u o i fhu Ge fy sLw m& JU IP
address e JU o i fo dv dkw Jh 0 u fb fq dku f ( o dkU) IP address Mu m; r Sm& Sdw Jh IP a w G& JUw n f& Sd& ma e & mu dk a jr y Hke JU jy o
w m jz p fy gw , f/ VisualRoute u dkz Gi fhv dku f& i fa w mhy Hk( 3 ) t w dki f; jr i f& y gw , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 269 -


y Hk( 3 )
y & dk* & r f& JUt v ky fv ky fy Hku dkMu n fhr , fq dk& i f VisualRoute u , m, Dz dk' gw p fc ku dkz e fw D; y gw , f/ z dk' g& JU
t r n fu dk GetTickCount API o Hk; jy D; w n fa q mu fw mjz p fw Jht w Gu f t c sde fr w lw me JUt r Qz dk' gt r n fv J a jy mi f;
a e r Smjz p fy gw , f/

y Hk( 4 )
jexepackboot.class z dki fu dk CreateProcessA API o Hk; jy D; z e fw D; y gw , f/ jy D; a w mh ' Dz dki fu dk execute
v ky fy gw , f/ ' ga Mu mi fhjexepackboot.class z dki fu dk z e fw D; jy D; c sde fr Sm t jc m; w p fa e & mr Sm u l; jy D; o dr f; x m; v dku fy g/
' Dz dki fu dku l; & r , fha e & mu a w mh
<root>:\Documents and Settings\<current_user>\<temp_settings>\Temp

y Hk( 5 )
y Hk( 5 ) u CALL 0040108A u dk execute v ky fjy D; c sde fr Sma w mh y & dk* & r fp t v ky fv ky fy gw , f/ F7 u dkE Sdy fjy D;
CALL x Ju dk0 i fMu n fhc sde fr Sma w mhy Hk( 6 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 6 )
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 270 -

y Hk( 6 ) r Smjr i f& w Jht w dki f; Java interpreter u dkt v ky fv ky fa p z dkU CreateProcessA API u dka c : o Hk; y g
w , f/ CreateProcessA u dk v ky fa q mi fjy D; c sde fr Sm jexepackboot.class z dki f y su fo Gm; y gw , f/ t jy n fht p Hku
a w mha t mu fy gt w dki f; jz p fy gw , f
java -mx256m jexepackboot ER \"C:\\Program Files\\VisualRoute\\VisualRoute.exe\"
\"C:\\DOCUME~1\\MYOMYI~1\\LOCALS~1\\Temp\\X170A7F4\"
' Da e mu fr Sma w mh WaitForSingleObject API u dko Hk; jy D; y & dk* & r fu Java session jy D; w Jht c sde fx d
a p mi hfq dki f; y gw , f/ y Hk( 7 ) /

y Hk( 7 )
w u , fa w mh ' g[ m Windows Java wrapper w dki f; & JU z GJUp n f; y Hkjz p fy gw , f/ y & dk* & r fu dk, fw dki fu dku
wrapper w p fc ko mjz p fjy D; z dki fu dkunpack v ky fjy D; java class u dkp w i ft v ky fv ky fy gw , f/
( 4 ) Java cracking ( u k' fr sm; u dka v hv mjc i f; )
CreateProcessA u dkv ky fa q mi fjy D; w Jha e mu fr Sma w mh wrapper [ m t q Hk; r & Sdw Jh loop w p fc kx Jr Sm
WaitForSingleObject API t o Gi fe JU a e mu fq Hk; u se fa e w Jh thread u dk JVM x Jo Gi f; w Jht x d a p mi fha e r Sm
jz p fy gw , f/
u Re fa w mfw dkUt a e e JU ' D loader z dki fu dk external loader w p fc kz e fw D; jy D; patch v ky fv dkU& y gw , f/
( Oy r ma jy m& & i f u Re fa w mfw dkUt a e e JU , m, Dz dk' gu dk e mr n fa o w p fc kx m; w n fa q mu fjy D; ' Dt x Jr Sm patch v ky f
x m; w Jh class a w Gx m; y gr , f/ ' ga y r , fh ' ga w G[ m t jr i ft & a w mh r v kdt y fy gb l; / a e mu fy dki f; u s& i f & Si f; o Gm;
r Smy g/ )
a v ma v mq , fa w mh jexepackboot.class u dk DJ Java Decompiler e JU decompile v ky fMu n fhy g
r , f/ b ma Mu mi fhv Jq dka w mh class u dk execute v ky fc sde fr Sm a q mi f& Gu fw Jhv ky fa q mi fc su fa w Gu dk t a o ; p dw f
o dc si fv dkUy g/
y Hkr Se fq dk& i fa w mh class w p fc kt w Gu f execute v ky fw Jh y x r q Hk; Method u dka w mh class constructor
u z e fw D; w mjz p fy gw , f/ ( o l[ m class t r n fe JUw lw Jh Method w p fc kjz p fy gw , f/ ) w u , fv dkU class u dk
w dku f& dku fa c : o Hk; w mq dk& i fa w mh( Oy r mjy & & i f java.exe interpreter jz i fh) main Method u dk execute v ky fw m
jz p fy gw , f/ main Method u dkMu n fhr , fq dk& i f y Hk( 8 ) t w dki f; a w GU& r Smy g/
public static void main(String args[])
{
PQ = System.currentTimeMillis();
QQ = args[0].indexOf('D') >= 0;
RQ("Java=" + System.getProperty("java.version"));
jexepackboot jexepackboot1 = new jexepackboot(); // New instance of the current class
int i = jexepackboot1.run(args); // Execute the Method run(String[ ] as)
if(i != 0)
System.exit(i);
}
y Hk( 8 )
u k' fu a w mh & dk; & dk; a v ; y gy J/ y x r q Hk; function t c sdKUu dka c : o Hk; jy D; jexepackboot class & JU instance
t o p fw p fc ku dk z e fw D; y gw , f/ y x r q Hk; execute v ky fw Jh Method u a w mh constructor jz p fjy D; EP object
w p fc ku dk instanciate v ky fy gw , f/ ' Dw p fc k[ m jexepackboot1 class e JUq u fE G, fa e jy D; v u f& Sdjexepackboot
class e JUq dki fw Jht jc m; [ ma w Ge JUa w mhb mr Sv ky fr Smr [ kw fy gb l; /
class constructor r Sma w mh type Properties & JU object EP t o p fw p fc ky g0 i fr Smjz p fy gw , f/ y Hk( 9 ) /
Properties u dkstream w p fc kt a e e JU o dr f; q n f; E dki fy gw , f/ ( o dkU) stream w p fc ku a e u l; w i fE dki fy gw , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 271 -

t w dkc sHK; a jy m& & i fa w mh Properties object u dk database t r sdK; t p m; w p fc kt jz p fjr i fE dki fjy D; property
list x Ju key t o D; o D; e JU o le JUo u fq dki fw Jhw e fz dk; a w G[ m string a w Gjz p fMu y gw , f/
public jexepackboot( )
{
// Create a new object EP of type Properties
EP = new Properties();
}
y Hk( 9 ) Class constructor u k' f
Item a w Gu dka w mh setProperty^ getProperty object Method a w Go Hk; jy D; database x Ju dk push
v ky fc HE dki f& y gw , f? database x Ju a e t z w fc HE dki f& y gw , f/ Java u k' ft c sdKUu dk a v hv mMu n fh& a t mi f/ y Hkr Se f
messagebox a w Gv dky J Java r Sm messagebox a w Gu dk t o Hk; jy Kc si f& i f swing class u dkt o Hk; jy K& r Smjz p fy gw , f/
swing u dkt o Hk; jy Kjy D; GUI u dkt a jc c Hw Jh Java y & dk* & r fa w Gz e fw D; E dki fy gw , f/ u Re fa w mfw dkY v ky fz dkUv dkw mu a w mh
class u dk import v ky fjy D; Method w p fc ku dk a c : o Hk; z dkUy g/ Oy r mjy & & i f main Method x Ja & mu f& Sdjy D;
constructor u dkexecute v ky fc sde fr Sm messagebox u a e a jc & mc HE dki fy gw , f/
z dki f& JUx dy fq Hk; u dko Gm; jy D; import command p m& i f; u dkMu n fhy g/ y x r q Hk; e JU a e mu fq Hk; import a w G& Sdu dk
& Sd& y gr , f/ y Hk( 1 0 ) /
import java.awt.*; // Also used for messagebox support, (AWT = Abstract Windowing Toolkit)
import java.io.*;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.*;
import java.util.zip.GZIPInputStream;
import javax.swing.*; // Added for messagebox support
y Hk( 1 0 )
t c kc sde fr Sma w mhpop-up message u dka y : a p c si fw Jha e & mr Sm a y : a p z dkU u k' fx Jr Sm message box w p fc ku dk
a & ; Mu n fhy gr , f/
Constructor u dka jc & mc HE dki fz dkU main Method x Jr Sma & ; y gr , f/ y Hk( 1 1 ) /
public jexepackboot( )
{
JOptionPane.showMessageDialog(null, "CLASS CONSTRUCTOR" , "Reversing info (jexepackboot)" ,
JOptionPane.INFORMATION_MESSAGE);
// Create a new object EP of type Properties
EP = new Properties();
}
public static void main(String args[])
{
JOptionPane.showMessageDialog(null, "MAIN METHOD - START" , "Reversing info (jexepackboot)",
JOptionPane.INFORMATION_MESSAGE);
PQ = System.currentTimeMillis();
QQ = args[0].indexOf('D') >= 0;
RQ("Java=" + System.getProperty("java.version"));
jexepackboot jexepackboot1 = new jexepackboot();
int i = jexepackboot1.run(args);
if(i != 0){
JOptionPane.showMessageDialog(null, "MAIN METHOD - SYSTEM EXIT" , "Reversing info
(jexepackboot)" , JOptionPane.INFORMATION_MESSAGE);
System.exit(i);
}
JOptionPane.showMessageDialog(null, "MAIN METHOD - END" , "Reversing info (jexepackboot)",
JOptionPane.INFORMATION_MESSAGE); }
y Hk( 1 1 )
jexepackboot.java u dk Java compiler (javac.exe) e JU compile v ky fjy D; Olly u VA
0x004021EB u dka & mu fw Jht c g Olly u z e fw D; v dku fw Jh r lv jexepackboot.class z dki fa e & mr Sm u Re fa w mfw dkU
jy i fx m; w Jhjexe packboot.class z dki fe JUt p m; x dk; jy D; F9 u dkE Sdy fy g/ y Hk( 1 2 ) t w dki f; jr i f& y gr , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 272 -


y Hk( 1 2 )
a u mi f; jy D/ y & dk* & r ft v ky fv ky fy Hku dke n f; e n f; Mu n fhMu y gr , f/ y Hk( 1 3 ) /
(1) VisualRoute.exe
(2) java -mx256n jexepackboot ER ...
(3) START (jexepackboot.class)
(4) jexepackboot jexepackboot1 = new jexepackboot();
(5) jexepackboot1 (constructor)
(6) int i = jexepackboot1.run(args);
(7) END (jexepackboot.class)
y Hk( 1 3 )
jexepackboot1 class & JU constructor u dk v ky fa q mi fc sde fr Sma w mh Properties() class t o p fw p fc ku dk
z e fw D; r Smjz p fy gw , f/ jexepackboot class u a e w q i fh jexepackboot1 class & JU Method run(args) u dk
a c : o Hk; c sde fr Sm b ma w Gjz p fw , fq dkw m a u mi f; a u mi f; e m; v n fE dki fa t mi f ' Dfunction u dkt a o ; p dw fMu n fhy gr , f/
run Method & JU argument a w Gu a w mh jexepackboot x Jx n fho Gi f; t o Hk; jy Kw Jh argument a w Ge JU
t w lw ly Jjz p fy gw , f/
Args[0] = ER
Args[1] = <root>:\<prog_folder>\VisualRoute\VisualRoute.exe (full path of the main executable)
Args[2] = <root>:\DOCUME~1\<user>\<temp_set>\Temp\XE70DC8 (full path of the temporary folder)
run Method & JUt p y dki f; u dkMu n fhv dku f& i f y Hk( 1 4 ) t w dki f; jr i f& r Smjz p fy gw , f -
private int run(String as[])
{
// install v ky fx m; a o m java p e p fu dkp p fa q ; o n f/
if(!SQ())
return 9999;
if(as.length < 3)
return 10010;
// command-line w Gi f E y gv mjc i f; & Sd^ r & Sdp p fa q ; o n f/
boolean flag = as[0].indexOf('E') >= 0;
// command-line w Gi f R y gv mjc i f; & Sd^ r & Sdp p fa q ; o n f/
boolean flag1 = as[0].indexOf('R') >= 0;
// file o n f main executable E Si fhq dki fa o m pointer w p fc kjz p fo n f/
File file = new File(as[1]);
// , m, Dz dk' gv r f; a Mu mi f; u kdstring s t a e jz i fho dr f; q n f; o n f/
String s = as[2];
// "System properties key = jexepack.exe" u dkitem = <full path for VisualRoute.exe> E Si fht w l push v ky fo n f/
UQ("exe", TQ = file.toString());
// "System properties key = jexepack.resdir" u dkitem = <, m, Dz dk' gv r f; a Mu mi f; > E Si fht w l push v ky fo n f/
UQ("resdir", s);
// file1 o n f , m, Dz dk' gE Si fhq dki fa o m pointer w p fc kjz p fo n f/
File file1 = new File(s);
y Hk( 1 4 )
' Da e & mr Sm UQ Method u dkE Sp fc ga c : o Hk; w m a w GU& r Smy g/ ' D Method r Sm message box u k' fu dk
x n fho Gi f; Mu n fhy gr , f/
private void UQ(String s, String s1)
{
Properties properties = System.getProperties();
properties.put("jexepack." + s, s1);
System.setProperties(properties);
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 273 -

String mybuffer = "key = jexepack." + s + "\nitem=" + s1;
JOptionPane.showMessageDialog(null, mybuffer , "Reversing info (UQ method)" ,
JOptionPane.INFORMATION_MESSAGE);
}
' Du k' fa w Gu dkrun v dku f& i fa w mhy Hk( 1 5 ) t w dki f; jr i f& r Smjz p fy gw , f/


y Hk( 1 5 )
t c sdKUa o m t c su ft v u fa w Gu dk System properties database x Jx n fho dr f; x m; jy D; file pointer
E Sp fc ku dkv Jinitialize v ky fy gw , f/
r Sw f& e f/ / System class [ m key/value t w GJa w Gy g0 i fw Jh properties a w Gu dk x de f; o dr f; x m; y gw , f/ ' Dkey
w GJa w G[ m v u f& Sdt v ky fv ky fa e w Jh environment & JU attribute a w Gu dk t " dy m, fz Gi fhq dky gw , f/ Runtime
system y x r q Hk; t Mu dr f p w i fw Jht c gr Sm system properties u dk runtime environment e JUy w fo u fw Jh
t c su ft v u fa w Gy g0 i fE dki fa p z dkU initialize v ky fy gw , f/ t c su ft v u fx Jr Sm y g0 i fE dki fw mu a w mh v u f& Sd user?
Java runtime & JU v u f& Sd version a w Gjz p fjy D; z dki ft r n fw p fc k& JU component a w Gu dk o D; jc m; p Djz p fa p a t mi f
t o Hk; jy Kw Jhp mv Hk; a w mi fy g0 i fE dki fy gw , f/
run Method & JUa e mu f instruction w p fc ku a w mhIM function u dka c : o Hk; w my g/
// VisualRoute.exe image u dkbyte array abyte0[] t a e e JU u l; w i fy gw , f/
byte abyte0[] = IM(file);
IM function & JUv ky fa q mi fy Hku a w mha t mu fy gt w dki f; jz p fy gw , f/
private byte[] IM(File file)
{
RandomAccessFile randomaccessfile = null;
try
{
randomaccessfile = new RandomAccessFile(file, "r");
// z dki ft & G, ft p m; u dk& , ljy D; byte array t o p fw p fc k\ t & G, ft p m; t jz p f o w fr Sw fo n f/
byte abyte0[] = new byte[(int)randomaccessfile.length()];
// abyte0[] o n f point v ky fc H& a o mz dki fE Si fh t & G, ft p m; w la o m byte array w p fc kjz p fo n f/ y x r q Hk; z dki fx J& Sd t & mt m; v Hk;
u dkz w fjy D; abyte0 array t a e jz i fh u l; , lo n f/ i f; a e mu f t & G, ft p m; u dk a o c sma p & e f p p fa q ; o n f/ t u , f z w fc Jha o m
a ' w m\ t & G, ft p m; o n f array t & G, ft p m; E Si fh w ln Dc Jhv Qi f ( z dki ft & G, ft p m; E Si fhw ln Dc Jhv Qi f) u l; , ljc i f; v ky fi e f; p Ofo n f a t mi f
jr i fp Gm jy D; q Hk; jy Djz p fo n f/ x dkUa e mu f u Re fa w mfw dkUt a e jz i fhabyte0[] array u dk abyte1[] t r n f& Sda o m t o p fw p fc kt a e jz i fh u l; , l
E dki fjy Djz p fy go n f/
if(abyte0.length == randomaccessfile.read(abyte0))
{
byte abyte1[] = abyte0; // abyte1[] o n f one dimensional byte array w p fc kt w Gu f reference w p fc kjz p fo n f/
return abyte1;
}
}
catch(Exception _ex) { }
finally
{
try
{
// t m; v Hk; t q i fa jy o Gm; jy Djz p fo n fht w Gu f file stream u dky dw fv dkU& jy Djz p fo n f/
randomaccessfile.close();
}
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 274 -

catch(Exception _ex) { }
}
return null;
}
run Method & JUa e mu f instruction a w Gu a w mhfile image (overlay data extraction) e JUw GJv ky fw m
jz p fy gw , f/ y x r q Hk; p p fa q ; Mu n fhjy D; r Sdata extraction u dko Gm; y gr , f/
private byte[] VQ(byte abyte0[], char c)
{
WQ = -1; // WQ u dk-1 t jz p fo w fr Sw fo n f/ t u , f t m; v Hk; t q i fa jy c Jhv Qi f w e fz dk; u dkr a jy mi f; v JE dki fy g/ )
for(int i = 0; i + 28 < abyte0.length; i += 16)
if(BQ(abyte0, i) && abyte0[i + 15] == c)
{
int j = LQ(abyte0, i + 16);
int k = LQ(abyte0, i + 20);
long l = (long)j & 0xffffffffL | (long)k << 32;
int i1 = LQ(abyte0, i + 24);
int j1 = i + 16 + 8 + 4;
if(j1 + i1 <= abyte0.length)
{
if(1L == l * UM(abyte0, j1, j1 + i1))
return FO(new String(abyte0, 0, j1, i1));
WQ = 10092;
}
}
return null;
}
for loop u dkMu n fhy g/ i w e fz dk; u dk o kn v dkU initialize v ky fjy D; i w e fz dk; r Sm 28 u dka y gi f; y gw , f/
o w fr Sw fx m; w Jh t a jc t a e e JU u dku fn Da e p Ofr Sma w mh i w e fz dk; r Sm a e mu fx y f 16 v ma y gi f; y gw , f/ y dk& Si f; v i f;
a t mi fv dkU PE header u dkMu n fhy g/ y Hk( 1 6 ) /

y Hk( 1 6 )
PE header u dkMu n fhv dku f& i f VA [ m 0x1C (28) u a e p w mu dk a w GU& y gw , f/ for loop y w fa e p Of
t w Gi f; r Sm BQ Method u dkp p fa q ; w ma w GU& y gw , f/ BQ & JU argument [ m data byte jz p fjy D; byte array
u a e 16 bytes t w GJu dkz w fy gw , f/
private boolean BQ(byte abyte0[], int i)
{
int j = 0;
do
if(abyte0[i + j] != (char)(74 + (j * 3) / 2))
return false;
while(++j < 15);
return true;
}
w u , fa w mh BQ Method u z w fv kdu fw Jhp mv Hk; 1 6 v Hk; w GJ[ m "JKMNPQSTVWYZ\]_"
[ kw f^ r [ kw f p p fa q ; w my g/ HEX t a e e JUjy & & i f 4A 4B 4D 4E 50 51 53 54 56 57 59 5A 5C 5D 5F
jz p fy gw , f/ w u , fv dkUo m t a o o w fr Sw fx m; w Jh ' Dkey w GJa w Gu dka w GUc Jh& i f return jy e fy dkUw Jh w e fz dk; [ m true
jz p fjy D; ' Dv dkr Sr [ kw f& i fa w mhfalse w e fz dk; u dkreturn jy e fy dkUr Smjz p fy gw , f/
VisualRoute.exe u dk WinHex e JUMu n fhr , fq dk& i f ' Dv dkw e fz dk; [ m a e & m 3 a e & mr Sm& Sda e w m a w GU& y g
w , f/ y Hk( 1 7 ) /

y Hk( 1 7 )
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 275 -

y Hk( 1 7 ) r Smjr i f& w ma w Gu dk Olly & JU dump window r SmMu n fh& i fa w mh ' Dv dkjr i f& r Sm r [ kw fy gb l; / b m
a Mu mi fhv Jq dka w mh 00004600? 000067F0 e JU 00006860 w dkU[ m disk a y : r Sm& Sdw Jh physical address a w G
jz p fa e v dkUy g/ Olly r Smjr i fc si f& i fa w mho i fht a e e JU virtual address u dka jy mi f; jy D; & Smz dkUv dky gr , f/
b ma w Gjz p fr v Jq dkw m o dE dki fz dkU LordPE r Smz Gi fhjy D; section a w Gu dkMu n fhMu & a t mi f/ y Hk( 1 8 ) /

y Hk( 1 8 )
u Re fa w mfw dkU& JU t y dka ' w ma w G[ m disk a y : r Smo m& Sdjy D; ' g[ m a e mu fq Hk; section r Sma w mi f r y g& Sdy g
b l; / w u , fv dkU o i fht a e e JU Size of Image e JU Raw Size a ' w ma y gi f; v ' fw dkUu dk E dIi f; , SOfv dku fr , fq dk& i f & Si f;
o Gm; r Smy g/
Raw offset + Raw Size
400 + 1A00 = 1E00
1E00 + 800 = 2200
2600 + 600 = 2C00
2C00 + 1A00 = 4600 ( Raw Size a ' w ma y gi f; v ' f)
z dki ft & G, ft p m; [ m 0x7000 jz p fw ma Mu mi fh Windows loader [ m t c sdKUa ' w ma w Gu dk r Sw fOmP fx J
u l; w i fr Smr [ kw fy gb l; /

y Hk( 1 9 )
t w dt u sa jy m& & i f u Re fa w mfw dkU& JU overlay data [ m 0x2A00 (0x7000 - 0x4600) jz p fy gw , f/
VisualRoute.exe z dki fu dk backup v ky fjy D; .rsrc section & JU Raw Size e JU Virtual Size w dkUu dk y Hk( 2 0 ) t w dki f;
a jy mi f; a y ; y g/

y Hk( 2 0 )
y Hk( 2 0 ) t w dki f; a jy mi f; jy D; & i fa w mh z dki fu dk save v ky fv dku fjy D; LordPE u dky dw fv dku fy g/ u Re fa w mfw dkU
backup v ky fx m; w JhVisualRoute.exe z dki fu dkCFF explorer r Smz Gi fhMu n fhy g/ y Hk( 2 1 ) /

y Hk( 2 1 )
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 276 -

jy D; & i f File Offset a e & mr Sm 4600 v dkU& dku fx n fhy g/ y Hkr Se ft m; jz i fha w mh CFF explorer r Smy gv mw Jh
Address converter u r Se fu e fw Jh RVA e JU VA u dk w Gu fx kw fa y ; E dki fy gw , f/ y Hk( 2 1 ) u dkMu n fh& i f RVA e JU
VA [ m y Hkr Se fr [ kw fw Jhw e fz dk; a w Gu dk jy a e y gw , f/
y Hk( 2 0 ) t w dki f; VisualRoute.exe u dkjy i fjy D; o dr f; x m; w Jhz dki fu dk CFF explorer r Smz Gi fhMu n fhjy D; File
Offset a e & mr Sm 4600 v dkU& dku fx n fhv dku fy g/ y Hk( 2 2 ) /

y Hk( 2 2 )
' Dw p fc gr Sma w mh CFF explorer u virtual address u dk r Se fu e fp Gm w Gu fx kw fE dki fy gjy D/ ' D address
t w dki f; Olly r Sm Mu n fhv dku f& a t mi f/ y Hk( 2 3 ) /

y Hk( 2 3 )
r lv VirtualRoute.exe z dki fu dkz Gi fhMu n fh& i fa w mhb mr Sa w GU& r Smr [ kw fy gb l; / y Hk( 2 4 ) /

y Hk( 2 4 )
Section & JU offset [ m 1A00 (406A00 - 405000) u a e p w i fr Smjz p fy gw , f/ Offset 000067F0 e JU
00006860 w dkUu dkOlly r SmMu n fh& i fv Jy Hk( 2 5 ) t w dki f; jr i f& r Smy g/

y Hk( 2 5 )
' Djy Kjy i fx m; w JhVisualRoute.exe u dkz Gi fhMu n fhv dku f& i f y Hk( 2 6 ) t w dki f; error w u fw ma w GU& y gr , f/

y Hk( 2 6 )
' gu a w mh file integrity e JUy w fo u fjy D; CRC p p fa q ; r Iy g/ ' gu dka w mh a e mu fMu r Sy J a v hv my gr , f/
t c ka w mhr lv VisualRoute.exe z dki fu dkjy e f restore v ky fv dku fy g/
Jexepack & JU BQ Method q D jy e fo Gm; v dku fMu & a t mi f/ u Re fa w mfw dkUt a e e JU overlay data u dk
t a o ; p dw fa v hv mw Jht c gr Sm VisualRoute.exe y & dk* & r f b , fv dkt v ky fv ky fo v Jq dkw m o dv my gw , f/ p dw f0 i f
p m; p & ma u mi f; w mu dka w GUE dki fz dkU VQ function u dkq u fMu n fhv dku fMu & a t mi f/
VQ function x Jr Sm LQ function u dkE Sp fc ga c : o Hk; w m a w GU& y gw , f/ LQ function u a w mhu k' fa w G
u dkdecrypt v ky fa y ; w mjz p fjy D; a e mu fq Hk; r Sma w mhbyte array w p fc kt a e e JU jy e fx m; y gw , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 277 -

run Method x Ju dkjy e fMu n fh& a t mi f/
// VisualRoute.exe u dkbyte array abyte0[] t a e jz i fhu l; w i fo n f/
byte abyte0[] = IM(file);
// Image u dka t mi fjr i fp Gm u l; w i fE dki fjc i f; & Sd^ r & Sdp p fa q ; o n f/
if(abyte0 == null)
return 10011;
// JKMNPQSTVWYZ\]_B u dkoverlay data t jz p f & Sd^ r & SdMu n fho n f/
if(VQ(abyte0, 'B') == null)
if(WQ > 0)
return WQ;
else
return 10002;
// JKMNPQSTVWYZ\]_V \ overlay data segment r Sbyte r sm; u dkextract v ky fo n f/
// Byte r sm; u dkdecrypt v ky fjy D; abyte1[] byte array t a e jz i fht m; v Hk; u dkjy e fx m; o n f/
byte abyte1[] = VQ(abyte0, 'V');
if(WQ > 0)
return WQ;
// decrypt v ky fx m; a o ma ' w mr sm; u dkdisk a y : & SdVdata.dat z dki fx Jo dkU dump v ky f, lo n f/
writeByteArrayToDisk(abyte1, "Vdata.dat" , 0, 0, 0);
writeByteArrayToDisk function u a w mh data array a w Gu dk disk a y : o dr f; q n f; E dki fz dkUt w Gu f
x n fho Gi f; x m; w Jh function w p fc kjz p fy gw , f/ Decrypt v ky fx m; w Jh array u dk disk a y : dump v ky f& jc i f;
u a w mh decrypt v ky fx m; w Jha ' w ma w Gr Sm b ma w Gy go v Jq dkw mu dk a v hv mE dki fz dkUjz p fy gw , f/ y Hk( 2 7 ) r Smjr i f& w m
u a w mhdecrypt v ky fx m; w Jhdata stream a w Gjz p fy gw , f/

y Hk( 2 7 )
writeByteArrayToDisk function u dka t mu fy gt w dki f; a & ; o m; x m; w mjz p fy gw , f/
private void writeByteArrayToDisk(byte bytebuffer[], String fileName, int start, int numbytes, int mode)
{
// Programmer = ThunderPwr of ARTeam
File file = new File(fileName);
if (mode == 0)
{
try
{ // 0 r So n f a e mu fq Hk; element x dbyte array t m; v Hk; u dka & ; o n f/
FileOutputStream file_output = new FileOutputStream (file);
DataOutputStream data_out = new DataOutputStream (file_output);
for (int i = 0; i < bytebuffer.length; i++)
{
data_out.writeByte(bytebuffer[i]);
}
file_output.close(); }
catch(IOException e)
{
System.out.println ("IO exception = " + e); } }
else
{
try
{ // start + numbytes elements r Sarray section w p fc ku dka & ; o n f/
FileOutputStream file_output = new FileOutputStream (file);
DataOutputStream data_out = new DataOutputStream (file_output);
for (int i = start; i < start + numbytes; i++)
{
data_out.writeByte (bytebuffer[i]);
}
file_output.close();
catch (IOException e)
{
System.out.println ("IO exception = " + e);
}
}
}
a e mu f instruction a w Gu a w mhEP Properties e JU o u fq dki fy gw , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 278 -

// extract v ky fw m a t mi fjr i fjc i f; & Sd^ r & Sdp p fa q ; y gw , f/ ' Da e mu fr Sma w mharray x Jr Sm& Sdw Jhstring u dkparsing v ky fjy D; a w mhparse
v ky fx m; w Jhstring u dkEP properties x Jr Sm o dr f; q n f; E dki fz dkU t w GJ( key? item) w p fc kt jz p f x m; & Sdy gw , f/
// EP propertes [ m local database e JUw lw m t r Sw f& y g/
if(abyte1 != null)
{
for(StringTokenizer stringtokenizer = new StringTokenizer(new String(abyte1, 0), "\n");
stringtokenizer.hasMoreTokens();)
{
String s3 = stringtokenizer.nextToken();
int j = s3.indexOf('=');
if(j > 0)
EP.put(s3.substring(0, j), s3.substring(j+1));
String key = s3.substring(0, j); // no need to add
String item = s3.substring(j+1); // no need to add
}
}
EP properties x J push v ky fc H& w Jhw e fz dk; t c sdKUu dk key/item pair t jz p f a t mu fy gt w dki f; a z mfjy E dki fy g
w , f/ *:\Program Files\VisualRoute\ z dk' ga t mu fu Vdata.dat z dki fu dk z Gi fhMu n fh& i f a t mu fy gt w dki f; a w GU
jr i f& r Smy g/
packager = JexePack 5.5a
main = vr
target = JM
mx = 256
windowed = yes
execwd = *
Overlay section u a e a ' w mt c sdKUu dk extract v ky fjy D; w Jha e mu fr Sma w mh VQ function [ m V p mv Hk;
e JUp w Jh chunk u dk& Sma z Gy gw , f/ ' Dha e mu fr Sma w mh decrypt v ky fjy D; abyte2[] t a e e JU t c su ft v u fa w Gu dk
o dr f; q n f; y gw , f/ a ' w mt m; v Hk; u dk YQ function e JU deflate v ky fr Smjz p fjy D; t q Hk; r Sma w mh ZQ function
u dkt o Hk; jy Kjy D; disk a y : a & ; r Smjz p fy gw , f/ r Sw fx m; & r Smu extract v ky fv dku fw Jhz dki fu dk , m, Dz kd' gt a e e JU o dr f;
q n f; r Smjz p fy gw , f/ y Hk( 2 8 ) /

y Hk( 2 8 )
r Sw fc su f/ / JexePack q dkw mu a w mh command-line tool w p fc kjz p fjy D; resource (GIF/JPG/TXT/p o n f)
a w Ge JUt w lw u Gjz p fw Jho i fh& JU Java application u dkcompress v ky fx m; w Jh32-bits Windows exe z dki ft a e e JU
a jy mi f; v Ja y ; E dki fy gw , f/ ' Dexe z dki f[ m Sun & JU Java Runtime Environment u dkt o Hk; jy Kjy D; t v ky fv ky fy g
w , f/ Console z dki ft a e e JUa & m? Windows application t a e e JUy g a jy mi f; a y ; E dki fy gw , f/
o i fh& JU exe z dki f t v ky fv ky fa e c sde fr Sm? JexePack [ m package w p fc kw n f; t a e e JU a y gi f; x m; w Jhz dki fa w G
u dk , m, Dz dk' gw p fc kr Sm extract jy e fv ky fjy D; java.class.path w p fc ku dk o w fr Sw fy gw , f/ ' Dha e mu fr Sma w mh o i fh
a w mfw Jh Java VM e JU o i fh& JU Java y & dk* & r fu dk t v ky fv ky fa p y gw , f/ y & dk* & r f jy D; q Hk; c sde fr Sma w mh , m, Dz dk' gu dk
z su fq D; & Si f; v i f; v dku fy gw , f/ JexePack u dka t mu fy gv dy fp mr Sm download v ky f, lE dki fy gw , f/
http://www.duckware.com/jexepack/index.html
JexePack & JU t * Fg& y fa w Gu a w mh-
Icon t y gt 0 i f o i fh& JU application u dkexe z dki fw p fc kw n f; t a e e JU pack v ky fa y ; E dki fy gw , f/
Native exe [ m system integration e JUy w fo u fjy D; y dka u mi f; v my gw , f/ ( icon? double-click?
shortcuts? p o n f)
Package t o Gi fa jy mi f; x m; w Jh class a w Ge JU resource a w G[ m compress v ky fc Hx m; & w mjz p fw Jh
t w Gu f exe z dki f[ m t & G, ft p m; t v Ge fa o ; a e r Smjz p fy gw , f/
w du sw JhJava runtime version r Smt v ky fv ky fa p E dki fy gw , f/
JNI (Java Native Interface) DLL a w Gu dkt jy n fht 0 v u fc Hy gw , f/
Run a e c sde fr Sm class a w Gu dku l; w i f& Sma z Gjc i f; u dkt jy n fht 0 a y ; p Gr f; E dki fy gw , f/
JRE u dk t v dkt a v smu f install v ky fa y ; E dki fy gw , f/
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 279 -

' Du kr P Du y J a e mu fx y fx kw fv ky fv dku fw Jh tool u a w mh Jobfuscate v dkUt r n f& jy D; VisualRoute.exe
r Sm obfuscate v ky fx m; w ma w GU& y gw , f/ ' ga Mu mi fhv J function a w G& JUt r n fa w G[ m VQ? WQ p o n fjz i fh
jz p fa e & w my g/ ' Dtool t a Mu mi f; u dka v hv mc si f& i fa w mha t mu fy gv dy fp mr Sm a v hv mE dki fy gw , f/
http://www.duckware.com/jexepack/index.html
run Method u dkq u fa v hv mMu n fh& a t mi f/
// "build" key item jz i fhProperties r Sextract v ky fo n f/
// x dkUa Mu mi fhr n fo n fhkey r Qbuild E Si fhr n Dc Jhv Qi f s2 u null t jz p fo w fr Sw fr n fjz p fo n f/
String s2 = EP.getProperty("build");
if(s2 != null)
UQ("build", s2);
if(!SQ())
return 9999;
// z dki fa & ; jc i f; p w i fo n f/
if(flag)
{
RQ("extract=yes");
// JKMNPQSTVWYZ\]_Z u dk& Smjy D; abyte2[] array t a e jz i fho dr f; q n f; o n f/
byte abyte2[] = VQ(abyte0, 'Z');
// t u , f a ' w mu dkextract v ky fc Jha o mf i f; u dkdisk a y : o dr f; q n f; o n f/
if(abyte2 != null && abyte2.length > 4)
{
Object obj = null;
abyte2 = XQ(abyte2);
int k = LQ(abyte2, 0);
int l = LQ(abyte2, 4);
abyte2 = YQ(abyte2, l, 8); // GZIP a ' w m stream u dkdecompress v ky fo n f/
int i1 = abyte2 != null ? ZQ(file1, abyte2, k) : 10034;
if(i1 > 0)
return i1;
RQ("extracted=" + k);
}
else if (WQ > 0)
return WQ;
else
return 10012;
}
// z dki fa & ; jc i f; jy D; q Hk; o n f/
if(!flag1)
return 12345;
q u fMu n fhr , fq dk& i fa w mha e mu f command a w Gu vr t r n fe JU class u dk& Sma z Gw mjz p fjy D; ' Dw p fc ku dk
Class1 v dkUo w fr Sw fy gw , f/ ( vr.class u dkextract v ky fjy D; jz p fo n f/ )
// "main" key o n f "vr" item t a Mu mi f; jz p fo n f/
// x dkUa e mu f statement o n f s1 u dk"vr" E Si fhn Da p v dr fhr n f/
String s1 = EP.getProperty("main");
if(s1 == null) // s1 = vr
return 10020;
// , c kt c g vr class t o p fu dkClass.forName(<class_name>) statement t o Hk; jy Kjy D; z e fw D; o n f/
Object obj1 = null;
int i = 0;
Class class1 = null;
try
{
class1 = Class.forName(s1);
}
catch(Throwable throwable)
{
obj1 = ((Object) (throwable));
i = 10024;
}
// Jz.Ky.Tx t r n fE Si fhz dki ft o p fw p fc ku dk, m, Dz dk' gw Gi f z e fw D; o n f/
File file2 = new File(file1, "Jz.Ky.Tx");
t c kc sde fr Sma w mh daemon thread w p fc ku dk jexepackboot class & JU run Method e JU o w fr Sw fjy D;
a e mu fr Sma w mh , m, Dz kd' gx Ju jexepackboot.class z dki fu dkz su fy p fv dku fjy D; r Mu ma o ; c i fu z e fw D; v dku fw Jh vr
class u dkas1 argument e JUw GJjy D; a c : o Hk; y gw , f/

t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 280 -

if(obj1 == null)
{
if(!QM(file2, new byte[100]))
return 10013;
String as1[] = new String[as.length - 3];
for(int j1 = 0; j1 < as1.length; j1++)
as1[j1] = as[3 + j1];
// , c kt c sde fw Gi f jexepackboot u dkdaemon thread (cyclic) w p fc kt a e jz i fhexecute v ky fy gv dr fhr n f/
Thread thread = new Thread(this);
thread.setDaemon(true);
thread.start();
// jexepackboot.class z dki fu dk, m, Dz kd' gx Jr Sz su fy p fo n f/
(new File(file1, getClass().getName() + ".class")).delete();
try
{ // t o p fw p fc kt w Gu f main Method u dkexecute v ky fo n f/
RQ("main=" + s1); // s1 = vr
Method method = class1.getMethod("main", new Class[] {java.lang.String[].class});
method.invoke(null, new Object[] { as1 });
}
' gu a w mh jexepackboot.class & JU t v ky fv ky fy Hky g/ w u , fa w mh jexepackboot [ m t jc m; class
a w Gu target y & dk* & r fu dk launch v ky fE dki fz dkUt w Gu f Mu dKw i fv ky fa q mi fa y ; & w Jh loader w p fc ko mjz p fy gw , f/
z dki fa w Gextract v ky fjy D; c sde fr Sm message box a y : a p c si f& i fa w mha t mu fy gt w dki f; x n fho Gi f; E dki fy gw , f/ y Hk( 2 9 ) /
// z dki fa & ; jc i f; jy D; q Hk; o n f/
if(!flag1)
return 12345;
JOptionPane.showMessageDialog(null, "run Method, FILE WROTE \n patch the vr.class" , "Reversing info
(jexepackboot)" , JOptionPane.INFORMATION_MESSAGE);

y Hk( 2 9 )
' De n f; u dkvr.class z dki ft w Gu f patch v ky fc sde fr Sm break v ky fE dki fz dkU t o Hk; jy KE dki fy gw , f/
( 5 ) Java cracking ( u k' fr sm; u dk t a o ; p dw fa v hv mjc i f; )
' Dw p fc ga w mhvr.class z dki fu dka t mu fy gt w dki f; jy i f& r Smjz p fy gw , f/
import java.io.*;
import java.util.Hashtable;
import javax.swing.*; // x y fx n fh& e f

public class vr extends ClassLoader
{
private Hashtable g_cl;
private Object m_o;
private String className = " vr " ; // y x r q Hk; t Mu dr fr Sma w mhvr jz p fy gw , f/
public vr()
{
// Default constructor
g_cl = new Hashtable();
}
public vr(String buffer)
{
// Overload of the default constructor
className = buffer;
printClassName( " CONSTRUCTOR " + className);
g_cl = new Hashtable();
}
public void printClassName(String functionName)
{
JOptionPane.showMessageDialog(null, functionName, "Reversing info (
"+getClass().getName()+" .class / " +className+")" , JOptionPane.INFORMATION_MESSAGE);
}
t c e f; ( 1 8 ) - Java jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 281 -

vr class t o p fw p fc ku dkvr1 t r n fe JU z e fw D; y gr , f/
vr vr1 = new vr("vr1"); // vr1 jz i fht p m; x dk; o n f/
vr1.equals(args);
vr1.equals("bl_ver=1.01");
a e mu fx y f ' Dv dkx y fjy i fy gr , f/
public boolean equals(Object obj)
{
try
{ // Create a new instance of the class A
printClassName("equals(loadClass(\"A\", true). newInstance() ");
m_o = m_o != null ? m_o : loadClass("A", true).newInstance();
}
catch(Exception exception)
{
exception.printStackTrace();
}
boolean flag = m_o.equals(obj); // Call the method equals for the class A
return flag;
}
' Da e mu fr Sma w mhargument A e JU loadClass method u dka c : o Hk; y gw , f/

' Dv dk jy i fjy D; w Jht c g VisualRoute.exe u dk Olly r Smjy e fz Gi fhy g/ y Hk( 2 9 ) t w dki f; jr i f& c sde fr Sm vr.class z dki fu dk
patch v ky fx m; w Jhvr.class z dki fe JUt p m; x dk; y g/ ' gq dky Hk( 3 0 ) t w dki f; jr i f& r Smjz p fy gw , f/




y Hk( 3 0 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 282 -

tcef;(19) - Visual Dot.net jzifh a&;om;xm;aom y&dk*&rfrsm;udk crack vkyfjcif;
' Dw p fc g u Re fa w mfw dkUt a e e JU crack v ky fMu n fhz dkU t v Sn fhu sv mw mu a w mh.net y & dk* & r fa w Gu dky g/ .net
y & dk* & r fa w Gu dk crack v ky f& w m[ m native API a w Ge JUa & ; o m; x m; w Jh t jc m; y & dk* & r fa w Gu dk crack v ky f& w m
x u f t r sm; Mu D; v G, fu lv my gw , f/ b ma Mu mi fhv Jq dka w mh y & dk* & r fu dka & ; o m; x m; w Jh source code a w Gu dk
Mu n fhv dkU& v dkUy g/ b , f function a w Gu dk b , ft c su ft v u fa w Ge JU a c : o Hk; w mu t p Mu n fhv dkU& w Jht w Gu f
cracker a w Gt w Gu f crack v ky f& w m t v Ge fv G, fu lv my gw , f/ b my Jjz p fjz p f crack r v ky fc i fa w mh .net & JU
o a b mo b m0 u dk e m; v n fa p c si fw Jht w Gu f .net e JUy w fo u fw Jht a jc c Ho Dt dk& Da w Gu dk t & i f& Si f; jy y gr , f/
( 1 ) .net q dko n fr Sm . . .
y & dk* & r fr mt r sm; p kt w Gu fu a w mh .net e JUy w fo u fw Jho a b mw & m; a w G[ m y a [ V dw p fy k' fv dky gy J/ .net
q dkw mu a w mh Microsoft & JU a & y e f; t p m; q Hk; p u m; v Hk; a w Gx Ju w p fv Hk; jz p fjy D; ASP.net u t p Visual
Studio.net t q Hk; & Sdw Jh Microsoft & JU product a w Gr Sm w Gi fu s, fp Gm t o Hk; jy Kv su f& Sdy gw , f/ w u , fa w mh .net
y & dk* & r fa w Gu dk machine code t jz p f w dku f& dku f compile v ky fv dku fw mr [ kw fy gb l; / ( C++ w dkUv dk b mo m
p u m; a w G[ m machine code t jz p fw dku f& dku f compile v ky fc H& w mjz p fy gw , f/ ) o lw dkUu dk IL v dkUa c : w Jh
Intemediate Language t jz p f compile v ky fv dku fw my g/ o i f[ m Java e JUy w fo u fc Jhz l; r , fq dk& i fa w mh .net
Framework [ m Java Virtual Machine v dky gy J/ IL a w Gu dk Java y & dk* & r fa w Gt jz p f compile v ky fa y ;
v dku fw Jh bytecode a w Ge JU E dIi f; , SOfE dki fy gw , f/ ' Dv dk bytecode a w Gt jz p fa jy mi f; v Ja y ; v dku fjc i f; [ m y & dk* & r f
a & ; o m; jc i f; & Ia x mi fhu a e Mu n fhr , fq dk& i f a u mi f; u sdK; a jr mu fjr m; p Gm ( t v ky fv ky fw JhE Ie f; u sq i f; o Gm; jc i f; r Sw y g; )
jz p fa p y gw , f/ Java & JUt a Mu mi f; jy c su fu a w mh ' Dv dkjy Kv ky fjc i f; t m; jz i fh r w ln Dw Jh OS a w Gr Sm Java y & dk* & r fa w G
u dkt v ky fv ky fa p E dki fjy D; r w ln Dw Jh y & dkq u fq mt r sdK; r sdK; r Sma w mi f t v ky fv ky fa p E dki fz dkUjz p fy gw , f/ .net & JU t " du
& n f& G, fc su fu ' Dt w Gu f r [ kw fa y r , fh' DZ dki f; y dki f; q dki f& m c sOf; u y fr Iu a w mhw ln Dy gw , f/
.net y & dk* & r fr ma w Gt w Gu f IL & JU t " du t m; o mc su fu a w mh compile v ky fx m; w Jhy & dk* & r fa w Gr Sm
identifier (class name? function name? variable name) a w G[ m & Sda e Mu w mjz p fy gw , f/ ( r Sw fc su f/ / C
y & dk* & r fa w Gu dk compile v ky fw Jht c gr Sm local variable t r n fa w G[ m t z w fq n fr & a t mi f q Hk; & IH; o Gm; a Mu mi f;
a q G; a E G; c Jhz l; w m t r Sw f& y g/ ) ' Dt c su fu y & dk* & r fr ma w Gu dk y & dk* & r fw p fc k& JU r w ln Dw Jht y dki f; a w Gu dk r w ln Dw Jh
b mo mp u m; a w Ge JU a & ; o m; v dkU& a p y gw , f/
Cracker a w Gt w Gu f t " du t m; o mc su fjz p fa p w mu v J ' Dt c su fy gy J/ b ma Mu mi fhv Jq dka w mh .net
y & dk* & r fa w G[ m o lU& JU source u dk bytecode e JUa z mfjy & w mjz p fw Jht w Gu f identifier a w G[ mv J r y su fr , Gi f; & Sda e
& w my g/ t v m; w ly J? IL [ m w u , fhy & dkq u fq mu k' fx u fp m& i f e n f; e n f; a v ; higher-level jz p fv mw Jht w Gu f
high-level b mo mp u m; t jz p f v G, fu lp Gmjy e fv n fw n fa q mu fE dki fMu w my g/ ' gu dk o dMu w Jht w Gu fa Mu mi fh .net
y & dk* & r fa w Gu dk r lv .net source code t jz p fjy e fa z mfa y ; E dki fr , fh tool a w Gu dkz e fw D; E dki fMu w mjz p fy gw , f/ ' Dv dk
jy e fa z mfa y ; E dki fw Jhtool a u mi f; a v ; w p fc ku dk Lutz Roeder u a & ; o m; c Jhjy D; Reflector v dkUa c : y gw , f/
( 2 ) Tools
.net y & dk* & r fa w Gcrack r v ky fc i fr Sm t o Hk; jy Kr , fh tool a v ; a w Gt a Mu mi f; a q G; a E G; y gr , f/ o i fht a e e JU
' Dtool a w Gt m; v Hk; u dk w p fc sde fw n f; r Sma w mhv dkt y fr Sm r [ kw fy gb l/ ' ga y r , fhtool a w Gt m; v Hk; & Sdx m; a t mi fa w mh
v ky fx m; & r Smjz p fy gw , f/
( 2 . 1 ) Relector (.net assembly decompiler)
Relector u a w mh .net component a w Gt w Gu f class browser w p fc kjz p fy gw , f/ ' Dtool a v ; [ m
.net assembly x Jr Smo dr f; q n f; x m; w Jh Meta data? IL instruction? resource? XML documention w dkUu dk
& Sma y ; E dki fy gw , f/
http://www.aisto.com/roeder/dotnet/
( 2 . 2 ) ILDasm (.net assembly decompiler)
MSIL Disassembler u a w mh MSIL Assembler (Ilasm.exe) t w Gu f tool w p fc kjz p fy gw , f/
ILDasm.exe [ m Microsoft intermediate language (MSIL) u k' fa w Gy gw Jh PE z dki fu dk, ljy D; Ilasm.exe
t w Gu f o i fha w mfr , fhp mo m; z dki ft jz p fz e fw D; a y ; y gw , f/
Reflector [ m .net assembly u dk IL u k' fa w Gt jz p f decompile v ky fa y ; E dki fa y r , fh assembly x Ju
IL instruction a w G& JU w u , fhbyte a w Gu dk jy o jc i f; r & Sdy gb l; / ILDasm r Sma w mhIL instruction a w Gu dk hex
w e fz dk; t a e e JUjy o a y ; E dki fa t mi f a & G; c s, fv dkU& y gw , f/
Oy r mjy & & i f - BLE instruction u dkMu n fhv dku fy g/ w u , fv dkUo m y x r w e fz dk; [ m ' kw d, w e fz dk; x u f
e n f; a e & i f ( o dkU) n Da e & i f o w fr Sw fx m; w Jhinstruction q Djump jz p fr Smy g/ ( Native code a w Gr Smw ke f; u a w mh
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 283 -

JLE e JUw ly gw , f/ ) w u , fv dkU hex editor r SmMu n fhv dku f& i f w u , fh byte [ m 3E jz p fa e w ma w GU& r Smy g/
BLE instruction t p m; BGT instruction v dkUa jy mi f; v dku f& i fa w mh y x r w e fz dk; [ m ' kw d, w e fz dk; x u fMu D; & i f
o w fr Sw fx m; w Jh instruction q D jump jz p fr Smy g/ o lUu dka z mfjy w mu a w mh 3D y g/ w u , fv dkU ' Da e & mu dk
jy i fc si f& i f hex editor q Do Gm; jy D; 3E t p m; 3D v dkUjy i f& r Smy g/
a u mi f; jy D? ILDasm e JUp p fx m; w Jhprocedure w p fc ku dkMu n fhv dku fMu & a t mi f/
.method public specialname instance class Scroller.Scroller/Title
get_Titles(object Index) cil managed
// SIG: 20 01 12 0C 1C
{
// Method begins at RVA 0xcd7c
// Code size 23 (0x17)
.maxstack 2
.locals init (class Scroller.Scroller/Title V_0)
IL_0000: /* 02 | */ ldarg.0
IL_0001: /* 7B | (04)00000D */ ldfld
IL_0006: /* 03 | */ ldarg.1
IL_0007: /* 28 | (0A)00005C */ call object
IL_000c: /* 6F | (0A)00005D */ callvirt instance object
IL_0011: /* 74 | (02)000003 */ castclass
Scroller.Scroller/Title
IL_0016: /* 2A | */ ret
} // end of method Scroller::get_Titles
' gu a w mhIL x Ju u k' ft c sdKUy g/
IL_0000 : line e Hy gw f/
02 : x dk line w Gi f& Sda o m IL instruction r sm; \ w u , fhbyte/
ldarg.0 : IL instruction/
' ga w Gu dke m; r v n fv dkU p dw fr y su fy ge JU/ a e mu fy dki f; r Sm t a o ; p dw fa q G; a E G; a y ; y gr , f/
Byte a w G? IL instruction a w Gjr i f& w Jh t m; o mc su fu a w mh CALL w p fc ku dk NOP a y ; c si fw my J
jz p fjz p f? u dk, f patch v ky fc si fw Jha e & mu dk jy i fc si fw my Jjz p fjz p f t v G, fw u ljy Kjy i fv dkU& y gw , f/ Offset u dkw Gu f
c su fz dkU RVA u dkt o Hk; jy K& r Smjz p fy gw , f/
Ildasm u a w mh Visual Studio 200x u dk install v ky fw Jht c gr Sm w c gw n f; y gv mw mjz p fw Jht w Gu f
o D; o e fU download v ky fp & mr v dky gb l; /
( 2 . 3 ) WinHex (Hex editor)
b , f hex editor u dkr q dk t o Hk; jy KE dki fa y r , fhWinHex u dka w mht Mu dKu fq Hk; jz p fa e v dkUy g/
http://www.x-ways.com/
( 2 . 4 ) CFF Explorer (General PE File Explorer)
Assembly x Ju metadata table a w Ge JU resource a w Gy g0 i fw Jh b , f PE z dki fr q dk& JU content a w Gu dk
Mu n fh& I& mr Sma w mht a w mfa v ; a u mi f; w Jhtool w p fc kjz p fy gw , f/
http://www.ntcore.com
( 2 . 5 ) SNS Remover (Strong Name Signature Remover)
t c sdKUa o m .net assembly a w G[ m assembly a w Gu dk z e fw D; v dku fc sde fr Sm t Mu Ht z e fr v ky fE dki fa t mi f?
r jy Kjy i fE dki fa t mi fw m; q D; z dkU digital signature a w Ge JU sign v ky fx m; Mu y gw , f/ Strongly named assembly
x Ju b , f byte u dkr q dk jy i fv dku fr , fq dk& i f .net runtime u assembly u dkp w i fz dkU ji i f; q e fy gv dr fhr , f/
' ga y r , fh u Re fa w mfw dkU& JU SNS remover tool u a w mh sign v ky fx m; w Jh assembly u a e signature field
u dkz , f& Sm; E dki fy gw , f/ ' Da e & mr Sm a jy mv dkw mu a w mhu Re fa w mfw dkU& JU CFF explorer u v J .net assembly u a e
Strong Name signature u dkz , f& Sm; E dki fjy D; PE z dki fu dk jy e fv n fw n fa q mu fE dki fy gw , f/ y Hk( 1 ) / ' ga y r , fh
u Re fa w mft a e e JU ' Dtool a v ; u dk y dkMu dKu fr dy gw , f/

y Hk( 1 )
http://www.pmode.com
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 284 -

( 2 . 6 ) PEBrowse Professional (Disassembler/Debugger)
.net assembly a w Gu dk disassemble v ky fE dki fw Jh^ debug v ky fE dki fw Jh debugger/disassembler w p fc k
jz p fy gw , f/ IL instruction a w Ge JU o lw dkU& JUw u , fh byte a w Gu dk jy o E dki fy gw , f/ ' ght jy i f b , f JIT
compiler event u dkr q dk break v ky fE kdi fy gw , f/ ' D debugger u dkt o Hk; jy Kjy D; .net IL instruction a w Gu dk
a jc & mc HE dki fy gw , f/ jy D; & i fa e mu fu G, fr Sm b ma w Gjz p fa e o v Jq dkw m o dE dki fy gw , f/
http://www.smidgeonsoft.com
( 2 . 7 ) .Net Generic Unpacker (.Net assembly Unpacker)
o i fht a e e JU .net assembly PE z dki fa w Gu dk dump v ky fw Jht c gr Sm ' D tool u dk v dky gv dr fhr , f/ .Net
reactor v dk t c sdKUa o m .net protection a q mhz f0 Jv fa w Gu o i fhy & dk* & r f& JU .net assembly u dk pack v ky fMu w m
jz p fjy D; MSIL r [ kw fw Jh PE z dki fu dkx kw fa y ; y gv dr fhr , f/ r Sw fOmP fx Jr Sm t v ky fv ky fw Jht c gr So m o i fhz dki f& JU
assembly a w Gu dk unpack jy e fv ky fMu w mjz p fy gw , f/ ' De n f; y n mu dka w mh r lv assembly & JU u k' fa w Gu dk
& , ljc i f; r S u mu G, fE dki fz dkU t o Hk; jy KMu w mjz p fy gw , f/ ' ga y r , fh o i fht a e e JU ' gu dk & dk; & Si f; v Sw Jh .net generic
unpacker o Hk; jy D; a u smfv Tm; E dki fy gw , f/
http://www.ntcore.com
a e mu fq Hk; t a e e JU a jy mv dkw mu a w mh w c gw & Hr Sm Reflector [ m t c sdKUa o m procedure ( o dkU)
function a w Gu dk o i fhp dw fMu dKu fb mo mp u m; (C#? VB? Delphi) t jz p f decompile r v ky fa y ; E dki fw Jht w Gu f
o i fht a e e JU IL instruction a w Gu dk & i f; E SD; a e z dkUv dkt y fy gw , f/ Native code a w Gu dk crack v ky fz dkU Assembly
b mo mp u m; u dk a v hv mw mx u fp m& i fa w mh IL u k' fa w Gu dk a v hv m& w m[ m y dkr dkv G, fu ljy D; v si fjr e fp Gme m; v n f
r Sm jz p fy gw , f/
( 3 ) Opcode
' gu a w mh crack v ky f& mr Sm t a & ; Mu D; q Hk; t c su fjz p fy gw , f/ o i fjr i fw Jht w dki f; .net application
a w G[ m o lw dkU& JU y & dk* & r f instruction a w Gu dk MSIL y Hkp He JUa z mfjy w mjz p fw Jht w Gu f Visual Studio r Sm
compile v ky fw Jht c g o i fh& JU source code a w Gu dk native machine u k' ft jz p f a jy mi f; v Ja y ; r Smr [ kw fy gb l; /
' ga y r , fh JIT compiler u dkt o Hk; jy Kjy D; compile v ky fr , fq dk& i fa w mh native code t jz p fa jy mi f; v Ja y ; r Sm
jz p fy gw , f/ JIT q dkw mu a w mh just-in-time compiler u dka jy mw mjz p fjy D; o i fhy & dk* & r fa w G& JU t p dw ft y dki f;
t c sdKUu dk native code t jz p fa jy mi f; v Ja y ; r Smjz p fjy D; v dkt y fw Jht c g execute v ky fr Smjz p fy gw , f/
Ildasm u x Gu fv mw Jhu k' ft c sdKUu dk a v hv mMu n fhv dku f& a t mi f/
IL_0000: /* 02 | */ ldarg.0
Line number Actual byte(s) IL instruction
Opcode q dkw mu a w mh Microsoft Intermediate Language (MSIL) instruction a w Gu dk
a z mfjy jc i f; jz p fy gw , f/ w u , fv dkU o i f[ m a & SYy dki f; t c e f; a w Gu dk a Mu n u fp Gme m; v n fx m; w , fq dk& i f a t mu fy g
instruction a w G[ m b mu dkq dkv dkw , fq dkw m o da e r Smy g/
JMP JNE JLE NOP CALL p o n f . . .
MSIL opcode a w Gu a w mh Intel y & dkq u fq ma w Gt w Gu f ' DZ dki f; jy Kx m; w Jh native opcode a w Ge JU
r w ln Dy gb l; / Oy r mjy & & i f native code y & dk* & r fa w Gr Sm CALL function & Sd& m offset u dk o i fo dx m; jy D; ' D
CALL u dkt v ky fr v ky fa p c si f& i f y & dk* & r fu dk hex editor r Smz Gi fhjy D; NOP (No OPertation) u dk& n fp l; w Jh 90
q dkw Jhbyte e JUt p m; x dk; & r Smjz p fy gw , f/
MSIL r Sma w mh 90 t p m; 00 e JUa z mfjy y gw , f/ ' g[ mt a & ; Mu D; w Jht c su fjz p fw Jht w Gu f MSIL t w Gu f
v dkt y fw Jh opcode p m& i f; u dk a z mfjy v dku fy gw , f/ o i fht a e e JU .net y & dk* & r fa w Gu dk crack v ky f& mr Sm ' Dopcode
a w Gt m; v Hk; u dk t o Hk; jy Kp & mr v kdy gb l; / r sm; a o mt m; jz i fha w mh NOP e JU unregistered t a jc t a e a w Gu dk a u smf
v Tm; E dki fz dkU jump instruction a w Gu dk t r sm; q Hk; t o Hk; jy K& r Smjz p fy gw , f/
Opcode a w Gt a Mu mi f; u dk y dkr dke m; v n fa p v dkw Jht w Gu f b mo mr jy e fb J r l& i f; t w dki f; a z mfjy v dku fy gw , f/
y & dk* & r fa w Gu dk v u fa w GU crack w Jht c gMu r Sy J v dkt y fo v dk b mo mjy e fa y ; r Smjz p fy gw , f/ & Sn fv sm; r Smp dk; w Jh
t w Gu f t o Hk; r sm; w Jhopcode a w Gu dky J a z mfjy v dku fy gw , f/
Opcode Meaning
Actual
bytes
And
Computes the bitwise AND of two values and pushes the result onto the evaluation
stack.
5F
Beq Transfers control to a target instruction if two values are equal. 3B
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 285 -

Beq_S Transfers control to a target instruction (short form) if two values are equal. 2E
Bge
Transfers control to a target instruction if the first value is greater than or equal to the
second value.
3C
Bge_S
Transfers control to a target instruction (short form) if the first value is greater than or
equal to the second value.
2F
Bge_Un
Transfers control to a target instruction if the the first value is greater than the second
value, when comparing unsigned integer values or unordered float values.
41
Bge_Un_S
Transfers control to a target instruction (short form) if if the the first value is greater
than the second value, when comparing unsigned integer values or unordered float
values.
34
Bgt
Transfers control to a target instruction if the first value is greater than the second
value.
3D
Bgt_S
Transfers control to a target instruction (short form) if the first value is greater than the
second value.
30
Bgt_Un
Transfers control to a target instruction if the first value is greater than the second
value, when comparing unsigned integer values or unordered float values.
42
Bgt_Un_S
Transfers control to a target instruction (short form) if the first value is greater than the
second value, when comparing unsigned integer values or unordered float values.
35
Ble
Transfers control to a target instruction if the first value is less than or equal to the
second value.
3E
Ble_S
Transfers control to a target instruction (short form) if the first value is less than or
equal to the second value.
31
Ble_Un
Transfers control to a target instruction if the first value is less than or equal to the
second value, when comparing unsigned integer values or unordered float values.
43
Ble_Un_S
Transfers control to a target instruction (short form) if the first value is less than or
equal to the second value, when comparing unsigned integer values or unordered float
values.
36
Blt Transfers control to a target instruction if the first value is less than the second value. 3F
Blt_S
Transfers control to a target instruction (short form) if the first value is less than the
second value.
32
Blt_Un
Transfers control to a target instruction if the first value is less than the second value,
when comparing unsigned integer values or unordered float values.
44
Blt_Un_S
Transfers control to a target instruction (short form) if the first value is less than the
second value, when comparing unsigned integer values or unordered float values.
37
Bne_Un
Transfers control to a target instruction when two unsigned integer values or unordered
float values are not equal.
40
Bne_Un_S
Transfers control to a target instruction (short form) when two unsigned integer values
or unordered float values are not equal.
33
Br Unconditionally transfers control to a target instruction. 38
Brfalse
Transfers control to a target instruction if value is false, a null reference (Nothing in
Visual Basic), or zero.
39
Brfalse_S Transfers control to a target instruction if value is false, a null reference, or zero. 2C
Brtrue Transfers control to a target instruction if value is true, not null, or nonzero. 3A
Brtrue_S
Transfers control to a target instruction (short form) if value is true, not null, or non-
zero.
2D
Br_S Unconditionally transfers control to a target instruction (short form). 2B
Call Calls the method indicated by the passed method descriptor. 28
Clt
Compares two values. If the first value is less than the second, the integer value 1
(int32) is pushed onto the evaluation stack; otherwise 0 (int32) is pushed onto the
evaluation stack.
FF 04
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 286 -

Clt_Un
Compares the unsigned or unordered values value1 and value2. If value1 is less than
value2, then the integer value 1 (int32) is pushed onto the evaluation stack; otherwise 0
(int32) is pushed onto the evaluation stack.
FE 03
Jmp Exits current method and jumps to specified method. 27
Ldarg Loads an argument (referenced by a specified index value) onto the stack. FE 09
Ldarga Load an argument address onto the evaluation stack. FF 0A
Ldarga_S Load an argument address, in short form, onto the evaluation stack. 0F
Ldarg_0 Loads the argument at index 0 onto the evaluation stack. 02
Ldarg_1 Loads the argument at index 1 onto the evaluation stack. 03
Ldarg_2 Loads the argument at index 2 onto the evaluation stack. 04
Ldarg_3 Loads the argument at index 3 onto the evaluation stack. 05
Ldarg_S Loads the argument (referenced by a specified short form index) onto the evaluation
stack.
0E
Ldc_I4 Pushes a supplied value of type int32 onto the evaluation stack as an int32. 20
Ldc_I4_0 Pushes the integer value of 0 onto the evaluation stack as an int32. 16
Ldc_I4_1 Pushes the integer value of 1 onto the evaluation stack as an int32. 17
Ldc_I4_2 Pushes the integer value of 2 onto the evaluation stack as an int32. 18
Ldc_I4_3 Pushes the integer value of 3 onto the evaluation stack as an int32. 19
Ldc_I4_4 Pushes the integer value of 4 onto the evaluation stack as an int32. 1A
Ldc_I4_5 Pushes the integer value of 5 onto the evaluation stack as an int32. 1B
Ldc_I4_6 Pushes the integer value of 6 onto the evaluation stack as an int32. 1C
Ldc_I4_7 Pushes the integer value of 7 onto the evaluation stack as an int32. 1D
Ldc_I4_8 Pushes the integer value of 8 onto the evaluation stack as an int32. 1E
Ldc_I4_M1 Pushes the integer value of -1 onto the evaluation stack as an int32. 15
Ldc_I4_S Pushes the supplied int8 value onto the evaluation stack as an int32, short form. 1F
Ldstr Pushes a new object reference to a string literal stored in the metadata. 72
Leave Exits a protected region of code, unconditionally tranferring control to a specific target
instruction.
DD
Leave_S Exits a protected region of code, unconditionally tranferring control to a target
instruction (short form).
DE
Mul Multiplies two values and pushes the result on the evaluation stack. 5A
Mul_Ovf Multiplies two integer values, performs an overflow check, and pushes the result onto
the evaluation stack.
D8
Mul_Ovf_Un Multiplies two unsigned integer values, performs an overflow check, and pushes the
result onto the evaluation stack.
D9
Neg Negates a value and pushes the result onto the evaluation stack. 65
Newobj Creates a new object or a new instance of a value type, pushing an object reference
(type O) onto the evaluation stack.
73
Nop Fills space if opcodes are patched. No meaningful operation is performed although a
processing cycle can be consumed.
00
Not Computes the bitwise complement of the integer value on top of the stack and pushes
the result onto the evaluation stack as the same type.
66
Or Compute the bitwise complement of the two integer values on top of the stack and
pushes the result onto the evaluation stack.
60
Pop Removes the value currently on top of the evaluation stack. 26
Rem Divides two values and pushes the remainder onto the evaluation stack. 5D
Rem_Un Divides two unsigned values and pushes the remainder onto the evaluation stack. 5E
Ret Returns from the current method, pushing a return value (if present) from the caller's
evaluation stack onto the callee's evaluation stack.
2A
Rethrow Rethrows the current exception. FE 1A
Stind_I1 Stores a value of type int8 at a supplied address. 52
Stind_I2 Stores a value of type int16 at a supplied address. 53
Stind_I4 Stores a value of type int32 at a supplied address. 54
Stloc Pops the current value from the top of the evaluation stack and stores it in a the local
variable list at a specified index.
FE 0E
Sub Subtracts one value from another and pushes the result onto the evaluation stack. 59
Sub_Ovf Subtracts one integer value from another, performs an overflow check, and pushes the
result onto the evaluation stack.
DA
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 287 -

Sub_Ovf_Un
Subtracts one unsigned integer value from another, performs an overflow check, and
pushes the result onto the evaluation stack.
DB
Switch Implements a jump table.
45
Throw Throws the exception object currently on the evaluation stack.
7A
Xor
Computes the bitwise XOR of the top two values on the evaluation stack, pushing
the result onto the evaluation stack.
61
b , f assembly u dkr q dk crack v ky f& mr Sm & i fq dki fMu HKa w GU& r , fh t [ e fUt w m; a w Gu a w mh a t mu fy g
t w dki f; jz p fy gw , f/ ' Da e & mr Sm u Re fa w mfht a e e JU t u sOf; r Qo ma z mfjy r Smjz p fjy D; t a o ; p dw fo dc si f& i fa w mh Google
r Sm& Smjy D; Mu n fhE dki fy gw , f/
( u ) Obfuscation
' gu a w mh IsLicensed function w dkUv dk Method e JU class t r n fa w Gu dk u Re fa w mfw dkUr & SmE dki fa t mi f
z w fv dkUr & w Jhp mv Hk; a w Gt jz p f a jy mi f; v Ja y ; w Jhjz p fp Ofu dk q dkv dkw my g/ Obfuscation [ m o i fhu dk t c u fa w GUa p E dki f
a y r , fh obfuscate v ky fx m; w Jhu k' fu a e w p fq i fh trace v ky f& w m ' Da v mu f r c u fv Sy gb l; / t a jz u a w mh
Reflector r Sm bookmark a w Gx m; jc i f; jz i fha o mfv n f; a u mi f; ? p m& Gu fv Gw fw p f& Gu fr Sm a & ; r Sw fjc i f; jz i fha o mf
v n f; a u mi f; a jz & Si f; E dki fy gw , f/ Cracking r Sma w mh p dw f& Sn fz dkUv dky gw , f/ p dw fr & Sn f& i fa w mh crack v ky fv dkU
& r Smr [ kw fy gb l; /
( c ) Encoded Strings
' gu a w mh a w mfa w mfa v ; q dk; y gw , f/ t & i fw ke f; u Olly r Sm string a w G& Smw ke f; u Search u a e
w q i fh & Smv dkU& y gw , f/ ' D string a w Gu a e w q i fh function (CALL) a w Gb , fv dkt v ky fv ky fw , fq dkw mu dk
Mu n fh& w m jz p fy gw , f/ ' Dr Sma w mh"Invalid Serial Number" p w Jhstring a w Gu dk jr i f& r Smr [ kw fy gb l; / String
a w Gu dk z Hk; u G, fE dki fz dkU t o Hk; t r sm; q Hk; e n f; v r f; u a w mh o lw dkUu dk encode v ky fjy D; encoded stream u dk binary
.net resource t jz p fo dr f; q n f; w mjz p fy gw , f/ t c sdKU string a w Gu dk v dkt y fr So m encoded stream u a e ' D
string a w Gu dk& , lz dkU function w p fc ku dka c : o Hk; w my g/ ' De n f; & JU t m; e n f; c su fu a w mh y & dk* & r ft v ky fv ky f
w mjr e fq e fa p z dkU decoding e n f; v r f; u dk jr e fa p a y ; & w my g/ ' ga Mu mi fhr dkU ' De n f; v r f; [ m decode v ky fjc i f; r & Sdb J
t o Hk; jy Kw mx u f? string a w Gr & Sdc sde fr Smt o Hk; jy Kw mx u f t r sm; Mu D; a E S; a e v dkU r & y gb l; / r sm; a o mt m; jz i fha w mh
decoding function a w G[ m byte shifting e n f; u dkt o Hk; jy Kjy D; string a w Gu dk decode v ky fz dkU jy e fp Dw m
jz p fy gw , f/ ' ga y r , fh o lw dkUu dk decode v ky fz dkUv G, fy gw , f/ Decoder (decoding function) u dk a w GUw me JU
o i fht a e e JU string a w Gu dk jy e fa z mfE dki fr Smjz p fjy D; o i fu dk, fw dki fa w mi f u dk, fy dki f decoder a & ; o m; E dki fr Smjz p fy g
w , f/ a e mu fy dki f; r Sma w mh a p s; u Gu f0 i fa q mhz f0 Ja w Gr Sm t o Hk; jy Ka e Mu w Jh decoding function a w Gu dk b , fv dk
crack v ky f& r v Jq dkw mjy y gr , f/
( * ) Strong Name Signature
Digital signature [ m digital document a w G? text a w G? data a w Gr Sm authenticate v ky fz dkUjz p fjy D;
t c su ft v u fa w Gu dk r r Se fr u e fr jy KE dki fa t mi f w m; q D; y gw , f/ Digital signature w p fc ku dkz e fw D; z dkU public
key cryptography u dkt o Hk; jy Ky gw , f/ Digital signature w p fc ku dkz e fw D; z dkU y x r q Hk; 160-bit & Sdw Jh hash
w e fz dk; w p fc ke JU sign v ky fw mjz p fy gw , f/ jy D; & i fa w mh w du sw Jh private key w p fc ko Hk; jy D; encrypt v ky fy gw , f/
Private key e JUo u fq dki fw Jh public key u dk& Sdx m; w Jh b , fo lr q dk author e JUy w fo u fw Jht c su ft v u fa w Gu dk
authenticate v ky fz dkU t o Hk; jy KE dki fjy D; data a w Gu dk r a jy mi f; v Jx m; b l; q dk& i fa w mhsign v ky fE dki fr Smy g/
' gu a w mh .net assembly a w Gu dk jy Kjy i fa jy mi f; v Jjc i f; r Su mu G, fE dki fz dkU t o Hk; jy KMu w Jh e n f; v r f; w p f& y f
jz p fy gw , f/ .net e JU z e fw D; x m; w Jh exe z dki fw p fc ku dk t v ky fv ky fa p c sde fr Sm y & dk* & r f[ m string name signature
u dkp p fa q ; y gv dr fhr , f/ w u , fv dkU & Sdc Jhr , fq dk& i f digital signature u dkp p fa q ; jy D; ? p p fq ; w mr a t mi fjr i f& i fa w mh
' g[ m assembly u dkjy i fx m; jy Dq dkw mo dv dku fjy D; y & dk* & r fu dkt v ky fv ky fa p z dkU ji i f; q e fy gv dr fhr , f/
o i fht a e e JU strong name signature b , fv dkt v ky fv ky fo v Jq dkw Jh t a o ; p dw ft c su ft v u fa w Gu dk
t i fw me u fr Sm & Sma z GE dki fy gw , f/
( 4 ) Entry Point Method (EPM) u dk& Smjc i f;
Entrypoint Method u a w mh .net application p w i fc sde fr Sm a c : , lo Hk; w Jh y x r q Hk; Method jz p fjy D; ?
' gu dk Reflector ( o dkU) Ildasm r SmMu n fhv dkU& z dkU t a & ; Mu D; y gw , f/ y Hkr Se f .net application w p fc kr Sma w mh
' Dv dky Hkp H& Sdy gw , f -
Public Shared Sub Main()
Application.Run (New MainForm)
End Sub
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 288 -

' DMethod & JUt a & ; y gy Hku a w mh o i fht a e e JU y & dk* & r f& JUv ky fa q mi fc su fa w Gu dk y & dk* & r fp w i fw Jht c sde fu p
jy D; register v ky fw Jhroutine & Sd& ma & mu fw Jht x da jc & mc HE dki fy gw , f/
' D Method u a e a e mu fx y f& & SdE dki fw Jht u sdK; a u s; Z l; u a w mh crack v ky fr , fh application & JU t " du
form t jz p fo Hk; r , fh MianForm class u dka v hv mq e f; p p fE dki fw my gy J/ w u , fv dkU o i fht a e e JU Application.
run u dkt a o t c smMu n fhr , fq dk& i f ' Dfunction x J t 0 i f^ t x Gu fv ky fa e w Jh argument a w G? argument w e fz dk;
a w Gu dk a w GU& r Smy g/
Entrypoint RawData offset u dk& Smz dkU o i fht a e e JU v ky fa q mi f& r Smu a w mh-
1 / Crack v ky fr , fhy & dk* & r fu dk CFF explorer r Smz Gi fhy g/
2 / .NET directory node q Do Gm; y g/
3 / * & p fu Gu fe JUjy x m; w Jhw e fz dk; a w Gx Ju EntrypointToken row u dk& Smy g/
4 / ' Drow t w Gu f a e mu fq Hk; column w e fz dk; u dkMu n fhy g/ ' Dw e fz dk; [ m DWORD jz p fjy D; entrypoint Method
& Sd& mq Du Re fa w mfw dkUu dk v r f; n Te fy gv dr fhr , f/
' Da e & mr Sma w mh token w e fz dk; u dk 060000028 v dkU, lq y gr , f/ o i fht a e e JUa w mh token w e fz dk; [ m
w p fr sdK; Mu D; y Jv dkU c Hp m; a e & r Smy g/ o l[ m table w p fc ke JU table & JU index u dka z mfjy w Jh DWORD w e fz dk; w p fc k
jz p fy gw , f/ q dkv kdw mu table w p fc ke JU ' Dtable x Ju row w p fc ku dk n Te fjy w my g/ Oy r mjy & & i f u Re fa w mfw dkU& JU
token w e fz dk; u dk 060000028 jz p fw , fv dkU o w fr Sw fMu n fhMu y gp dkU/
06 000028
Table index Row index in that table
' Da e & mr Sm u Re fa w mfw dkUa jy ma jy ma e w Jhtable q dkw mu a w mhMethods table u dka jy mw my g/ o i fht a e e JU
CFF explorer r SmMu n fhr , fq dk& i f Metadata Streams node a t mu fu Tables node r SmMu n fhE dki fy gw , f/
Tables node a & mu f& i fa w mhy Hk( 2 ) t w dki f; Method table & Sd& mu dk& Smy gr , f/

y Hk( 2 )
Method table u dk expand v ky fjy D; index 40 (28h) u dk& Smy gr , f/ ' gq dk y Hk( 3 ) t w dki f; a w GU& y gr , f/

y Hk( 3 )
y Hk( 3 ) u a e & mu dka & G; c s, fjy D; ' Dmethod e JUq dki fw Jht c su ft v u fa w Gu dk Mu n fh& Iv dkU& y g
w , f/ ' Da e & mr Sm u Re fa w mfw dkUp dw ft 0 i fp m; q Hk; u a w mh y x r q Hk; row jz p fjy D; ' Dmethod & JU RVA u dka z mfjy y g
w , f/ a e mu fq Hk; column u w e fz dk; u dk z w fv dku f& i fa w mh0x4974 jz p fy gw , f/
( 5 ) EPM t w Gu f z dki f offset u dk CFF explorer jz i fh& Smjc i f;
.net PE z dki fw p fc kr Sma w mh .text? .reloc? .rsrc p w Jh section 3 c k& Sdy gw , f/ .text section r Sma w mh
Import Table? Import Address Table e JU .Net Section w dkYy g0 i fy gw , f/ .net PE z dki fw p fc ku dk a t mu fy g
t c su ft v u fr sm; y g0 i fw , fv dkU , lq Mu n fhv dku fMu & a t mi f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 289 -

.net PE z dki ft w Gu f ImageBase 0x400000
.text section virtual address 0x002000
.text section Raw address 0x000200
EntryPoint Method VA 0x004974
' Dz dki fu dk r Sw fOmP fa y : u l; w i fv dku fw Jht c gr Sm jr i f& w mu a w mh-
0x400000 0x402000 0x404974 RVA
ImageBase > > > .text > > > EP_Method
0x0 0x2000 0x4974 VA
' ga Mu mi fhr dkU z dki fu dk r Sw fOmP fr Sma e & mc sx m; w Jht c g ImageBase & JU 0x2000 byte t u Gmr Sm .text
section u dk& Sm& r Smjz p fy gw , f/ Method data u dka w mh ImageBase & JU 0x4974 byte t u Gmr Sm& Sm& r Smjz p fy g
w , f/
a u mi f; jy D? .text section r Sm ep_method u dk& Smz dkU offset u dkw Gu fc su fMu n fh& a t mi f/
Offset = [EP_Method VA] [.text section VA]
= 0x4974 0x2000
= 0x2974
' ga Mu mi fh method data [ m .text section data & JU 0x2974 r Smp y gw , f/ w u , fv dkU .text section
RawData Offset u dkt o Hk; jy Kc Jh& i f u Re fa w mfw dkUt a e e JU method t w Gu f RawData Offset u dkv J t v m; w l
w Gu fc su fE dki fy gw , f/
Method RawData Offset = .text section RawData Offset + 0x2974
= 0x200 + 0x2974
= 2B74
' ga Mu mi fhz dki fx Jr Sm& Sdw JhMethod Offset [ m 2B74 jz p fy gw , f/
y Hk( 3 ) u a e & mu dk right-click E Sdy fjy D; Disassemble Method u dka & G; v dku f& i f y Hk( 4 )
t w dki f; jr i f& y gw , f/

y Hk( 4 )
t & Si f; q Hk; y Hkp He JUjy & & i fa w mh
EPM File Offset = [EntryPoint VA] [Section.txt VA] + [Section.txt RawAddress]
' Dw e fz dk; 3 c kv Hk; u dk CFF Explorer u a e & & SdE kdi fy gw , f/ CFF Explorer r Sm Address converter
y g& Sdjy D; o i fhr Sm RVA w e fz dk; & Sdx m; jy Dq dk& i f b , f Method & JU file offset u dkr q dkw Gu fc su fE dki fy gw , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 290 -

( 6 ) Entry Point Method (EPM) u dk Ildasm jz i fh& Smjc i f;
' gu a w mh v G, fu lw Jht v ky fjz p fjy D; Entrypoint Method disassembly u a e w u , fh byte t w GJa w G
u dk o dx m; & r Smjz p fy gw , f/ ' De n f; u kda w mhEPM r [ kw fw Jhb , f Method t w Gu fr q dk t o Hk; jy KE dki fy gw , f
.method public hidebysig static void Main() cil managed
// SIG: 00 00 01
{
.entrypoint
.custom instance void
[mscorlib]System.STAThreadAttribute::.ctor() = ( 01 00 00 00 )
// Method begins at RVA 0x4974
// Code size 26 (0x1a)
.maxstack 8
IL_0000: /* 00 | */ nop
IL_0001: /* 28 | (0A)000078 */ call void
IL_0006: /* 00 | */ nop
IL_0007: /* 16 | */ ldc.i4.0
IL_0008: /* 28 | (0A) 000079 */ call void
IL_000d: /* 00 | */ nop
IL_000e: /* 73 | (06) 00003D */ newobj instance
IL_0013: /* 28 | (0A) 00007A */ call void
IL_0018: /* 00 | */ nop
IL_0019: /* 2A| */ ret
} // end of method Form1::Main
' gu a w mh & dk; & Si f; v Sw Jh .net application w p fc ku a e , lx m; w Jh EntryPoint Method t w Gu f
disassembly jz p fjy D; ' D Method x Ju IL instruction a w Gu dka w GU& w mjz p fy gw , f/ Hex editor w p fc kr Sm
a t mu fy gp mo m; w GJa w Gu dk & SmMu n fhy g/
IL_0001 287800000A
IL_0008 287900000A
' ga Mu mi fh & Sm& r , fh HEX t w GJu a w mh 00 28 78 00 00 0A 00 16 28 79 00 00 0A jz p fy gw , f/
y Hkr Se ft m; jz i fha w mh 1 0 v Hk; a v mu f& Smv dku f& i f offset t r Se fu dk& Sma w GUz dkU v Hka v mu fjy Dx i fy gw , f/ y Hk( 5 ) u a w mh
HEX t w GJu dk WinHex r Sm & Smx m; w mjz p fy gw , f/

y Hk( 5 )
' gq dk& i fa w mh w u , fh byte & Sd& m y x r q Hk; offset u dka & mu fo Gm; y gv dr fhr , f/ jy D; c Jhw Jhe n f; v r f; w ke f; u
o i fa & mu f& Sdc Jhw m[ m Code byte r w dki fc i fr Sm& Sdw Jh Method Header byte u dky g/ .net Method w n fa q mu f
x m; y Hku a w mhy Hk( 6 ) t w dki f; jz p fy gw , f/

y Hk( 6 )
y x r e n f; v r f; u a w mh o i fhu dk > & Sd& ma e & mq D a & mu fa p w mjz p fjy D; u k' fa w G& Sd& m y x r q Hk; byte q D
a & mu fa p c si f& i fa w mh header t & G, ft p m; w e fz dk; 1 ( t jr Jw r f; 1 jz p fa e r Sm r [ kw fy gb l; / ) u dka y gi f; a y ; & r Sm
jz p fy gw , f/ ' ga Mu mi fhu Re fa w mfw dkU w Gu fc su fv dkU& w Jht a jz [ m 2B75 t p m; 2B74 jz p fa e & w my g/


t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 291 -

( 7 ) Entry Point Method node u dk Ildasm Tree w Gi f& Smjc i f;
Entrypoint Method t w Gu f decompilation u dk o i fht a e e JUjr i fc si fy go v m; / CFF explorer u a e
EntryPoint Method RVA u dko djy D; w Jha e mu fr Sma w mho lU& JUu k' fu dkMu n hfz dkU t c sde fa & mu fy gjy D/
' Dt w Gu f ILDasm u dka & m? Reflector u dky g t o Hk; jy KE dki fy gw , f/ ' ga y r , fh r Sw fx m; & r Smu ILDasm
[ m .net Method a w Gt w Gu f decompilation u dk IL y Hkp Ht a e e JUo m jy E dki fy gw , f/ u Ha u mi f; & i fa w mh
Reflector u EntryPoint Method u k' fu dk o i fhp dw fMu dKu f .net b mo mp u m; t a e e JU decompile v ky fa y ; r Sm
jz p fy gw , f/ ' gr Sr [ kw f& i fa w mhu k' fu dk analyze v ky fz dkUu a w mhILDasm a y : r lw n fr Smjz p fy gw , f/
ILDasm a & m? Reflector u y g assembly a w Gu dk tree view t a e e JUjy E dki fy gw , f/ ' ga y r , fh
ILDasm u o m o i f decompile v ky fw Jh Method w dki f; t w Gu f RVA w e fz dk; u dk a jy mjy E dki fr Sm jz p fy gw , f/
ILDasm e JU p p fx m; w Jhu k' ft c sdKUu dk Mu n fhv dku fMu & a t mi f/
.method public hidebysig static void Main() cil managed
// SIG: 00 00 01
{
.entrypoint
.custom instance void
[mscorlib]System.STAThreadAttribute::.ctor() = ( 01 00 00 00 )
// Method begins at RVA 0x4974
// Code size 26 (0x1a)
.maxstack 8
IL_0000: /* 00 | */ nop
IL_0001: /* 28 | (0A)000078 */ call void
IL_0006: /* 00 | */ nop
IL_0007: /* 16 | */ ldc.i4.0
IL_0008: /* 28 | (0A) 000079 */ call void
IL_000d: /* 00 | */ nop
IL_000e: /* 73 | (06) 00003D */ newobj instance
IL_0013: /* 28 | (0A) 00007A */ call void
IL_0018: /* 00 | */ nop
IL_0019: /* 2A| */ ret
} // end of method Form1::Main
t c sde fa w mfa w mfr sm; r sm; r Sma w mh o i f[ m obfuscated u k' fa w Gu dka w GU& r Smjz p fjy D; ILDasm x Ju b , f
node [ m EntryPoint Method q dkw m o i fo dE dki fr Sm r [ kw fy gb l; / w u , fv dkU & me JUc sDw Jh? a x mi fe JUc sDw Jh node
a w Ga w GY& i f y dk& Sm& c u fr Smy g/
CFF explorer u a e EntryPoint Method RVA u dk o i fht a e e JU o djy D; jz p fy gv dr fhr , f/ c kt c gr Sma w mh
EntryPoint Method node u dk & Smjy y gr , f/ ILDasm r Sm b , f class r Smr q dk& Sdw Jh Method t c sdKUu dk
decompile v ky fjy D; o lU& JU RVA w e fz dk; u dkMu n fh& r Smjz p fy gw , f/ w u , fv dkU ' Dw e fz dk; [ m EPM RVA x u f
Mu D; c Jh& i fa w mh higher-level node w p fc ku dk x y fMu n fh& r Smjz p fy gw , f/ Node a w Gt a y : w u fv ma v a v o lU
Method t w Gu f RVA w e fz dk; e n f; a v a v jz p fy gw , f/ ' Dv dke n f; e JU w p fr de p f? E Sp fr de p f& Smv dku f& i fa w mh
ILDasm r Sm EntryPoint Method node u dk& Sma w GUr Smjz p fy gw , f/ ( r Sw fc su f/ / ' Dv dk& Smr , fq dk& i fa w mh
ILDasm & JU View menu u Sort by name u dka & G; r x m; r da p z dkU o w dx m; & r Smjz p fy gw , f/ )
( 8 ) Entry Point Method (EPM) u dk PEBrowse Debugger jz i fhw GJo Hk; jc i f;
Crack v ky fr , fh application t w Gu f CFF explorer u a e EntryPoint token u dko djy D; w Jha e mu f
r Sma w mh' Dtoken u dk t o Hk; jy Kjy D; a w mhPEBrowse r Sm EntryPoint Method u dk& Smv dkU& y gw , f/ EPM u dk JIT
compiler u compile v ky fc sde fr Sm breakpoint x m; jc i f; jz i hf .net application u dk break v ky fv dkU& y gw , f/
' Dt w Gu f o i fht a e e JU v ky fa q mi f& r Smu a w mh
( 1 ) Crack v ky fr , fh application u dk PEBrowse r Smz Gi fhy g/ Library a w Gt m; v Hk; e JU module a w Gt m; v Hk; u dk
u l; w i fjy D; w Jht x da p mi fhy g/
( 2 ) PEBrowse [ m EPM u dka c : o Hk; w m r w dki fc i fe m; a v ; r Sm & y fo Gm; y gv dr fhr , f/ ' ga Mu mi fh ' Dt c sde f[ m node
u dk& Smz dkUe JU t J' Da e & mr Sm breakpoint o w fr Sw fz dkU t a u mi f; q Hk; y gy J/
( 3 ) Application u dku l; w i fc sde fr Sm module x Jr Sm& Sdw Jh .net module a w G[ m t e Da & mi f icon a w Ge JUjz p fa e y g
v dr fhr , f/ y Hk( 7 ) / Methods node u dkMu n fhv kdu f& i fa w mhMethod a w Gu dk, fp De JU class a w Gu dka w GU& y gv dr fhr , f/
( 4 ) Method w dki f; t w Gu f token a w Gu dk o lw dkU& JUt r n fa b ; r Sm a w GU& y gv dr fhr , f/ Oy r mjy & & i f button1_
Click t w Gu f token u a w mh06000005 jz p fy gw , f/
( 5 ) CFF explorer u a e EPM u dko dx m; jy D; jz p fw Jht w Gu fa Mu mi fh o i fht a e e JU r Se fu e fw Jh node u dk ' Da e & mr Sm
& SmE dki fy gw , f/ ILDasm u RVA r Smv dky J a t mu fu dkq i f; o Gm; & i f token w e fz dk; w dk; o Gm; y gv dr fhr , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 292 -

( 6 ) r Se fu e fw Jh node u dka w GU& i fa w mh t J' Da e & mr Sm right-click E Sdy fjy D; "Add Breakpoint" menu u dka & G; v dku f& Hk
y gy J/
y Hk( 7 )
( 9 ) Patch v ky fjc i f; t a jc c H
' Dw p fc gr Sma w mh .net application a w Gu dk patch v ky fjc i f; e JUy w fo u fjy D; a v hv mMu n fhv dku f& a t mi f/
' Dw p fc g patch v ky fz dkUa & G; c s, fx m; w Jh y & dk* & r fu a w mh Dot_Net_ReverseMe_2.exe jz p fy gw , f/ ' Dy & dk* & r fu dk
www.tuts4you.com & JU download section u a e download v ky f, lE dki fy gw , f/ ( o i fht a e e JU ' Dy & dk* & r fa v ;
u dk & Sdr x m; v J t a & ; r Mu D; y gb l; / & Si f; jy w mu dk e m; v n fa t mi fMu n fhz dkUo m t a & ; Mu D; y gw , f/ ) y x r q Hk; patch
v ky fr , fhy & dk* & r fu dk PEiD e JUp p fMu n fhy gr , f/ y Hk( 8 ) /
y Hk( 8 )
y & dk* & r fu dk .net b mo mp u m; e JU a & ; x m; w ma o c smy gw , f/ a u mi f; jy D? y & dk* & r fu dkz Gi fhv dku fw Jht c g y Hk( 9 )
t w dki f; a w GU& y gw , f/
y Hk( 9 )
y Hk( 9 ) t & q dk& i fa w mhu Re fa w mfw dkUt w Gu f b mr Sv ky fp & mr & Sdy gb l; / b ma Mu mi fhv Jq dka w mhserial & dku fx n fh
p & m textbox w dkU? serial r Se f^ r r Se fp p fw Jh button w dkU r a w GUv dkUy g/ ' ga Mu mi fh a & ; x m; w Jhu k' fu dkMu n fhE dki fz dkU
y & dk* & r fu dk Reflector e JUz Gi fhv dku fy g/ y Hk( 1 0 ) /

y Hk( 1 0 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 293 -

' Dt c gr Sma w mh p dw f0 i fp m; p & ma w Gu dk a w GU& y gjy D/ ' Dt x Ju w p fc ku a w mh IsRegistered q dkw Jh boolean
class y g/ a e mu fw p fc ku a w mh CheckReg() function y g/ CheckReg() u dk double-click E Sdy fjy D; z Gi fhv dku f& i f
u Re fa w mfw dkU o Ho , & Sda e w m r Se fu e fa Mu mi f; a w GU& y gr , f/ y Hk( 1 1 ) /

y Hk( 1 1 )
' Dw p fc gr Sma w mh .ctor() t a Mu mi f; & Si f; jy r Smjz p fy gw , f/ C++? Java? C# ( o dkU) b , f OOP (Object
Oriented Programming) b mo mp u m; r Smr q dk o lUr Smy g0 i fw Jh class member a w G& JUw e fz dk; u dk initialize
v ky fz dkU constructor w p fc ky g0 i fw Jh class a w G& Sdy gw , f/ .net r Sma w mh class constructor u dke mr n fa y ; a v h
r & Sdy gb l; / Constructor & JUt w dka u mu fjz p fw Jh .ctor() q dkw Jht r n fo mx m; y gw , f/ IsRegistered q dkw Jh
member variable [ m y & dk* & r fu dk register v ky fx m; jc i f; & Sd^ r & Sd q Hk; jz w fy gw , f/ u Re fa w mfw dkUt w Gu f t c Gi fh
t a & ; & & Sda p w mu a w mh register jz p f^ r jz p fu dk constructor x Jr Sm initialize v ky fv dkUy g/ a u mi f; jy D? .ctor()
u dkz Gi fhjy D; Mu n fhv dku fMu & a t mi f/ y Hk( 1 2 ) /

y Hk( 1 2 )
w u , fa w mh u Re fa w mfw dkUy & dk* & r fu unregistered jz p fa e w m[ m .ctor() x Ju this.IsRegistered =
false; q dkw Jhstatement a Mu mi fhjz p fy gw , f/ ' Da e & mr Sm false t p m; true v dkU jy i fa y ; E dki fr , fq dk& i f . . .
t c ku Re fa w mfw dkU Mu n fha e w Jh decompile v ky fx m; w Jhu k' f[ m C# b mo mp u m; e JUjz p fy gw , f/ y Hk( 1 2 ) u dk
MSIL b mo mp u m; e JU Mu n fhv dku fMu & a t mi f/ y Hk( 1 3 ) /

y Hk( 1 3 )
y Hk( 1 3 ) u a w mh bytecode t a e e JU w dku f& dku fb mo mjy e fw my g/ .net y & dk* & r fa w Gu dk patch v ky fz dkUq dk& i f
a w mh IL b mo mp u m; t a e e JUo m Mu n fh& r Smjz p fy gw , f/ w u , fa w mh .net u dk stack machine v dkUa c : v dkU& y g
w , f/ b ma Mu mi fhv Jq dka w mh o lUt v ky fa w Gu dk register r Smx u f stack r Smv ky fv dkUy g/ Oy r mjy & & i f A u
w e fz dk; w p fc ku dk B u dka & TUc si fw , fq dk& i f A u w e fz dk; u dk stack a y : PUSH v ky fv dku fjy D; stack u a e r Sw q i fh B
a y : jy e f POP v ky fa y ; w mjz p fy gw , f/ t jc m; p e p fa w Gr Smq dk& i fa w mhA u a e B u dkw dku f& dku fa & TYa jy mi f; jc i f; ( o dkU)
, m, Dx m; & Sdz dkUt w Gu f register w p fc ku dkt o Hk; jy Kjc i f; r sdK; jy Kv ky fy gw , f/
y Hk( 1 3 ) u dk t a o t c sme m; v n fE dki fz dkU IL opcode a w Gt a Mu mi f; e m; v n fa e z dkUv dky gw , f/ y Hk( 1 3 ) u dk
Mu n fhr , fq dk& i f ' Du k' fE Sp fa Mu mi f; t w Gu f stack u dk t v Ge ft r i f; t o Hk; jy Kx m; w ma w GU& r Smy g/ this.IsRegistered
= false; p ma Mu mi f; t w Gu fu dky J a t mu fr Smjy x m; w Jht w dki f; stack e JUy w fo u fw Jhp ma Mu mi f; 3 a Mu mi f; a v mu f
b mo mjy e fx m; w ma w GU& y gw , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 294 -

L_0000: ldarg.0
L_0001: ldc.i4.0
L_0002: stfld bool Dot_Net_ReverseMe_2.frmMain::IsRegistered
' DIL instruction a w Gu dk IL reference t o Hk; jy Kjy D; b mo mjy e f& r , fq dk& i f . . .
ldarg.0 Argument 0 u dk stack a y : u l; w i fo n f/
ldc.i4.0 0 u dk stack a y : I4 t jz p f PUSH v ky fo n f/
stfld Object obj \ field w e fz dk; u dk val E Si fht p m; x dk; o n f/
' gu dk Object-Oriented & JU pseudo u k' ft a e e JUjy e fa & ; jy & & i fa w mh (arg0).IsRegistered = 0;
e JUw ly gw , f/ Register t a jc t a e jz p fa p z dkU jy e fjy i fa & ; o i fhw mu a w mh(arg0).IsRegistered = 1; jz p fy gw , f/
t " dy m, fu a w mh' kw d, instruction u dkldc.i4.1 v kdUa jy mi f; o i fhw , fv dkU q dkv dkjc i f; jz p fy gw , f/
' gu a w mh t a jc c Hu sw Jh cracking jz p fy gw , f/ ldc.i4.0 & JU bytecode u dkMu n fhy g/ 0x16 jz p fy gw , f/
ldc.i4.1 & JU bytecode u a w mh 0x17 jz p fy gw , f/ ' gq dk u Re fa w mfw dkU b mu dkt p m; x dk; & r v Jq dkw m o dy gjy D/
Reflector u u Re fa w mfw dkUu dk u k' fa w Go mjy y gw , f/ u Re fa w mfw dkUa jy mi f; c si fw Jh byte & Sd& m address u dkr jy y g
b l; / ' Dv dk byte/instruction a w G& JU virtual address u dkjy E dki fw Jh tool u dka w mh r a w GUb l; a o ; y gb l; / ' ga Mu mi fh
.ctor() u dkReflector r SmMu n fhr , fht p m; ILDasm e JUa jy mi f; Mu n fhv dku fy gr , f/ y Hk( 1 4 ) /

y Hk( 1 4 )
w u , fa w mh Method & Sd& m offset u dk& Sme n f; t a Mu mi f; u Re fa w mfw dkU a v hv mjy D; y gjy D/ ' Da e & mr Sma w mh
offset w e fz dk; u dk y Hka o e n f; e JU r w Gu fc su fa w mhb J 02 16 7D 06 00 00 04 02 28 0E 00 00 0A q dkw Jh hex
byte t w GJu dky Jhex editor w p fc kc kr Sm & dku fx n hfjy D; & SmMu n fhy gr , f/ y Hk( 1 5 ) /

y Hk( 1 5 )
o i fht a e e JU Mu dKu fw Jh hex editor w p fc kc ku dk t o Hk; jy KE dki fy gw , f/ t c ku Re fa w mft o Hk; jy Kx m; w mu a w mh
WinHex 15.2 y g/ y Hk( 1 5 ) t w dki f; & dku fx n hfjy D; & Smv dku f& i f y Hk( 1 6 ) t w dki f; jr i f& y gr , f/

y Hk( 1 6 )
y Hk( 1 6 ) t & q dk& i fa w mh .ctor() & Sd& m& JU offset t p [ m 0x105C jz p fy gw , f/ y dkjy D; a o c sma p c si f& i fa w mh
CFF explorer r SmMu n fhE dki fy gw , f/ y Hk( 1 6 ) u 16 a e & mr Sm 17 v dkUjy i fv dku fjy D; z dki fu dko dr f; v dku fy g/ o dr f; v dku fw Jh
z kdi fu dk jy e fz Gi fhMu n hfv dku f& i fa w mhy Hk( 1 7 ) t w dki f; a w GU& r Smy g/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 295 -


y Hk( 1 7 )
' gq dk& i fa w mh u Re fa w mfw dkU register v ky fw m a t mi fjr i fo Gm; y gjy D/ CheckReg() function u dk b , fu
a e a c : o Hk; o v Jq dkw m o dc si f& i fa w mh Reflector & JU CheckReg() function r Sm right-click E Sdy fjy D; Callee
Graph (Ctrl+E) u dka & G; jy D; Mu n fhv dkU& y gw , f/ y Hk( 1 8 ) /

y Hk( 1 8 )
Patch v ky fjy D; o dr f; v dku fw Jhz dki f& JU .ctor() u dk Reflector r SmMu n fhv dku f& i fa w mh y Hk( 1 9 ) t w dki f; jr i f& y g
w , f/

y Hk( 1 9 )
( 1 0 ) NsPack jz i fhpack v ky fx m; a o m .net z dki ft m; unpack v ky fjc i f;
y Hkr Se ft m; jz i fha w mho mr e f pack v ky fx m; w Jh32-bit PE z dki fa w Gr Smy J unpack v ky fz dkU Olly u dkt o Hk; jy KMu
w mjz p fy gw , f/ ' Dt c gr Sma w mh .net z dki fa w Gu dk Olly t o Hk; jy Kjy D; unpack v ky fjy r Smjz p fy gw , f/ Unpack v ky fz dkU
a & G; c s, fx m; w Jhy & dk* & r fu a w mh NsPack e JU pack v ky fx m; w Jh UnPackMe_NsPack3.6.exe z dki fjz p fy gw , f/
y & dk* & r fu dk z Gi fhMu n fhv dku fy g/ y Hk( 2 0 ) /
y Hk( 2 0 )
PEiD e JUp p fa q ; Mu n hfv dku f& i fa w mhy Hk( 2 1 ) t w dki f; a w GU& y gw , f/
y Hk( 2 1 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 296 -

a u mi f; jy D? y & dk* & r fu dk Olly r Smz Gi fhv dku fy g/ y Hk( 2 2 ) /

y Hk( 2 2 )
y Hk( 2 2 ) r Smjr i f& w Jht w dki f; exe z dki f[ m OEP r Sm& y fw e fUjc i f; r & Sdo v dk y & dk* & r f[ m t v dkt a v smu f run
a e y gw , f/ u Re fa w mfw dkU b mv ky fo i fhy go v J/ u Re fa w mfht a e e JU t Mu Hjy Kv dkw mu a w mh unpack v ky fx m; w Jhu k' f
a w Gu dk r Sw fOmP fx Jr Sm& Smz dkUy g/ ' ga Mu mi fh o w fr Sw fx m; w Jh string w p fc ku dk y & dk* & r f& JU resource x Jr Sm& Sm
Mu n fhy g/
& Smo i fhw Jh t r n fa w Gu a w mh button t r n f? window caption e JU messagebox w dkUe JUq dki fw Jh t c su f
a w Gjz p fy gw , f/ ' Da e & mr Sm u Re fa w mfw dkU& SmMu n fhr Smu a w mh y Hk( 2 0 ) r Smjr i f& w Jh button1 y g/ Resource a w Gu dk
exe/DLL z dki fa w Gx Jr Sm unicode t o Gi fe JU o dr f; Mu w mjz p fw Jht w Gu f Alt+M u dkE Sdy fjy D; button1 q dkw Jhp mo m; u dk
unicode t a e e JU & SmMu n fhMu & a t mi f/ y Hk( 2 3 ) /

y Hk( 2 3 )
y Hk( 2 3 ) t w dki f; & dku fx n fhjy D; & Smv dku f& i f y Hk( 2 4 ) t w dki f; a w GU& y gr , f/

y Hk( 2 4 )
y Hk( 2 4 ) u dk Text Unicode (64 chars) e JUMu n fhv dku f& i fa w mhy Hk( 2 5 ) t w dki f; a w GU& r Smy g/

y Hk( 2 5 )
' Da e & mr Sma jy mv dkw mu a w mh y Hk( 2 4 ?2 5 ) r Smjr i fa e & w Jh virtual address a w G[ m o i fu Ge fy sLw mr Smjr i f& w Jh
* P e f; a w Ge JU w lr Smr [ kw fy gb l; / a e mu fjy D; c ku Re fa w mfw dkUa & mu f& Sda e w Jha e & m[ m resource section x Jr Smr [ kw f
y gb l; / ' ga Mu mi fhr dkU Alt+M E Sdy fjy D; Ctrl+L e JU x y f& SmMu n fhy gr , f/ y Hk( 2 6 ) /
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 297 -


y Hk( 2 6 )
y Hk( 2 6 ) r Sm a e mu fx y f button1 w p fc ku dka w GU& jy e fy gjy D/ _CorExeMain u dka w GUr dy go v m; / ' gu a w mh
.net application a w Gr Smo m& Sdw Jh w p fc kw n f; a o m API y g/ Unicode view t a e e JUMu n fhv dku f& i f y Hk( 2 7 )
t w dki f; a w GYy gw , f/

y Hk( 2 7 )
y Hk( 2 7 ) t w dki f; q dk& i fa w mhu Re fa w mfw dkU resource section x Ja jc c sr djy Dq dkw m a o c smy gw , f/

y Hk( 2 8 )
a u mi f; jy D? y Hk( 2 7 ) u dk HEX view t a e e JUjy e fMu n fhjy D; t a y : u dk scroll e n f; e n f; q GJjy D; Mu n fhv dku f& i f
a w mhy Hk( 2 8 ) r Sm jr i f& w Jht w dki f; PE header & Sd& mu dk a w GU& r Smy g/

y Hk( 2 9 )
y Hk( 2 8 ) u MZ & Sd& m virtual address (00CD0000) u dkr Sw fo m; jy D; LordPE u Dump Region
u dka & G; c s, fjy D; Dump button u dka & G; c s, fy g/ ' gq dk unpack v ky fw ma t mi fjr i fo Gm; jy Djz p fy gw , f/ Dump
v ky fx m; w Jh Region00CD0000-00CD2000.exe z dki fu dk PEiD e JUp p fMu n fh& i fa w mh Microsoft .net b mo m
p u m; e JUa & ; o m; x m; a Mu mi f; jy r Smy g/

t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 298 -

( 1 1 ) .net y & dk* & r fr Sserial z r f; jc i f;
' Dw p fc gr Sma w mh .net e JU y w fo u fw Jh serial fishing t a Mu mi f; u dk a v hv mr Smjz p fy gw , f/ Byte a w Gu dk
patch v ky fw m[ m t jr Jw r f; a w mh t q i fa jy r Sm r [ kw fy gb l; / q dkv dkw mu r Se fu e fp Gm register v ky fx m; jc i f;
& Sd^ r & Sdu dk e n f; r sdK; p Hke JU r Mu mc P p p fa q ; a v h& Sdw Jh y & dk* & r fa w Gt w Gu f ' De n f; v r f; [ m t q i fa jy r Sm r [ kw fy gb l; /
' ga Mu mi fhr dkUv J serial z r f; jc i f; t a Mu mi f; u dk a q G; a E G; & jc i f; jz p fy gw , f/ ' Do i fc e f; p mt w Gu f v dkt y fw Jhy & dk* & r f
u a w mhCrackme1.exe jz p fjy D; www.accessroot.com r Sm download v ky f, lE dki fy gw , f/
' Dy & dk* & r fu dk Visual Dot.net e JUa & ; o m; x m; w mu dk o djy D; o m; jz p fw mr dkU PEiD e JU r p p fa w mhy gb l; /
Crackme1.exe u dkz Gi fhjy D; y & dk* & r f& JU o a b mo b m0 u dk a v hv mMu n fhv dku fMu & a t mi f/ y Hk( 3 0 ) /

y Hk( 3 0 )
y Hk( 3 0 ) r Smjr i f& w Jht w dki f; user name e JU serial u dk& dku fx n fhjy D; Check button u dkE Sdy fv dku fc sde fr Sma w mh
y Hk( 3 1 ) t w dki f; jr i f& y gw , f/

y Hk( 3 1 )
' Da v mu fq dk u Re fa w mfw dkU o dc si fw ma w Go d& jy Dr dkU Crackme1.exe u dk .NET reflector r Smz Gi fhMu n fhy g
r , f/ y Hk( 3 2 ) /

y Hk( 3 2 )
btnCheck_Click u dk a & G; v dku fw Jht c gr Sma w mhy Hk( 3 2 ) t w dki f; jr i f& w mjz p fy gw , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 299 -

' Do i fc e f; p mr Sm u Re fa w mfw dkU p dw f0 i fp m; w mu serial routine r [ kw fy gb l; / a e mu fq Hk; x kw fa y ; v dku fw Jh
serial [ m b mv Jq dkw mu dko m o dc si fw my g/ .NET reflector [ m .net u k' fa w Gu dk Mu n fh& I& mr Sm t a u mi f; q Hk;
tool jz p fa y r , fhv J u k' fa w Gu dkw n f; jz w fjc i f; ? debug v ky fjc i f; w dkU jy Kv ky fa y ; E dki fjc i f; r & Sdy gb l; / ' ga Mu mi fh Myo
Myint Htike q dkw Jhuser name e JUo u fq dki fw Jhserial u dk& SmE dki fz dkU PEBrowse Professional Interactive 9.0
u dkt o Hk; jy KMu y gr , f/ ' Dtool u dk t o Hk; r jy Kc i fr Sm setting a w Gu a t mu fy gt w dki f; jz p f& y gr , f/ y Hk( 3 3 ^ 3 4 ) /

y Hk( 3 3 )

y Hk( 3 4 )
y Hk( 3 3 ^ 3 4 ) t w dki f; setting a w Gu dk jy i fjy D; & i fa w mhCtrl+S u dkE Sdy fjy D; debug v ky fz dkUp w i fy g/ y Hk( 3 5 ) /

y Hk( 3 5 )
y Hk( 3 5 ) & JU b , fz u ft jc r f; r Sm t e Da & mi fjz p fa e w mu t v ky fv ky fa e w mu dk jy w my g/ u Re fa w mfw dkUt a e e JU
y & dk* & r fu k' fw p fa Mu mi f; c si f; p Du dk p p fa e r Sm r [ kw fy gb l; / u k' fa w Gu dk p p fa q ; w Jh shortcut key a w Gu a w mh Olly
e JUw lr Smr [ kw fy gb l; / PEBrowse & JU key a w Gu a w mhRun(F5)? Step over(F10)? Step into(F11) t o D; o D;
jz p fy gw , f/ a u mi f; jy D? u Re fa w mfw dkU p p fa q ; c si fw Jha e & mu dk t jr e fa & mu fz dkU breakpoint o w fr Sw fMu & a t mi f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 300 -

y Hk( 3 5 ) u .NET Methods u dkE Sdy fjy D; btnCheck_Click u dka & G; v dku fy g/ y Hk( 3 6 ) /

y Hk( 3 6 )
y Hk( 3 6 ) u a w mh serial routine u dk IL b mo mp u m; t a e e JU jr i f& w my g/ IL_00B3 a e & mr Sm F9 E Sdy fjy D;
breakpoint o w fr Sw fy gr , f/ ' gq dk& i fa w mh u Re fa w mfw dkU breakpoint o w fr Sw fx m; w Jha e & mu dk y Hk( 3 7 ) t w dki f;
jr i f& r Smjz p fy gw , f/

y Hk( 3 7 )
Breakpoint o w fr Sw fjy D; o Gm; & i fa w mhF5 u dkE Sdy fjy D; y & dk* & r fu dk run y g/

y Hk( 3 8 )
y & dk* & r fu dk run w Jht c g y Hk( 3 8 ) t w dki f; w p fc ka y : v my gv dr fhr , f/ F5 u dkx y fE Sdy fy g/ ' gq dk y Hk( 3 9 ) t w dki f;
y & dk* & r fw u fv my gv dr fhr , f/

y Hk( 3 9 )
y Hk( 3 9 ) t w dki f; jr i f& w Jht c gr Sm user name e JU serial u dk& dku fx n fhjy D; check button u dka & G; a y ; y g/ y Hk( 4 0 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 301 -


y Hk( 4 0 )
y Hk( 4 0 ) r Sm jr i f& w mu a w mh u Re fa w mfw dkU breakpoint o w fr Sw fx m; w Jha e & mu dk a & mu fa e w my g/ > u
v u f& Sdassemble v ky fr , fha e & mu dk jy o y gw , f/

y Hk( 4 1 )
y Hk( 4 1 ) u a w mh register window jz p fy gw , f/ Disassembly window r Sm F10 u dkE Sdy fjy D; u k' fa w Gu dk
w p fa Mu mi f; c si f; p p fw Jht c gr Sma w mh register window r Sm b ma w Ga jy mi f; v Jo Gm; w , fq dkw mu dk o w dx m; jy D; a p mi fh
Mu n fh& y gr , f/ y Hk( 4 2 ) t w dki f; VA 0x40E89B0 x da & mu fw Jht x dF10 u dkE Sdy fv mc Jhy g/

y Hk( 4 2 )
y Hk( 4 2 ) r Sm floating-point w e fz dk; E Sp fc ku dk E Idi f; , SOfw m a w GU& y gw , f/ Floating-point e JUy w fo u fw Jh
mnemonics a w Gu dkMu n fhMu & a t mi f/
FILD load integer
FSTP store floating-point value and pop
FLD load floating-point value
FCOMIP compare floating-point, set %e flags, and pop
FSTP store floating-point value and pop
JPE u a w mhJump if Parity even jz p fjy D; flag (PF) w e fz dk; 1 jz p f& i f jump jz p fr Smjz p fy gw , f/ JNZ
u a w mhJump if Not Zero jz p fjy D; flag (ZF) w e fz dk; 0 jz p f& i f jump jz p fr Smjz p fy gw , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 302 -


y Hk( 4 3 )
FCOMIP u floating-point w e fz dk; E Sp fc ku dkE dIi f; , SOfjy D; parity flag u dko w fr Sw fy gw , f/ o lE dIi f; , SOf
w Jh w e fz dk; E Sp fc ku a w mh 4458204637983 e JU 4101979 w dkUjz p fy gw , f/ ' Dw e fz dk; E Sp fc ku dk E dIi f; , SOfw Jht c gr Sm r n D
w Jht w Gu f parity flag w e fz dk; u dk o kn v dkUo w fr Sw fy gw , f/ Parity flag w e fz dk; [ m 0 v m; ? 1 v m; o dc si f& i f
a w mhregister window r Sm right-click E Sdy fjy D; EFLAGS u dka & G; & y gr , f/ y Hk( 4 4 ) /

y Hk( 4 4 )
y Hk( 4 4 ) u a w mh FCOMIP instruction u dk v ky fa q mi fjy D; c sde fjz p fy gw , f/ Parity flag [ m 0
jz p fa e y gw , f/ FSTP instruction u dko Hk; jy D; 4101979 w e fz dk; u dk o dr f; y gw , f/ Parity flag [ m 0 jz p fw Jh
t w Gu f JPE 0x40E89C6 [ m VA 0x40E89C6 q Djump r jz p fE dki fa w mhy gb l; / JNZ 0x40E89C6 u a w mh
1 r jz p fw Jht w Gu f VA 0x40E89C6 q DVA 0x40E89C6 v ky fr Smjz p fy gw , f/ y Hk( 4 5 ) /

y Hk( 4 5 )
' ga Mu mi fhv J F5 E Sdy fv dku fw Jht c sde fr Sm u Re fa w mfw dkUr jr i fc si fw JhBadBoy message u dkjr i f& w my g/ y Hk( 4 6 ) /

y Hk( 4 6 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 303 -

Myo Myint Htike q dkw Jh user name t w Gu f serial textbox r Sm u Re fa w mfw dkU& dku fx n fhv dku fw Jh
4101979 u dk Crackme1.exe u w Gu fc su fv dkU& v mw Jh 4458204637983 w e fz dk; e JU E dIi f; , SOfw mjz p fy gw , f/
' ga Mu mi fh Myo Myint Htike q dkw Jh user name t w Gu f serial textbox r Sm u Re fa w mfw dkU t r Se fw u , f
& dku fx n fh& r , fh* P e f; [ m . . .
a u mi f; jy D/ PEBrowse u dky dw fv dku fy g/ Crackme1.exe u dko D; o e fUz Gi fhjy D; y Hk( 4 7 ) t w dki f; register
v ky fMu n fhy gr , f/

y Hk( 4 7 )
' gq dk& i fa w mhy Hk( 4 8 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 4 8 )
.net y & dk* & r fa w Gr Sm serial & Sm& w m t & r f; v G, fv Ge f; w , fv dkU x i fr dy go v m; /
' gq dk& i fa w mh o i fx i fw m r Sm; o Gm; jy Djz p fy gw , f/ b ma Mu mi fhv Jq dkw m & Si f; & Si f; v i f; v i f; o d& a t mi fv dkU
y & dk* & r fw p fy k' fu dk e r le mjy y gr , f/ y Hk( 4 9 ) /

y Hk( 4 9 )
' Dy & dk* & r fu dk b , fv dka & ; x m; o v Jq dkw m o dE dki fa t mi fv dkU .NET reflector r Smp p fMu n fhy gr , f/ y Hk( 5 0 ) /

y Hk( 5 0 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 304 -

y Hk( 5 0 ) u u dkE Sdy fv kdu f& i fa w mhy Hk( 5 1 ) t w dki f; jr i f& y gw , f/
public Registration()
{
this.components = null;
this.InitializeComponent();
this.pictureReg.Image = Image.FromFile("Picture/nag_close.png");
StringBuilder volumeName = new StringBuilder(0x100);
StringBuilder fs = new StringBuilder(0x100);
bool flag = false;
Environment.GetLogicalDrives();
flag = GetVolumeInformation("c:", volumeName, (uint) (volumeName.Capacity - 1), out this.serialNum, out
this.serialNumLength, out this.flags, fs, (uint) (fs.Capacity - 1));
for (int i = 0; i <= 13; i++)
{
this.serialNum = (((((2 * this.serialNum) / 7) - (12 * this.serialNum)) + (11 * this.serialNum)) - 0x239875) ^
this.serialNum;
}
this.textcode.Text = this.serialNum.ToString();
}
y Hk( 5 1 )
y Hk( 5 1 ) u a w mhregistration dialog u dka & G; v dku fc sde fr Sm y & dk* & r fu initialize v ky fw mjz p fy gw , f/
u dkE Sdy fv kdu f& i fa w mhy Hk( 5 2 ) t w dki f; jr i f& y gw , f/
private void butOK_Click(object sender, EventArgs e)
{
string text;
FileStream stream;
BinaryWriter writer;
long num2 = Convert.ToInt64(this.serialNum);
long num4 = 0x1fca055L;
for (int i = 0; i <= 30; i++)
{
num2 = (7L * num2) ^ (num4 + 0x23c1bcL);
}
string strB = Convert.ToString(num2);
if (string.Compare(this.textregcode.Text, strB) == 0)
{
MessageBox.Show("Registered successfully!\r\nThank you for buying our product!", "Registration Successful!",
MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
if (this.passControl != null)
{
this.passControl(this.textname);
}
base.Hide();
text = this.textname.Text;
stream = new FileStream("reg.key", FileMode.Create);
writer = new BinaryWriter(stream);
try
{
writer.Write(this.serialNum);
writer.Write(text);
}
finally
{
writer.Close();
stream.Close();
}
Registry.SetValue(@"HKEY_CURRENT_USER\Software\Myanmar Cracking Team\Windows Repair",
"UserName", text, RegistryValueKind.String);
}
y Hk( 5 2 )
y Hk( 5 1 ) u u k' fa w Gu a w mh y Hk( 5 0 ) r Smjr i f& w Jh t w Gu fjz p fy gw , f/
w u , fa w mh Windows Repair 1.0 y & dk* & r f[ m u Re fa w mfw dkU harddisk u C: drive & JU serial number
u dkz w fjy D; XOR v ky fy gw , f/ XOR v ky fx m; w Jhw e fz dk; u a w mh 3538139584 jz p fy gw , f/ jy D; a w mh u Re fa w mf
& dku fx n hfv dku fw Jh 4101979 u dk XOR v ky fjy D; & v mw Jhw e fz dk; w p fc ke JU E dIi f; , SOfw mjz p fy gw , f/ w u , fv dkU serial
number [ m r Se fu e fc Jhr , fq dk& i f reg.key z dki fr Sm & dku fx n fhv dku fw Jh serial number u dko dr f; r Smjz p fjy D;
GoodBoy message u dk jy r Smjz p fy gw , f/ u Re fa w mfht a e e JU PEBrowse e JU serial-fishing v ky f& mr Sm
3538139584 u k' ft w Gu f HEX w e fz dk; EAEF9EBE & v my gw , f/ ' Dw e fz dk; u dk decimal w e fz dk; a jy mi f; jy D;
registration dialog r Sm& dku fx n hfv dku fw Jht c gr Sma w mh y & dk* & r fu serial r Sm; a e y gw , fv dkU a jy my gw , f/
( w u , fa w mh u Re fa w mfw dkUu dk jy o w Jh 3538139584 [ m * P e f; r [ kw fb J p mo m; a w Gjz p fa e y gw , f/
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 305 -

PEBrowse [ m p mo m; a w Gu dk u dki fw G, fE dki fjc i f; r & Sdy gb l; / ' ga Mu mi fh u Re fa w mfw dkU & dku fx n hfw Jh* P e f; w dki f; [ m
r Sm; a e w mjz p fy gw , f/ )
' ga Mu mi fh ' Dv dkjy e mr sdK; Mu HKa w GUc Jhr , fq dk& i fa w mh PEBrowse e JU serial & Smr , fht p m; Visual
Studio.net e JU y & dk* & r fjy e fa & ; & r Sm jz p fy gw , f/ y & dk* & r fu dk o D; o e fUa & ; p & mr v dky gb l; / string strB = Convert.
ToString(num2); a e & ma t mu fe m; r Sm this.textcode.Text = strB; v dkU jy i fa & ; v dku f& Hky gy J/
e d* Hk; c sKy ft a e e JU a jy mv dkw mu a w mh t c k serial & Smjy c Jhw m[ m t v Ge f& dk; & Si f; v Sw Jh serial routine a w Ge JU
y g/ o i fht a e e JU a & mi f; w e f; 0 i fa q mhz f0 Jv fa w Gu dk crack v ky fr , fq dk& i fa w mh ' Dx u f t q a y gi f; & me JUc sDjy D; c u fc J
v Sw Jhserial routine a w Ge JU a w GU& r Smjz p fy ga Mu mi f; . . .
( 1 2 ) .net y & dk* & r fr SStrong Name Signature t m; z , f& Sm; jc i f;
Strong Name Signature e JUy w fo u fjy D; t e n f; i , fa jy m& r , fq dk& i fa w mh StrongName w p fc kr Sm
y & dk* & r fe JUy w fo u fw Jh assembly & JU identity a w Gy g0 i fjy D; o lw dkUa w Gu a w mh & dk; & Si f; v Sw Jhp mo m; a w Ge JU t r n f?
version t r Sw f? culture w dkUt jy i f public key w p fc ke JU digital signature w p fc kw dkU y g0 i fE dki fy gw , f/
' ga w Gu dk assembly z dki fw p fc ku a e o u fq dki f& m private key u dkt o Hk; jy Kjy D; x kw fa y ; w mjz p fy gw , f/ ( ' Dz dki fr Sm
assembly manifest a w Gy gjy D; t jy e ft v Se ft m; jz i fh assembly manifest r Smv J assembly u dkjy Kjy i fa y ; w Jh
z dki fa w Gt m; v Hk; & JU hash a w Ge JU t r n fa w Gy g0 i fy gw , f/ ) Microsoft Visual Studio e JU .NET framework
u dkt o Hk; jy KMu w Jht jc m; tool a w G[ m StrongName a w Gu dk assembly w p fc kt a e e JU o w fr Sw fE dki fy gw , f/
' Do i fc e f; p mr Sm .net exe z dki fa w Ge JU .net DLL z dki fa w Gr Sm& Sdw Jh & dk; & Si f; v Sw Jh StrongName (SN) a w Gu dk
b , fv dkz , f& Sm; & r v Jq dkw m a v hv mMu r Smjz p fy gw , f/
w p fc kw n f; a o m exe^ DLL z dki fx Jr Sm& Sdw JhSN a w Gu dkz , f& Sm; z dkU e n f; v r f; t c sdKU & SdMu y gw , f . . .
t & dk; & Si f; q Hk; e n f; v r f; u a w mh y & dk* & r fu dk IL u k' fa w Gt a e e JU decompile v ky fjy D; SN u dkz , f& Sm; w mjz p f
y gw , f/ SN z , f& Sm; jy D; & i fa w mh ILASM.exe z dki fu dk t o Hk; jy Kjy D; compile jy e fv ky fw mjz p fy gw , f/ ' gu a w mh
v Hk; 0 y n mo m; r y gw Jhe n f; v r f; jz p fy gw , f/ o i fht a e e JU p D; y Gm; jz p fa q mhz f0 Jv fa w Gu dk' Dv dke n f; o Hk; jy D; jy e f compile
v ky fv dkU& r , fv dkU r x i fv dku fy ge JU/ b ma Mu mi fhv Jq dka w mh ' Dy & dk* & r fa w Gr Sm u k' fa w Ge JU function t r n fa w Gu dk
obfuscation v ky fx m; v dkUy g/
t jc m; e n f; w p fc ku a w mh PE header u dkt o Hk; jy Kjy D; SN u dk patch v ky fz dkUt w Gu f t o Hk; 0 i fw Jht c su f
t v u ft c sdKUu dk & , lz dkUy g/ ' Dv dkv ky fz dkUt w Gu f o i fht a e e JU z dki fE Sp fz dki f v dky gw , f/ w p fc ku a w mh SN e JUjz p fjy D;
a e mu fw p fc ku a w mh SN r y gw Jhz dki fjz p fy gw , f/ jy D; & i f o lw dkU& JU PE header a w Gu dk CFF explorer e JU E dIi f; , SOf
& r Smjz p fy gw , f/
' Do i fc e f; p mt w Gu f a & G; x m; w Jh y & dk* & r fu a w mh StrongName.exe jz p fjy D; www.tuts4you.com r Sm
download v ky f, lE kdi fy gw , f/ StrongName.exe y & dk* & r fu dkz Gi fhv dku f& i fa w mh y Hk( 5 3 ) t w dki f; jr i f& r Smjz p fy g
w , f/

y Hk( 5 3 )
w u , fa w mh ' Dy & dk* & r fr Sm x l; x l; a x Ga x G crack v ky fp & mb mr Sr & Sdy gb l; / ' ga Mu mi fh useless q dkw Jh
p mo m; t p m; patched v dkUa jy mi f; Mu n fhMu & a t mi f/ ' gu dka w mhWinHex t o Hk; jy Kjy D; jy i fv dkU& y gw , f/ y Hk( 5 4 ) /

y Hk( 5 4 )
y Hk( 5 4 ) t w dki f; jy i fjy D; & i fa w mhz dki fu dko dr f; jy D; jy e fz Gi fhv dku fy g/ y Hk( 5 5 ) /
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 306 -


y Hk( 5 5 )
y & dk* & r fu SN u dkp p fw ma Mu mi fh u k' fu dke n f; e n f; a v ; jy i fv dku fw me JU ' Dv dk error w u fv mw mjz p fy g
w , f/ ' ga Mu mi fh SN & Sdw Jhz dki fe JU SN r & Sdw Jhz dki f b ma w Gu Gmv Jq dkw m e n f; e n f; a v ; Mu n fhv dku fMu & a t mi f/ No
StrongName.exe z dki fe JU StrongName.exe z dki fw dkUu dk CFF explorer r Sm z Gi fhMu n fhy gr , f/ y Hk( 5 6 ?5 7 ) /

y Hk( 5 6 ) SN r & Sda o m No StrongName.exe z dki f

y Hk( 5 7 ) SN & Sda o m StrongName.exe z dki f
Flag a e & mu 1 q dkw mu a w mh COMIMAGE_FLAGS_ILONLY jz p fjy D; 9 q dkw mu a w mh
COMIMAGE_FLAGS_ILONLY | COMIMAGE_FLAGS_STRONGNAMESIGNED v dkUq dkv kdw m
y g/ y Hk( 5 8 ) /
y Hk( 5 8 )
' ga Mu mi fh' Dw e fz dk; a w Gu dk& Smjy D; patch v ky f& r Smjz p fy gw , f/
MetaData Streams & JU Tables directory u dk Mu n fhMu & a t mi f/ y Hk( 5 9 ) /

y Hk( 5 9 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 307 -

Tables directory a t mu fu Assembly u dkMu n fhv dku f& i fa w mhy Hk( 6 0 ?6 1 ) t w dki f; jr i f& y gr , f/

y Hk( 6 0 ) SN r & Sda o m No StrongName.exe z dki f

y Hk( 6 1 ) SN & Sda o m StrongName.exe z dki f
StrongName u dk z , f& Sm; z dkU StrongName.exe z kdi f& JU offset a w Gr Sm a t mu fy gt w dki f; jy i fa y ; & y gr , f-
Offset 1018 Flags 01
Offset 1028 StrongNameSignature RVA 00
Offset 102C StrongNameSignature Size 00
Offset 1554 Flags 00
Offset 1558 PublicKey 00
w u , fv dkU DLL z dki fw p fc ku dk exe z dki fw p fc ku a e a c : , lo Hk; w mjz p fjy D; ' DDLL z dki fx Jr Sm registration
routine u dka & ; o m; x m; c Jhr , fq dk& i f u Re fa w mfw dkUt a e e JU DLL z dki fu dk patch v ky f& r Smjz p fy gw , f/ ' Dw p fc g
e r le mjy r , fh y & dk* & r fu a w mh Divelements Limited u x kw fw Jh Navsight y g/ Navsight a q mhz f0 Jv fr Sm
Demo.exe e JU Navsight.dll z dki fw dkUy g& Sdy gw , f/
Demo.exe u dkz Gi fhjy D; Show ExplorerBar Demonstration u dka & G; r , fq dk& i f y Hk( 6 2 ) t w dki f; jr i f& y gw , f/

y Hk( 6 2 )
OK button u dk E Sdy fv dku f& i fa w mhy Hk( 6 3 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 6 3 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 308 -

y Hk( 6 3 ) & JU n mz u fr Sm& Sdw JhAnimate! button u dkE Sdy fv dku f& i fa w mhb , fz u fu task pane [ ma y smu fo Gm;
r Smjz p fy gw , f/ a u mi f; jy D? u Re fa w mfw dkUt a e e JU ' ga w Gu dk jy i fz dkUv dky gr , f/ ' ga y r , fhSN u dk y x r q Hk; z , f& Sm; & y g
r , f/ Navsight.dll z dki fx Ju RSA1 q dkw Jhp mo m; u dk WinHex r Sm& Smjy D; o lUr w dki fc i fr Sm& Sdw Jh 2 1 c ka jr mu fe JU
2 2 c ka jr mu f p mv Hk; a w G(80 0A)u dk 00 00 v dkUa jy mi f; v dku fy g/ y Hk( 6 4 ) / ( SN u dkz , f& Sm; w Jh ' De n f; u a w mh
UnREalRCE {Persian Crackers} u Newbie_Cracker & JUe n f; jz p fy gw , f/ )

y Hk( 6 4 )
y Hk( 6 4 ) u Navsight.dll z dki fu dk 80 0A t p m; 00 00 v dkUa jy mi f; jy D; z dki fu dko dr f; v dku fy g/ ' Dha e mu f
demo.exe z dki fu dkz Gi fhMu n fhw Jht c gr Sma w mhy Hk( 6 5 ) t w dki f; error w u fa e w m a w GU& y gw , f/

y Hk( 6 5 )
e n f; e n f; a v mu f p Of; p m; Mu n fh& a t mi f/ u Re fa w mfw dkU[ m DLL z dki fu a e SN u dkz , f& Sm; c Jhy gw , f/
u Re fa w mfw dkU o Hk; c Jhw Jhe n f; u v J t a u mi f; q Hk; y g/ ' gq dkb mv dkU jy e mw u fa e & w my gv J/ SN u dk a e mu fx y f
p p fa q ; r Ia w Gr sm; x y f& Sda e v dkUv m; / w u , fv dkU SN u dkp p fa q ; w mq dk& i fa w mh DLL x Jr Sma w mh r [ kw fa v mu fy g
b l; / exe z dki fx Jr Smy J jz p fy gv dr fhr , f/ Error message jz p fw JhCould not load file with PublicKeyToken =
75b7... u dkMu n fhy g/ ' gu dkp p fa q ; E dki fz dkU Demo.exe u dk CFF explorer e JUz Gi fhjy D; .NET Directory
r Sm& SmMu n fhy g/ y Hk( 6 6 ) /

y Hk( 6 6 )
y Hk( 6 6 ) u Navisight u dkMu n fhr , fq dk& i fa w mhy Hk( 6 7 ) t w dki f; jr i f& y gr , f/

y Hk( 6 7 )
' gu a w mh u Re fa w mfw dkU v dkc si fw Jht c su fy g/ PublicKeyOrToken u dkMu n fhy g/ o i fht a e e JU exe z dki f
w p fc kt jz p f compile v ky fp Ofr Sm .NET compiler u module t o D; o D; & JU PublicKey u dk o lUt r n fa w Gv dky J
o dr f; x m; a y ; w mjz p fjy D; v kdc si fw Jh module & JU PublicKey u dk& Smjy D; p p fa q ; & mr Sm reference w p fc kt a e e JU
PublicKeyOrToken u dkt o Hk; jy Kw my g/ ' ga Mu mi fh ' Da e & mr Sm 0 v dkUa jy mi f; v dku f& i f y Hk( 6 5 ) u error message
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 309 -

a y : v ma w mhr Sm r [ kw fy gb l; / Demo.exe z dki f& JU Offset 0x26324 a e & mr Sm 0 v dkUjy i fjy D; z dki fu dk o dr f; v dku fy g/
Demo.exe z dki f a u mi f; a u mi f; t v ky fv ky fw ma w GU& r Smy g/
' gq dk Navsight.dll z dki fu dk patch v ky fv dkU& jy Djz p fy gw , f/ Navsight.dll z dki fu dk IDA Pro e JU
Reflector w dkUr Smz Gi fhjy D; evaluation period u dk& Smy g/
.method public static hidebysig bool '() // CODE XREF: sub_2840+72_p
// sub_33A0+77_p ...
{
.locals init (bool V0,
class System.String V1,
class System.String V2,
class System.String[] V3)
call bool '::'()
stloc.0
ldloc.0
brfalse.s loc_3272
call class [mscorlib]System.Reflection.Assembly
[mscorlib]System.Reflection.Assembly::GetExecutingAssembly()
callvirt class [mscorlib]System.Reflection.AssemblyName
[mscorlib]System.Reflection.Assembly::GetName()
callvirt class System.String [mscorlib]System.Reflection.AssemblyName::get_Name()
stloc.1
ldc.i4.5
newarr [mscorlib]System.String
stloc.3
ldloc.3
ldc.i4.0
ldstr "Your evaluation period for "
stelem.ref
ldloc.3
ldc.i4.1
ldloc.1
stelem.ref
ldloc.3
ldc.i4.2
ldstr " has expired. Product functionality will be limited."
y Hk( 6 8 ) IDA Pro jz i fhz Gi fhx m; y Hk
y Hk( 6 8 ) u dkMu n fhr , fq dk& i f call function() a e mu fr Sm brfalse u dka w GU& y gw , f/ b mr Sr v ky f& a o ; c i fr Sm
function t r n fa w Gu dk& SmMu n fhy g/ Function t r n fa w Gu dk obfuscation v ky fx m; w Jht w Gu f r a w GU& y gb l; / ' D
DLL z dki fu dk o i f compile jy e fjy D; v ky fE dki fy go v m; / Reflector r Smv Jt Mu mMu D; v dku f& Smjy D; w Jha e mu fr Sm
y Hk( 6 9 ) t w dki f; a w GU& y gw , f/

y Hk( 6 9 )
y Hk( 6 9 ) u dkMu n fhv dku fjy e fa w mhv J function a w Gu dk obfuscation v ky fx m; w ma w GU& y gw , f/ t r Se fu
a w mh flag w e fz dk; [ m 0 jz p f& y gr , f/ ' gq dk flag w e fz dk; 0 u dk return jy e fy dkUr , fh function u b , fa e & mr Sm
& Sda e y go v J/
y Hk( 6 8 ) u IDA Pro u dko Gm; jy D; call bool '::'() a e & mu dk E Sdy fv dku fy g/ t e n f; i , f& Iy fa x G; w Jhu k' fa w Gu dk
a w GU& y gr , f/ u Re fa w mfw dkUt a e e JU function & JU return w e fz dk; u kd FALSE v dkUjy i fv dkU& y gw , f/ ' ga y r , fh
t E & m, f& SdE dki fw Jhu k' fa w Gy g^ r y g o dE dki fa t mi fv dkU a t mu fu dke n f; e n f; scroll q GJMu n fhv dku fy g/
y Hk( 7 0 )
t c e f; ( 1 9 ) Visual Dot.net jz i fha & ; o m; x m; a o m y & dk* & r fr sm; u dk crack v ky fjc i f;
- 310 -

' gu dk Reflector r SmMu n fhy gr , f/ y Hk( 7 1 ) /

y Hk( 7 1 )
DLL u registry x Jr Sm NETFramework key & Sd^ r & Sdp p fa q ; jy D; & Sdc Jh& i f Demo.exe u dk y x r q Hk;
z Gi fhc Jhw Jh & u fp GJe JUt c sde fu dk r Sw fo m; x m; jy D; v u f& Sd& u fp GJe JUt c sde fu dkw Gu fc su fjy D; E dIi f; , SOfy gw , f/ w u , fv dkU
v u f& Sdt c sde f[ m y x r q Hk; z Gi fhc Jhw Jht c sde fx u f & u f3 0 y dka e c Jh& i f return w e fz dk; [ m TRUE jz p fjy D; ? ' Dv dkr Sr [ kw f
& i fa w mh FALSE jz p fr Smy g/ ' ga Mu mi fh t E & m, f& SdE dki fw Jhu k' fa w G? function a w Gr & Sda w mhb l; q dkr S u Re fa w mfw dkU
t a e e JU return w e fz dk; u dk 0 v dkU patch v ky fv dkU& r Smjz p fy gw , f/
Patch v ky fz dkUt w Gu f function & JU offset t p & Sd& m 0x4784 q Do Gm; jy D; 16 2A v dkUjy i fjy D; z dki fu dk o dr f; y g
r , f/ b ma Mu mi fhjy i f& w mv Jq dkw m o d& a t mi f y Hk( 6 8 ) u dk jy e fMu n fhy g/
IDA View opcode (CFF Explorer) Instruction (CFF Explorer)
call class [mscorlib]System.Reflection.Assembly 28 E7 00 00 0A call 0x0A0000E7
callvirt class [mscorlib]System.Reflection 6F E8 00 00 0A callvirt 0x0A0000E8
y Hk( 7 2 )
y Hk( 7 2 ) u a w mh Offset 0x4784 r Sm 16 2A v dkU patch r v ky fc i f IDA Pro e JU CFF explorer w dkUr Sm
jr i f& w my g/
IDA View opcode (CFF Explorer) Instruction (CFF Explorer)
ldc.i4.0 16 ldc.i4.0
ret 2A ret
y Hk( 7 3 )
y Hk( 7 3 ) u a w mh Offset 0x4784 r Sm 16 2A v dkU patch v ky ft jy D; IDA Pro e JU CFF explorer w dkUr Sm
jr i f& w my g/ ldc.i4.0 q dkw mu a w mh stack a y : int32 w e fz dk; w p fc ku dk o kn t a e e JU u l; w i fv dku fw my g/
q dkv dkw mu a w mhcall a w Gu dk r p p fa p a w mhy J 0 w e fz dk; u dk return jy e fy dkUv dku fw mjz p fy gw , f/
jy i fx m; w Jhy & dk* & r fu dk jy e fz Gi fhc sde fr Sma w mhexpiration dialog a y smu fo Gm; r Smjz p fy gw , f/

t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 311 -

tcef;(20) - rdkbdkif;zkef; application rsm;udk crack vkyfjcif;
' Dw p fc gr Smaw mhr dkb dki f; z ke f; (smartphone) aw Gr Sm t o Hk; jy Kw Jhapplication aw Gu dkcrack v ky fMu n fhr Sm
jz p fy gw , f/ Mu dKw i far w m&y fc Hv dkw mu aw mh mobile cracking e JUy w fo u fw Jh o i fc e f; p mr sm; u v J &Sm; y g; w m
u w p faMu mi f; ? u Re faw mfhx Hr Smv J smartphone r &Sdw Jht w Gu f ' Do i fc e f; p mu aw mh o i fht w Gu f p dw fau se y fr I
t jy n fhay ; Edki fr Sm r [ kw fw Jht aMu mi f; y g/ ' gaMu mi fh t m; e n f; c su ft r sm; Mu D; &Sdw Jh ' Do i fc e f; p mu dk o n f; c Hz w f&Iap
v dky gw , f/
' Dae Uac w f r dkb dki f; z ke f; aw mfaw mfr sm; r sm; e JU smartphone aw mfaw mfr sm; r sm; [ m z ke f; t q i fhw i fr u b J
u Ge fy sLw me D; e D; jz p fv my gw , f/ u Ge fy sLw maw Gv dky J u Ge f, u fc sdw fq u fr Iaw Gy gv mMu y gw , f/ (Bluetooth?
WiFi? GSM? IR? USB)/ u Ge fy sLw maw Gv dky J v Hkjc HKa&; q dki f&mp n f; r sOf; aw G&Sdjy D; ? z ke f; aw Gr Sm ai Gac s&w Jhp e p f
w c gw n f; y gv mw maMu mi fho i fht ae e JU w u , fhai GaMu ; aw Gu dk q Hk; &IH; &Edki fy gw , f/ r dkb dki f; z ke f; &JU anti-malware
e JUy w fo u fjy D; o kaw o e jy Kc Jhw mu aw mh F-Secure u y g/ r dkb dki f; z ke f; aw Gr Smo Hk; w Jh Symbian application
aw Ge JUy w fo u fv dkUcrack v ky fjy D; y x r q Hk; w i fjy c Jho lu aw mhARTeam u Shub-Nigurrath jz p fy gw , f/
' Do i fc e f; p mr Smaw mhSymbian z ke f; aw Gr Smo Hk; w Jhapplication aw Gu dko m crack v ky fjy r Smjz p fy gw , f/

y Hk( 1 ) Symbian smartphone z ke f; r sm;
( 1 ) Symbian OS q dko n fr Sm . . . .
Symbian OS u dk Nokia (47.9%) e JU SonyEricsson (15.6%) w dkUu smartphone aw Gr Sm
t " du t o Hk; jy Kc JhMu jy D; 20 0 8 - c kESp f ESp fv , fy dki f; av mu fr Sm open source t jz p fjy Kv ky fz dkUt w Gu f Nokia u
Symbian Ltd. u dk0 , f, lc Jhy gw , f/ Symbian OS aw G[ m t ap my dki f; u Psion v dkUac : w JhEPOC u dk t ajc c H
y gw , f/ 20 0 1 c kESp fr Smaw mh EPOC u ae Symbian v6 q dkjy D; jz p fv my gw , f/ Symbian &JU v u f&Sd major
version u aw mh 9 jz p fy gw , f/ Symbian r Sm OS e JU UI u dkc GJjc m; x m; y gw , f/ OS u aw mh Symbian u
jz p fjy D; UI u aw mh hardware a&mi f; c so law Ge JUo u fq dki fy gw , f/ ' gaMu mi fhr dkU Series60 (S60) [ m Nokia
u jz p fjy D; UIQ u aw mh Sony Ericsson u jz p fy gw , f/ MOAP u aw mh Sharp/NTT DoCoMo u
jz p fy gw , f/ Symbian OS aw Gr Sm ARM y &dkq u fq maw Gu dk t o Hk; jy KMu jy D; ' Dy &dkq u fq maw G[ m RISC
(Reduced Instruction Set CPU) y &dkq u fq maw Gjz p fy gw , f/ ' gaMu mi fhr dkUv dkU ARM CPU aw Gr Sm
instruction aw Ge n f; y g; jy D; register aw G r sm; jy m; v mw Jht w Gu f cracker aw Gt w Gu f e m; v n f&c u fap r Sm
jz p fy gw , f/
Symbian OS &JU t ap my dki f; version aw Gr Smaw mh EKA kernel u dkt o Hk; jy Kc JhMu jy D; ae mu fy dki f;
version aw Gr Smaw mh ERK2 kernel u dko mt o Hk; jy Kc JhMu y gw , f/ ' D kernel aw G[ m multi-processing?
Multithreading e JUmulti-tasking w dkUu dkjy Kv ky fay ; Edki fp Gr f; &Sdy gw , f/ r Sw fOmP fu mu G, fr Ip e p fv Jy g&Sdy gw , f/
x l; jc m; c su fu aw mh o lUr Sm user w p fOD; w n f; p e p fu dk o Hk; p GJy gw , f/ ' gaMu mi fh user e JU admin c GJjc m; x m; w m
r &Sdo v dkUlogin/logout p e p fv Jr &Sdy gb l; /
Symbian OS aw G[ m resource x u f API u dkt ajc c Hy gw , f/ Build v ky fc sde fr Smo m assign v ky fEdki f
jy D; run ae c sde fr Smaw mh ajy mi f; v JEdki fjc i f; r &Sdy gb l; / DLL u k' faw Gu dkaw mh application process &JU p Gr f; aq mi f
&n faw Ge JUt w l execute v ky fw mjz p fy gw , f/ p Gr f; aq mi fr Iaw Gu dkaw mh exe x Jr Smy J o dr f; w mjz p fy gw , f/
Symbian OS t w Gu f aq mz hf0 Jv fx kw fv ky fz dkU Mandatory Code Signing e JU x de f; c sKy fy gw , f/ Exe aw Ge JU
library aw Gu dk a' w maw Ge JU o D; o e fUc GJjc m; Edki fz dkU data caging u dkt o Hk; jy Ky gw , f/ ' gaMu mi fh exe aw G[ m
\sys\bin at mu fr Sm&Sdjy D; process a' w maw Gu aw mh\private\<APP UID> at mu fr Sm&Sdw m jz p fy gw , f/
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 312 -

Symbian z dki fp e p fu aw mhdrive p mv Hk; aw G? directory aw Ge JUz dki faw Gu dkt ajc c Hy gw , f/
( 1 ) C: - Flash RAM/ User e JUy w fo u fw Jht c su ft v u faw G? user u install v ky fx m; w Jh application
aw G&Sdy gw , f/
( 2) D: - TEMP RAM/ Application aw Gt w Gu f , m, Dz dki fx m; o kdy gw , f/
( 3 ) E: - MMC/ " gw fy Hkaw Ge JUapplication aw Gt w Gu f removable disk jz p fy gw , f/
( 4 ) Z: - OS ROM/ OS z dki faw Gt r sm; p ky g0 i fw Jhflash drive jz p fy gw , f/
Drive w dki f; r Sm system directory &Sdy gw , f/
( 1 ) Media t o p fw p fc kx y fa&mu fv mw dki f; directory u dkt v dkt av smu fz e fw D; r Smjz p fy gw , f/
( 2) System directory r Smaw mh OS e JU application z dki faw Gy g0 i fw Jh directory tree y g0 i fy gw , f/
C:\Windows e JUw ly gw , f/
t a&; Mu D; w Jhdirectory aw Gu aw mh-
( 1 ) System\Apps/ User aw Gjr i fEdki fw Jhapplication aw G&Sdy gw , f/
( 2) System\Recogs/ Recognizer components
( 3 ) System\Install/ Install v ky fx m; w Jhapplication aw Ge JUy w fo u fw Jhuninstallation t c su ft v u fr sm; /
( 4 ) System\libs/ System e JU3rd-party library r sm; /
Phone menu e JUbutton aw Gr Sm&Sdw Jhapplication aw Gu aw mh-
( 1 ) Z:\System\Apps\Menu\Menu.app - Phone main menu & application launching service
( 2) Z:\System\Apps\AppInst\Appinst.app - Application installation
( 3 ) Z:\System\Apps\AppMngr\AppMngr.app - Application uninstallation
( 4 ) Z:\System\Apps\MMM\Mmm.app - Messaging application
( 5 ) Z:\System\Apps\Phonebook\Phonebook.app - Phonebook
( 6 ) Z:\System\Apps\BtUI\btui.app - Bluetooth control panel
Mobile application aw Gu dkz e fw D; &mr Sm t o Hk; jy Kw Jhy &dk* &r fb mo mp u m; u aw mhCarbide.c++ jz p fjy D;
developing process u aw mhat mu fy gt w dki f; jz p fy gw , f/

( 2) Symbian Executable File Format
' Dw p fc gr Smaw mh Symbian OS r Smo Hk; w Jh application aw G&JU z GJUp n f; w n faq mu fy Hku dk av hv m
Mu n fhy gr , f/ Symbian OS r Sm t o Hk; jy Kw Jh exe z dki fy Hkp Hu aw mh E32 y Hkp Hjz p fy gw , f/ ' Do i fc e f; p mr Sm aq G; aEG;
r , fhexe z dki fq dkw m ARM y &dkq u fq maw Gt w Gu fu dkq dkv dk&i f; jz p fy gw , f/ Emulater aw Gt w Gu fu dkr aq G; aEG;
<app>.mmp
Project file
<app>.rss
Resource file
<app>.app
<app>.ilk
<app>.rsc
<app>.dll
Executable
<app>.aif
Package
information file
Normal C++
Build Process
<app>.
UID.cpp
Resource file
<app>.WINS
<app>.MARM
Makefile
<app>.app
<app>.ilk
<app>.rsc
<app>.dll
Executable
Makefile
nmake
make SIS
<app>
.sis
<app>.pkg
List of
components
Normal EPOC
Packaging Process
Copyright White Cracker (Myanmar Cracking Team)
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 313 -

y gb l; / b maMu mi fhv Jq dkaw mhemulater &JU exe z dki faw G[ m Windows &JU PE-COFF (Portable Executable
Common Object File Format) u dkt o Hk; jy Kv dkUy g/
Symbian r Sm t o Hk; jy Kw Jh executable z dki faw Gjz p fw Jh .app? .exe ( o dkU) .dll aw Gr Sm E32 z dki fy Hkp Hq dkw Jh
t x l; y Hkp Hw p fc k&Sdy gw , f/ Microsoft/Intel &JU PE (Portable Executable) ( o dkU) UNIX &JU ELF
(Executable and Linking Format) w dkUe JU t e n f; i , fu GJjy m; ay r , fh t ajc c Ht m; jz i fh w ln Dr I&Sdy gw , f/
Symbian [ m GCC compiler u dkt o Hk; jy Kw Jht w Gu f w u , faw mh o i fh&JU source code u dk PE y Hkp Ht jz p f
compile v ky fv dku fw mjz p fy gw , f/ Symbian &JUbuild process u sr So m PETRAN q dkw Jhtool u dkt o Hk; jy Kjy D;
o i fh&JUPE z dki fu dkE32 z dki ft jz p f ajy mi f; ay ; v dku fw mjz p fy gw , f/
E32 Header
Code Section
Text Section
Export Table
Import Table
BSS Section
Data Section
Import Section
Relocation Section
y Hk( 2) E32 z dki fy Hkp H
t jc m; z dki fy Hkp Haw Gr Smv dk E32 r Smv J header u ae p y gw , f/ Header &JUae mu fr Sm u y fy gv mw maw G
u aw mhat mu fy gt w dki f; jz p fy gw , f -
o Code section - o lUr Smaw mhtext section? export address table e JU import address table (IAT)
q dkjy D; 3 y dki f; y g0 i fy gw , f/ Text section r Smaw mh source code &JU .obj z dki ft m; v Hk; y g0 i fy gw , f/
u se fw Jhsection ESp fc ku aw mhy &dk* &r fx Ju import/export v ky fx m; w Jhfunction aw Gu dkjy y gw , f/
o BSS section - o lUr Smaw mh initialize r v ky f&ao ; w Jha' w maw G y g0 i fy gw , f/ ' D section u dk
Symbian application aw mfaw mfr sm; r sm; r Smaw mht o Hk; r jy KMu y gb l; /
o Data section - o lUr Smaw mh initialize v ky fjy D; o m; a' w maw Gy g0 i fy gw , f/ Symbian application
aw mfaw mfr sm; r sm; [ m .app? .dll z dki ft ae e JUv mw maMu mi fh' Dsection r &Sdw mu r sm; y gw , f/
o Import section - o i fhy &dk* &r fu t o Hk; jy Kx m; w Jh imported function aw Ge JUo u fq dki fw Jh t c su f
t v u faw Gy g0 i fy gw , f/
o Relocation section - o i fhy &dk* &r fu dk Symbian loader u u l; w i fw Jht c gr Sm v dkt y fw Jhrelocation
table y g0 i fy gw , f/
E32 r Sm t " dy m, fz Gi fhq dkx m; w Jh header e JUy w fo u fw Jh t c su ft v u faw Gu aw mh at mu fy gt w dki f;
jz p fy gw , f -
class E32ImageHeader
{
public:
TUint32 iUid1;
TUint32 iUid2;
TUint32 iUid3;
TUint32 iCheck;
TUint iSignature; // 'EPOC'
TCpu iCpu; // 0x1000 = X86, 0x2000 = ARM, 0x4000 = M*Core
TUint iCheckSumCode; // sum of all 32 bit words in .text
TUint iCheckSumData; // sum of all 32 bit words in .data
TVersion iVersion;
TInt64 iTime;
TUint iFlags; // 0 = exe, 1 = dll, +2 = no call entry points
TInt iCodeSize; // size of code, import address table, constant data and export dir
TInt iDataSize; // size of initialized data
TInt iHeapSizeMin;
TInt iHeapSizeMax;
TInt iStackSize;
TInt iBssSize;
TUint iEntryPoint; // offset into code of entry point
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 314 -

TUint iCodeBase; // where the code is linked for
TUint iDataBase; // where the data is linked for
TInt iDllRefTableCount; // filling this in enables E32ROM to leave space for it
TUint iExportDirOffset; // offset into the file of the export address table
TInt iExportDirCount;
TInt iTextSize; // size of just the text section
TUint iCodeOffset; // file offset to code section
TUint iDataOffset; // file offset to data section
TUint iImportOffset; // file offset to import section
TUint iCodeRelocOffset; // relocations for code and const
TUint iDataRelocOffset; // relocations for data
TProcessPriority iPriority; // priority of this process
};
iUid1? iUid2 e JUiUid3 w dkU[ m identifier aw Gjz p fjy D; ? y x r UID u o i fh&JUy &dk* &r f[ m .dll z dki fv m; ?
.exe z dki fv m; q dkw m c GJjc m; ay ; Edki fy gw , f/ .dll q dk&i faw mh0x10000079 jz p fjy D; .exe q dk&i faw mh0x1000007A
jz p fy gw , f/ ' kw d, UID u aw mh object aw Gu dkc GJjc m; ay ; w mjz p fjy D; polymorphic interface DLL aw G
t w Gu f 0x100039CE jz p fjy D; ? static interface (shared library) t w Gu fu aw mh0x1000008d jz p fy gw , f/
w w d, UID u dkaw mh y &dk* &r f identifier t jz p fjr i fEdki fy gw , f/ ' ghjy i f 0x100000 u ae 0xFFFFFF
t w Gi f; Mu m; &Sdw JhUID t c sdKUv J&Sdy gao ; w , f/
iCheck u aw mh y x r UID 3 c k&JU checksum jz p fy gw , f/ Symbian SDK r Sm uidcrc.exe v dkU
ac : w Jhtool w p fc k&Sdjy D; y x r UID 3 c ku ae u dkx kw fay ; y gw , f/ Oy r mjy &&i f at mu faz mfjy y g command [ m
0x1000079? 0x1000029CE? 0x00DD3103 p w JhUID aw Gt w Gu f checksum u dkx kw fay ; y gv dr fhr , f/
C:\>uidcrc 0x10000079 0x100039CE 0x00DD3103
0x10000079 0x100039CE 0x00DD3103 0xAE035303
iSignature u aw mhE32 z dki fe JUy w fo u fw Jhsignature jz p fjy D; EPOC w e fz dk; jz p fy gw , f/
iCPU u aw mh y &dk* &r faw G&JU platform jz p fjy D; ? ECpuX86 = 0x1000 q dk&i f Intel y &dkq u fq maw G
t w Gu fjz p fjy D; ECpuArm = 0x1000q dk&i faw mhy &dkq u fq maw Gt w Gu fjz p fy gw , f/
iCheckSumCode u aw mhcode section &JU checksum jz p fy gw , f/ Header z dki fx Ju r Sw fc su ft &
q dk&i faw mh ' g[ m .text section x Jr Sm&Sdw Jh 32-bit WORD aw Gt m; v Hk; &JU ay gi f; v ' f jz p fy gw , f/ ' gay r , fh
' Dw e fz dk; [ m IAT e JU export table (=iCodeSize field) t y gt 0 i f code section x Jr Sm&Sdw Jh32-bit WORD
aw Gt m; v Hk; &JUay gi f; v ' fv Jjz p fEdki fy gw , f/
iCheckSumData u aw mh.text section x Jr Sm&Sdw Jh32-bit WORD aw Gt m; v Hk; &JU ay gi f; v ' f jz p fy g
w , f/ Symbian r Sm u Re faw mfw dkU y &dk* &r faw Gu dk build v ky fc sde fr Smaw mh' Dchecksum w e fz dk; [ m o kn jz p fy g
w , f/
iVersion u aw mhE32 z dki fu dkx kw fay ; &mr Sm t o Hk; jy Kw Jh PETRAN &JU version jz p fy gw , f/ w u , f
v dkUo i fu UID 2.1 u dkt o Hk; jy Kw , fq dk&i f version u 1.00 (175) jz p fr Smy g/
iTime u aw mhy &dk* &r fu dkbuild v ky fv dku fw Jh&u fp GJe JUt c sde f (TimeDateStamp) jz p fy gw , f/
iFlags u aw mh.exe t w Gu f 0? .dll t w Gu f 1 e JUentry point u dkac : o Hk; jc i f; r &Sdw Jhz dki faw Gt w Gu faw mh
+2 jz p fy gw , f/
iCodeSize u aw mh code section &JUt &G, ft p m; jz p fjy D; IAT? constant data e JU export address
table w dkUy g0 i fy gw , f/
iDataSize u aw mh initialize v ky fx m; w Jh data section &JUt &G, ft p m; jz p fjy D; iCheckSumData
r Smv dky J' Dfield r Sm o kn jz p fae w m aw GU&r Smy g/
u se fw Jh parameter aw Gu aw mh r Sw fc su faw Gy gv mjy D; jz p fv dkU r &Si f; jy aw mhy gb l; / y dkjy D; &Si f; v i f; p Gm
e m; v n fEdki fz dkUexample_app.app u dkPETRAN e JUMu n fhv dku fMu &at mi f/ y Hk( 3 ) /
PETRAN - PE file preprocessor V01.00 (Build 175)
Copyright (c) 1996-2001 Symbian Ltd.
E32ImageFile 'example_app.app' // file name (not in E32 image header)
V1.00(175) Time Stamp: 00e0be89,69063b40 // iVersion iTime
EPOC Dll for ARM CPU // iCpu
Entry points are not called // iFlags
Uids: 10000079 100039ce 10008ace (7ec529db) // iUid1, iUid2, iUid3 and iCheck
File Size: 00001368 // file size (not in E32 image header)
Code Size: 00000ed8 // iCodeSize
Data Size: 00000000 // iDataSize
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 315 -

Chk code/data: d4ad460a/00000000 // iCheckSumCode iCheckSumData
Min Heap Size: 00001000 // iHeapSizeMin
Max Heap Size: 00100000 // iHeapSizeMax
Stack Size: 00002000 // iStackSize
Code link addr: 10000000 // iCodeBase
Data link addr: 00000000 // iDataBase
Code reloc offset: 00001194 // iCodeRellocOffset
Data reloc offset: 00000000 // iDataRellocOffset
Dll ref table count: 4 // iDllRefTableCount
Offset Size Relocs NumOfRelocs
Code 00007c 000ed8 // iCodeOffset, iCodeSize
001194 0000e1 +000000 (entry pnt) // iCodeRellocOffset .. iEntryPoint
Data 000000 000000 // iDataOffset iDataSize
Bss 000000 // iBssSize
Export 000f50 000004 (1 entries) // iExportDirOffset iExportDirCount
Import 000f54 // iImportOffset

Code (text size=00000d08) // iTextSize

... // here the dump of the text section

225 relocs
... // here the dump of the relocation section

Idata Size=00000240
Offset of import address table (relative to code section): 00000d08

... // here the import tables information
y Hk( 3 ) u dky dkjy D; &Si f; v i f; ap z dkUy Hk( 4 ) u dkMu n fhy g/

y Hk( 4 )
y Hk( 4 ) &JU b , fz u fjc r f; r Smaw mh section t o D; o D; &JU offset aw Gu dkjr i fEdki fy gw , f/ Oy r mjy &&i f -
iCodeOffset (= 0x7C) [ m code section &JU offset jz p fy gw , f/ n mz u fjc r f; u aw mh section t o D; o D; &JU
t &G, ft p m; jz p fy gw , f/ t &G, ft p m; aw Ge JUy w fo u fjy D; aw mh t e n f; i , f t c u faw GU&y gw , f/ b maMu mi fhv J
q dkaw mh t c su ft v u ft m; v Hk; u dk header x Jr Sm o dr f; q n f; w m r [ kw fv dkUy g/ E32ImageHeader &JU t &G, f
t p m; u dkaw mhsizeof operator u dkt o Hk; jy Kjy D; t v G, fw u lw Gu fc su fEdki fy gw , f/ Text section? code section
w dkU&JU t &G, ft p m; u dk o dz dkU&mv G, fy gw , f/ b maMu mi fhv Jq dkaw mh header x Jr Sm o lw dkUe JUo u fq dki fw Jh t c su f
t v u faw G&Sdv dkUy g/ ( iTextSize ESi fhiCodeSize) /
Export table &JUt &G, ft p m; u dk w Gu fc su f&w maw mht e n f; i , fc u fy gw , f/ o i fht ae e JU iExportDir
Count u dk sizeof(UINT) e JU ajr Smu fz dkUv dky gw , f/ b maMu mi fhv Jq dkaw mh export v ky fx m; w Jh function t o D;
o D; u dk unsigned integer t ae e JU o dr f; q n f; v dkUy g/ Oy r mjy &&i f - o i fhr Sm export v ky fx m; w Jh function
w p fc k&Sdr , fq dk&i f sizeof(UINT) e JUajr Smu fw Jht c g 4 &v mr Smjz p fy gw , f/
Import address table &JU t &G, ft p m; u dk w Gu fc su f&mr Smaw mh Symbian r Sm import table aw Gu dk
b , fv dkw n faq mu fx m; o v Jq dkw mu dk o dx m; z dkUv dky gw , f/ t ajc c Ht m; jz i fhaw mh o i fhy &dk* &r fu import v ky f
x m; w Jh function t a&t w Gu fu dk o dx m; z dkUv dky gw , f/ 114 v dkU , lq Mu y gp dkU/ 114 u dk&z dkU u Re faw mfw dkU
y &dk* &r fu import v ky fx m; w Jh DLL z dki faw Gx Jr Sm import v ky fx m; w Jh function aw Gu dk a&w Gu f&r Smjz p fy g
t c e f; ( 20 ) r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f;
- 316 -

w , f/ jy D; &i f ' gu dk sizeof(UINT) e JUajr Smu fay ; &r Smjz p fy gw , f/ r Sw fc su f/ / Import v ky fx m; w Jh function
t a&t w Gu fr Sm w p fay gi f; ay ; z dkUv dky gw , f/ b maMu mi fhv Jq dkaw mhimport table &JUt q Hk; r Sm \0 o au Fw &Sdv dkUy g/
Import section &JUt &G, ft p m; jz p fw Jh 0x0240 u dkaw mh import section &JU y x r 32-bits u ae
z w f, lEkdi fy gw , f/ o i fht ae e JU E32Image.h u dkz Gi fhMu n fhv dku f&i f E32ImportSection v dkUac : w Jh structure
w p fc ku dk&Smaw GUr Smjz p fy gw , f/
class E32ImportSection
{
public:
TInt iSize; // size of this section
// E32ImportBlock[iDllRefTableCount];
};
' Dstructure [ m import section x Ju y x r 32-bits jz p fy gw , f/ iSize u aw mhimport section
&JUt &G, ft p m; jz p fy gw , f/
Import section v dky J relocation section &JUt &G, ft p m; u dk relocation section &JU y x r 32-bits
u ae z w f, lEkdi fy gw , f/ ' Dt c su ft v u faw Gu dk o dr f; q n f; x m; ay ; w Jh structure u aw mh E32RelocSection
jz p fjy D; field ESp fc ke JUjz p fy gw , f/
class E32RelocSection
{
public:
TInt iSize; // size of this relocation section
TInt iNumberOfRelocs; // number of relocations in this section
};
' DOy r mr Smaw mh iSize [ m 0x01CC jz p fy gw , f/ b maMu mi fh sizeof(E32RelocSection) u dk
relocation section &JUt &G, ft p m; r Sm ay gi f; ay ; z dkUv dky go v J/ b maMu mi fhv Jq dkaw mh E32RelocSection.iSize
r Sm relocation header &JUt &G, ft p m; w e fz dk; r y gv dkUy g/ ' g[ m import section e JUEdIi f; p m&i f e n f; e n f; av ;
u GJv GJae y gw , f/ b maMu mi fhv Jq dkaw mhE32RelocSection.iSize [ m import header x Jr Smy gjy D; o m; jz p fae v dkU
y g/ ' Dav mu fq dk&i faw mhE32 z dki fz GJUp n f; y Hku dke m; v n fav mu fjy Dv dkUx i fy gw , f/
( r dkb dki f; z ke f; application r sm; u dkcrack v ky fjc i f; t m; ae mu f version r sm; w Gi f q u fv u faz mfjy y gr n f/ )

., Loader .. patch ..-._.


.,.__-] Loader q.- patch e-e,._.-.



-. . ..-. loader -.-- .- .__. loader . patch ..-- -.
. - .. . -. ._. ._.. -. .-.. -.-.-. - .-. - -. cracking -.--
._-.--.. ..._._..--- loader - -. ...... . -.- ... . ._
. ..- - - . Loader patch ..-- .....-.._. -. . - .. . -.- .. . -..
........_..-. .... - . .-. ARTeam - Shub-Nigurrath Thunderpwr -
.....- "Cracking with loaders: theory, general approach and a framework" ... ..-
.- . _- _ -.
Info: : Loader .-.-.-. process -. - .- - ...... application -._.._. unpack
.- protect ..-.-_._..- process ....,- .....-. ..-...-.
-. - -. ...... . - . ...- .._ .- .- - _ . . . . - . - process
- patch -._.. -. .._ .- -. -.-. loader .- -. -. .- - _. -. . .-
....-. ..._..-. loader .- ..-..--. -_- directory ..-..
_--. ....- -. -.-. loader .--. -.- unpack . protect ..-.-
_._...-. ._-. cracking .. . - .- ....-. Loader -. . ..
.._.- father-child process ..._._--. .... loader -.-. father _.. -.
-.._-. . .-. . -. -. - . .. . . -. -.-. child _..-. -.._-.
..-. .-. Loader -.-_..-. .--. GUI tool .--
. ._ - - .- .-. ........ - . - - - _ .. - _ ..
. --.-. -. address .. -.....-- patch ...-. dUP ABEL - -.-.
..__-. loader creator .- ..- _.. - - -.-. patch . ... . ...
. . -. - . - . . . unpack .- - - ... . .._ ._.. -. , --. .
-._-... patch -...._..-. patch ..- -...._-...... ..-
. loader .- ...-. -. .- -. loader .--. -.- run .-..... . _- ....
_--. --. loader .-._-.. ..... -.- unpack - . . . - . -
virtual address ...-- ._...--.
-. crack _-_ .. ... . -.-. JSI Inc -...- Windows NT Tips, Tricks,
and Registry Hacks ...._..-. Windows Registry -.-- --..
-. ... . ..- . ._ ...-._.. _ . ... . - www.jsiinc.com .. . download .
-. ... . .... .-.-. $4000 .-. _.. _ . . . . .. .. .-. . . -
.....- ...-.. - ..- . -. -. ._ -.-. Jsittarh.exe _.. -.
--. .-. Jsittarh.exe -. HTML .......-..-- web compiler 1.3 ..__. exe .
. compile ..-._..-. -.- _-_-_-.. ,

,
., Loader .. patch ..-._.
.

,-.-. Windows Registry -.----.-- _-. ,- 79nn -.
_-_- ,-. _.-.

,
,- ...-.....- ..- ,-. password .-.....
,
,-. password -_-_. OK button - . - -. MessageBox (Message)
. ..- ,- _ ..- . ..-. -.-. -. .-. ._ -. - PEiD
.. _-_ - _-.. ,

,
PEiD .. ...- .-. PEtite 2.x _-. Protection ID 6.2.3 -.-. PEtite 2.2
protect ..-. ._.-. Protection ID -.-. protector .- - .- _ . _ .- --
._.- ... -. . .-. -. - unpack . ._ -. - Olly ...

,
., Loader .. patch ..-._.


,-_-_ VA 004BA042 -.-. entrypoint _.. -. ..- ......_-_ ..
PUSHAD .-.-.-. DWORD -.....- PUSH - instruction _..-._-.. ._.
..-. _.- ._-.. hardware breakpoint .-.-.. VA 004BA05D - PUSH EAX
.- F8 . _ .. .. - VA 004BA05D ..- register window ESP register .. right-
click -._. Follow in Dump -... ,
,
,-. Follow in Dump -..-.-. ,-._...

,
,- highlight _.. .- 38 07 91 7C .. right-click ._. Breakpoint - Hardware, on
access WORD - . . - _ . .-. F9 (Run) -.- .,-. _...

.,
F9 (Run) -.--...-. hardware breakpoint . VA 004BA03D . . . ..-.
.- .. .. .-.- - .-. - entry point . VA 004BA042 .. MOV EAX, XXX ...
JMP 00484724 _...-..--. ._-. virtual address ..- ..._-_ ...-.
_.. -. --. .-. PEtite - entry point ...... -.-- decompress -._..
-. VA 004BA042 .. ..- ... F8 -.. JMP 00484724 -. -. OEP
.- jump -. ,

,
,- OEP .- ..- _ . dump .. Right-click ._. Dump debugged
process -..- ,-. _...
,
., Loader .. patch ..-._.


,- Dump button - . ._ . dump.exe ._ .-...- _. .....-.
.... _._-_-

,
,-. -.-.- ....-_.- ,.-. .._-._.....-. ..
...- _-_-_ ,-. _.-. Overlay ..-. ..--.

,
.-...-. -.-.- unpack --. -.......-. --
.-.-. HTML . .- - ._.. -. Dump --.- PEiD .._-_ Borland
Delphi 3.0 .......-. _-. --. .-. - .-. - dump --.-. Web
Compiler ... . .- .- .._.. -. dump.exe File menu - Compiler Option -..-
,- . _. .. Jsittarh.exe File menu . ..-. Compiler Option ..- .,

,
,- ..._-_ ,.._.- dialogbox -. ,._-. _.. -..._
... ... . - password --...-- ... master key -.-.-.-. _..-..
., Loader .. patch ..-._.


user key .-_. password -.-.-. .. password routine -. password -...
. -. _ ._ ....-. - . . TEAM LAXiTY -.-. key ----..-. -.-.
cracking ..- .-.-.-. key ..-.._-. Key -.-. 15416??? _..
-. ... ..-. - .-. . key - ._._. ..- - - . --. key -..-. .
-.- ...---.._..-. ... cracker ..._..-.

,
Dump.exe .. --- ...._.-..- Jsittarh.exe -__-_-_-..

,
,.. dump _ . .. -.- _ .- _-.. OEP ..-._._. hardware
breakpoint .- - .- _ .- _ .. .. .-. F9 (Run) - . - ,- ..- ..
.....- 79nn - 7900 DNS problems in .. - . _ . register . _-...._-_..
,

,
,- ._. - . . Olly . . F12 -._. -.- - ,- . _.
..

,
Alt + K -._. Call Stack -_-_ .,-._.-.

.,
., Loader .. patch ..-._.


.,- procedure ....- breakpoint .-.- Breakpoint .-.-. virtual
address .... right-click ._. Show procedure (Enter key) - . ... Breakpoint .- . - _ .
.-. ,- OK button - . . - ,- . .- ..

,
, VA 0047E52D - CALL 00403AFC - ....._-_- EAX - . ..-
._. . .-. .- . . .... .-.....-.-. VA 0047E53C .. ... . JE
0047E5E0 (0F,84,9E,00,00,00) ... JMP 0047E5E0 (E9,9F,00,00,00,90)__. -.- run
_-_- Breakpoint .-...- ..-.-- - _ _.- - .-- Hex - ..-
- .-. .. - - -. - . ..... . . . . .. ,

,
,-. --__. -.- run _-_-- ,-. _.-.

,
. -.-.-.-.- ._-...- key .. - .- _ ... . ._ ...
.-. .-.-.-. -. - Olly .....-. .--. - .-. - . _- - - . .
_--..-... patch ..-._ .-.._ -.-.- -.-_..-.- Olly
.. ...._.- ,.. _.--. .- ...._..-.


., Loader .. patch ..-._.



,
-.._-. error ---..-. ._.... -. (Jsittarh.exe) - Olly _.
- Entry point (004BA042) - ..- - . .- -.

,
. . - .-. - patch ...._..- VA 0047E53C ...._-_-_-..
,
,
-.. -.- . ..- - . . _.- -. -_.--.--. decompression
stub - unpack _ ........ _.. -. --. .-. unpack _ ..... .- . ..
_.... _-...---. ... PEtite - -.-.- unpack -. ... _. - .
._-. _..- ._. .. .. loader .-.-...._ Loader -.-. PEtite -
-.- .-... process _......_. unpack .. patch .. byte -,
--._. -....-. byte -, ....._..-.
Loader/Patch .-.-.. ABEL Loader Generator 2.31 -.- ,

,
., Loader .. patch ..-._.


_ . .-. ..- - .... - _ . loader .- .-.-
- .-. - patch ...._ (Jsittarh.exe) --_
Loader .._- .-.- (Jsittarh_Loader.exe)
Timeout . -.-.-. loader - process - load . ..... .-.. _...
_.- --..-....-. timeout -..- 15 .- . - . -.
Patch .. virtual address -.-. VA 0047E53C . ._.. _ . _ .. byte .- -.-.
-.-.- ..--.. .-......- HEX - ..- _.. -. JE 0047E5E0 (0F,84,9E,
00,00,00) JMP 0047E5E0 (E9,9F,00,00,00,90), ,
..- . .. -.-. Generate button -.-

,
Loader . - . - ._ .- ..- . ..-. loader . (Jsittarh_Loader.exe) - Jsittarh.exe
directory -.-_...-...._.._-_ - ,- ..- _ . -. key .-_...-
..-..- ....._......

,



t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 325 -

tcef;(22) - Crypto uk'frsm;udk avhvmjcif;
' Dw p fc gr Sma w mh crack v ky f& mr Sm t a w GUr sm; r , fh crypto u k' fa w Gt a Mu mi f; a v hv mr Smjz p fy gw , f/
Crypto q dkw mu a w mh cryptography & JUt w dka u mu fjz p fjy D; encrypt v ky fjc i f; ? decryption v ky fjc i f; e JU o u f
q dki fy gw , f/ Encrypt v ky fw , fq dkw mu a w mh o u fq dki f& m key w p fc kc ku dko Hk; jy D; ( key r y gw mv Jjz p fE dki fy gw , f)
p mo m; a w Gu dk e m; r v n fE dki fw Jh p mo m; a w Gt jz p f a jy mi f; v Ja y ; w mjz p fy gw , f/ Decrypt v ky fw mu a w mh 0 Su f
x m; w Jhu k' f^ p mo m; a w Gu dk r lv t w dki f; jz p fa t mi f jy e fa z mf, lw my g/ ' De n f; y n m& y fu dka w mh p p fb u fq dki f& m a Mu ;
e e f; a w Gr Sm 0 Su fp mt a e e JU t o Hk; jy Kjc i f; t jy i f a q mhz f0 Jv ft c sdKU& JU registration key z dki fa w Gu dk v la w Gr o da p
c si fw Jht c gr Sm t o Hk; jy Ky gw , f/ ' ghjy i f crypto u k' fa w Gu dk unpack v ky fw Jht c gr Smv n f; a u mi f; ? serial routine
a w Gr Smv n f; a u mi f; ? CRC u dk p p fa q ; & mr Smv n f; a u mi f; Mu HKa w GU& r Smjz p fv dkU ' Dt c e f; r Sm x n fho Gi f; a q G; a E G;
& jc i f; jz p fy gw , f/ a & SUt c e f; a w Gr Sm a jy mc Jho v dky J ' Dp mt ky f[ m t a jc c Ht c su fa w Gu dky J OD; p m; a y ; & Si f; jy w mjz p fv dkU
o i fht a e e JU cryptography t a Mu mi f; t a o ; p dw fo dc si f& i fa w mh Michael Welschenbach a & ; o m; w Jh
"Cryptography in C and C++" e JU Oded Goldreich a & ; o m; w Jh "Foundations of Cryptography"
p mt ky fa w Gu dk z w f& Iy gv dkU t Mu Hjy Kv dky gw , f/ ' Dp mt ky fa w Gu dk n Te f; & w Jht a Mu mi f; & i f; u a w mh t Ge fv dki f; r Sm t c r Jh
( w & m; r 0 i f) & & SdE dki fv dkUy Jjz p fy gw , f/
u Re fa w mfw dkUa v hv mr , fht a jc c Hcrypto e n f; y n mt c sdKUu a w mha t mu fy gt w dki f; jz p fy gw , f -
( 1 ) Transposition
( 2 ) Substitution
( 3 ) Frequency analysis
( 4 ) Le Chiffre Indchiffrable
( 5 ) Charles Babbage & Vigenre
( 6 ) Playfair
( 7 ) ADFGX crypto
( 1 ) Transposition
' De n f; v r f; u a w mh p mo m; a w Gu dk a e & mc si f; v Jw Jhe n f; y g/ ' D& dk; & Si f; v Sw Jh a e & mc si f; v Jv S, fw Jhe n f; r Sm
a w mhmessage u dkt w e f; E Sp fw e f; c GJjy D; a & ; z dkUy g/
- y x r w e f; r Sm 1? 3? 5 p w ma w Gy gy gr , f/
- ' kw d, w e f; r Sma w mh2? 4? 6 p w ma w Gy gy gr , f/
Oy r m message/
- Your secret is your prisoner, let it go and you become its prisoner.
y x r w e f; r Sm& Sd& r Smu a w mhr * P e f; a jr mu fp mv Hk; a w Gjz p fy gw , f/
- Yusceiyupioelyyonyueoeypioi
' kw d, w e f; r Sm& Sd& r Smu a w mhp Hk* P e f; a jr mu fp mv Hk; a w Gjz p fy gw , f/
- orertsorrsnreigadobcmisrsnr
' DE Sp fc ku dkcrypt v ky fv dku fc sde fr Sma w mha t mu fy gt w dki f; a w GU& y gw , f . . .
- Yusceiyupioelyyonyueoeypioiorertsorrsnreigadobcmisrsnr
( 2 ) Substitution
' De n f; v r f; u a w mhp mv Hk; w p fv Hk; u dk t jc m; p mv Hk; w p fv Hk; e JU t p m; x dk; jc i f; jz p fy gw , f/
u k' fw p fc k[ m p mv Hk; t ky fp k( o dkU) p u m; v Hk; w p fc ku dkt p m; x dk; y gw , f/
( 2 . 1 ) Monoalphabetic substitution
e r le my Hkp Hw p fc ku a w mh Caesar roll jz p fy gw , f/ ' gu a w mh crypt r v ky fx m; w Jh message u dk a e & m
a & TUw mjz p fy gw , f/ r sm; a o mt m; jz i fh ' Dv dky Hkp Ho Hk; & i fa w mh r lv p mo m; u dk p mv Hk; a o ; e JUa z mfjy jy D; ? crypt v ky fc H& w Jh
p mo m; u a w mhp mv Hk; Mu D; e JU jz p fa e r Smy g/
r lv p mo m;
- abcdefghijklmnopqrstuvwxyz
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 326 -

Crypt v ky fx m; a o mp mo m;
- DEFGHIJKLMNOPQRSTUVWXYZABC ( ' DOy r mr Sma w mh n mz u fu dk rotate v Sn fhx m;
w m jz p fy gw , f/ )
r lv p mo m;
- veni, vidi vici
Crypt v ky fx m; a o mp mo m;
- YHQL, YLGL, YLFL
' DOy r mu dkMu n fhr , fq kd& i f v a e & mw dki f; r Sm Y e JUt p m; x dk; jy D; i a e & mw dki f; r Sm L e JUt p m; x dk; x m; w m
a w GU& y gw , f/ ' ga Mu mi fh ' De n f; e JUu mu G, fw m[ m p dw fr c s& w m a w GU& y gw , f/ ' ga Mu mi fh y & dk* & r fr mu p mv Hk;
a w Gu dkt Mu dr fMu dr fv Sn fhjy D; r lv p mo m; u dk t v G, fw u ljy e fa z mfE dki fy gw , f/
( 2 . 2 ) Key y ga o m Monoalphabetic substitution
' De n f; u a w mh cracker a w Gu dk a w mfa w mfOD; a E Smu fa jc mu fa p y gw , f/ w u , fv dkU cracker w p fa , mu f
[ m crypt v ky fx m; w Jhp mo m; e JU a q mhz f0 Jv f& JU algorithm u dk& x m; c Jhr , fq dk& i fa w mi f crypted u k' fu dkjy e fa jz z dkU
r v G, fu ly gb l; / b ma Mu mi fhv Jq dka w mh crypt v ky fx m; w Jh key u dk r o dv dkUy g/ jz p fE dki fw Jh key t a & t w Gu fu v J
400 000 000 000 000 000 000 000 000 a v mu f& SdE dki fy gw , f/ ' ga Mu mi fh o i f[ m w p fp u e fUr Sm key
w p fc kE Ie f; e JU u k' fu dkjy e fa z mfr , fq dk& i f o i fh& JUt o u f[ m 10+9 a v mu f& Sdr Sy Jcrypted u k' fu dka jz E dki fr Smjz p fy gw , f/
r lv p mo m;
- abcdefghijklmnopqrstuvwxyz
Crypt v ky fx m; a o mp mo m;
- DJKTUVCWNOLPAEGFHIQRXYMSZB
r lv p mo m;
- ettu, brute?
Crypt v ky fx m; a o mp mo m;
- URRX, JIXRU?
' De n f; r Sm o i ft o Hk; jy Kw Jh key [ m & Sn fv sm; c Jhr , fq dk& i f cracker a w Gt z dkU key u dkr o dc Jh& i f decrypt
v ky fz kdU c u fc Ja e r Smjz p fy gw , f/
key w kdjc i f; ? w ln Da o m key u dky i f t Mu dr fMu dr fo Hk; a e jc i f; ? p mv Hk; w GJr sm; o Hk; jc i f; ( Oy r m Julius
Ceasar) ? space E Si fhp mv Hk; w lr sm; o Hk; jc i f; ( Julius Ceasar t p m; JULISCAER v dkUo Hk; & r Smjz p fy gw , f) a w Gu
' De n f; u dk t m; e n f; c su fjz p fa p y gw , f/ u se fw Jhp mv Hk; a w Gu a w mh key q Hk; w Jha e & mu a e p jy D; a w mh shift v ky f, lE dki f
y gw , f/
r lv p mo m;
- abcdefghijklmnopqrstuvwxyz
Crypt v ky fx m; a o mp mo m;
- JULISCAERTVWXYZBDFGHKMNOPQ
Crypt v ky fx m; a o mp mo m; ( a t mu fy gt w dki f; v Jv Sn fhE dki fy gw , f)
- CAERTVWXYZBDFGHKMNOPQJULIS
' De n f; & JU a u mi f; w Jht c su fw p fc ku a w mh key ( o dkU) key p mo m; u dk r Sw f& v G, fu ljc i f; y gy J/ & dk; & Si f; v Sw Jh
key a w Gu dka y gi f; p y fjy D; p mo m; a w Gu dk r a z mfE dki fa t mi f encrypt v ky fc Jhw mu a w mhv Ge fc Jhw JhE sp fw p fa x mi fa v mu f
u y g/ ' De n f; u dkz su fq D; E dki fw Jhe n f; v r f; a w G& Sda y r , fht m& y fv lr sdK; a w Gu y x r q Hk; jz p fc JhMu y gw , f/
( 3 ) Frequency Analysis
Monoalphabetic crypto u dka z mfE dki fc Jh t m& y fw p fa , mu f& JU a & ; o m; c su f[ m 800 AD a v mu fu
jz p fy gw , f/ ' Dv Sn fhu Gu fa v ; u a w mh b , fb mo mp u m; r Smr q dk r Mu mc P t o Hk; jy Ka v h& Sdw Jh p mv Hk; a w Gy J jz p fy g
w , f/ w u , fv dkUo m b mo mp u m; w p fc kr Sm t o Hk; r sm; w Jhp mv Hk; a w Gu dko m o dc Jhr , fq dk& i f crypt v ky fx m; w Jh
p mo m; & JU t o Hk; r sm; q Hk; p mv Hk; a w Gu dk t p m; x dk; z dkUy Jjz p fy gw , f/ a e mu fw p fc ku a w mh t o Hk; t r sm; q Hk; p u m; v Hk; a w G
r Sm t p m; x dk; w mu dkv J t v m; w l t o Hk; jy KE dki fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 327 -

Cracker w p fa , mu ft a e e JUu a w mh p mo m; z dki ft c sdKUu dk p dp p fa y ; E dki fw Jh application t a o ; p m; w Gu dk
a & ; z dkU& m v G, fu lr Smy g/ w u , fv dkU *.asm z dki fw p fc ku dk o i fht a e e JUu k' fa z mfr , fq dk& i f EAX? EBX? ECX p w Jh
p mv Hk; a w Gu a e a jc & mc H& r Sm jz p fy gw , f/ b ma Mu mi fhv Jq dka w mh Assembly b mo mp u m; e JU y & dk* & r fa & ; o m; & m
r Sm ' Dregister a w Gu dkt r sm; q Hk; t o Hk; jy KMu v dkUy g/
( 4 ) Le Chiffre Indchiffrable
v QdKU0 Su fp ma w Ga & ; z dkU monoalphabetic substitution crypto [ m & mp kE Sp fa y gi f; r sm; p Gm a c w fp m; c Jhw Jh
e n f; jz p fy gw , f/ ' ga y r , fh t m& y fa w Gu frequency analysis u dkw Dx Gi fv dku fw Jht c gr Sma w mh ' De n f; v r f; [ m
t o Hk; jy K& mr Sm p dw fc s& r Ir & Sda w mhy gb l; /
' D crypto t o p f& JU r lv t a w G; t a c : u a w mh 1 4 0 4 - c kE Sp fr Sm a r G; z Gm; c Jhw Jh Leon Battista Alberti
q Du & w mjz p fy gw , f/ o lU& JUt , lt q u a w mh E Sp fc k ( o dkU) ' Dhx u fy dkw Jh crypto t u & mu dkt o Hk; jy Kjy D; o lw dkU
t c si f; c si f; u dka e & mv Ja y ; z dkUjz p fy gw , f/
r lv p mo m;
- a b c d e f g h i j k l m n o p q r stuvwxyz
Crypt v ky fx m; a o mp mo m; 1
- F Z B V K I X A Y M E P L S D H J O RGNQCUTW
- G O X B F W T H Q I L A Z P J D E S YVCRKUHN
Crypt v ky fx m; a o mp mo m; 2
- GOXBFWTHQILAZPJDESYVCRKUHN
w u , fv dkU u Re fa w mfw dkUt a e e JU hello q dkw Jhp u m; v Hk; u dk crypt v ky fr , fq dk& i f y x r t u & m h [ m A
jz p fv my gr , f/ ' kw d, t u & m e u a w mh F jz p fv my gr , f/ ' De n f; v r f; u dk t o Hk; jy K& i f hello [ m AFPAD
jz p fv my gw , f/
1 5 2 3 - c kE Sp fr Sm a r G; z Gm; c Jhw JhBlaise de Vigenre u ' De n f; v r f; u dk develop x y fv ky fc Jhw mjz p fy gw , f/
t u & mE Sp fv Hk; ( o dkU) o Hk; v Hk; t p m; o lu a w mh 2 6 v Hk; ( t * Fv dy fb mo mp u m; t w Gu f a-z) u dk t o Hk; jy Kc Jhw mjz p fy g
w , f/ o lU& JUt , lt q [ m t & i fv la w Ga y : t a jc c Hc Jha y r , fhv J ' De n f; u dka w mh Vigenre crypto v dkUa c : a 0 : Mu
y gw , f/ w p fv Hk; x u fy dkw Jh crypto t u & mu dk t o Hk; jy Kw Jht w Gu f ' Dv dk crypto r sdK; u dk polyalphabetic crypto
v dkUt r n fw y fMu y gw , f/
' De n f; r Sm y x r q Hk; v ky f& r Smu a w mh Vigenre Z , m; w p fc ku dk a & ; z dkUy g/ crypto t u & ma w Ga e mu fr Sm
r lv p mo m; a w Gv dku fjc i f; t m; jz i fh Z , m; u dka & ; q GJE dki fjy D; t w e f; t o D; o D; u dk a e & mv Sn fhjc i f; ^ a & TUjc i f; [ m jy D; c Jhw Jh
t w e f; e JU q u fE G, fr I& Sdy gw , f/
r lv p mo m;
abcdefghijklmnopqrstuvwxyz
Crypt v ky f& e fq GJx m; a o mZ , m;
1 BCDEFGHIJKLMNOPQRSTUVWXYZA
2 CDEFGHIJKLMNOPQRSTUVWXYZAB
3 DEFGHIJKLMNOPQRSTUVWXYZABC
4 EFGHIJKLMNOPQRSTUVWXYZABCD
5 FGHIJKLMNOPQRSTUVWXYZABCDE
6 GHIJKLMNOPQRSTUVWXYZABCDEF
7 HIJKLMNOPQRSTUVWXYZABCDEFG
8 IJKLMNOPQRSTUVWXYZABCDEFGH
9 JKLMNOPQRSTUVWXYZABCDEFGHI
10 KLMNOPQRSTUVWXYZABCDEFGHIJ
11 LMNOPQRSTUVWXYZABCDEFGHIJK
12 MNOPQRSTUVWXYZABCDEFGHIJKL
13 NOPQRSTUVWXYZABCDEFGHIJKLM
14 OPQRSTUVWXYZABCDEFGHIJKLMN
15 PQRSTUVWXYZABCDEFGHIJKLMNO
16 QRSTUVWXYZABCDEFGHIJKLMNOP
17 RSTUVWXYZABCDEFGHIJKLMNOPQ
18 STUVWXYZABCDEFGHIJKLMNOPQR
19 TUVWXYZABCDEFGHIJKLMNOPQRS
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 328 -

20 UVWXYZABCDEFGHIJKLMNOPQRST
21 VWXYZABCDEFGHIJKLMNOPQRSTU
22 WXYZABCDEFGHIJKLMNOPQRSTUV
23 XYZABCDEFGHIJKLMNOPQRSTUVW
24 YZABCDEFGHIJKLMNOPQRSTUVWX
25 ZABCDEFGHIJKLMNOPQRSTUVWXY
26 ABCDEFGHIJKLMNOPQRSTUVWXYZ
y x r t w e f; [ m Caesar roll e JU crypto t u & mw p fv Hk; jz p fy gw , f/ ' gu dk a e & mw p fa e & mp m a & TUx m;
w mjz p fy gw , f/ ' De n f; u dk t o Hk; jy Kr , fq dk& i f o i f crypt v ky fv dku fw Jht p mv Hk; t w Gu f t w e f; t o p fw p fc ku dk
t o Hk; jy K& r Smjz p fy gw , f/ Decrypt jy e fv ky fz dkUt w Gu f cracker [ m b , fp mv Hk; t w Gu f b , ft w e f; u dk t o Hk; jy K&
r v Jq dkw m o dx m; & y gr , f/ o i fht a e e JU crypt v ky fz dkU
y x r p mv Hk; t w Gu f - t w e f; ( 5 )
' kw d, p mv Hk; t w Gu f - t w e f; ( 1 4 )
w w d, p mv Hk; t w Gu f - t w e f; ( 2 1 ) p w ma w Gu dkt o Hk; jy KE dki fy gw , f/
' Dv dkr sdK; 0 Su fp ma w Gu dka z mfz dkU 0 Su fp mu dk v u fc H& & Sdo l[ m b , ft w e f; a w Gu dkt o Hk; jy K& r v Jq dkw m o dx m; &
y gr , f/ ' Dt w Gu f e n f; v r f; w p fc ku a w mhkeyword w p fc ku dkt o Hk; jy Kz dkU jz p fy gw , f/
Oy r ma jy m& & i f "Begin attack at sundown" q dkw Jhp mo m; u dk 0 Su fz dkUt w Gu f GREEN q dkw Jh
keyword u dkt o Hk; jy Kr , fv dkU, lq Mu y gp dkU/ ' gq dk keyword u dk p mo m; t a y : x y fu mx y fu ma & ; & r Smjz p fy gw , f/
' gr So m keyword x Jr Sm& Sdw Jhp mv Hk; a w G[ m 0 Su fr , fhp mo m; x Jr Sm& Sdw Jhp mv Hk; a w Ge JU c sdw fq u fr dr Smjz p fy g w , f/
G R E E N G R E E N G R E E N G R E E N (keyword)
b e g i n a t t a c k a t s u n d o w n (message)
b q dkw Jhp mv Hk; u dk 0 Su fz dkUt w Gu f keyword x Ju , lr Smu a w mh G y g/ Vigenre Z , m; t & G & Sdw mu
a w mh t w e f; ( 6 ) r Smjz p fy gw , f/ b u dkt p m; x dk; r , fht u & mu a w mh t w e f; ( 6 ) u b e JUw p fw e f; w n f; r Sm& Sdw Jh H
p mv Hk; jz p fy gw , f/
e q dkw Jhp mv Hk; u dk 0 Su fz dkUt w Gu f keyword x Ju , lr Smu a w mh R y g/ Vigenre Z , m; t & R & Sdw mu
a w mh t w e f; ( 1 7 ) r Smjz p fy gw , f/ e u dkt p m; x dk; r , fht u & mu a w mh t w e f; ( 1 7 ) u e e JUw p fw e f; w n f; r Sm& Sdw Jh V
p mv Hk; jz p fy gw , f/
' ga Mu mi fh "beginattackatsundown" p mo m; u dk "GREEN" q dkw Jh keyword o Hk; jy D; 0 Su fv dkU& v mw Jh
a e mu fq Hk; p mo m; u a w mh"HVKMAGKXEPQRXWHTUSAA" jz p fy gw , f/
Keyword a w G[ m & Sn f& i fy Jjz p fjz p f? 0 gu sa w Gu dk keyword t jz p fe JUt o Hk; jy Kw my Jjz p fjz p f o i fht a e e JU
Vigenre Z , m; u t w e f; a w Gu dk y dkr kdx n fho Gi f; E dki fw mjz p fw Jht w Gu f o i fh& JU crypto u k' fu dk jy e fa z mfE dki fz dkU
c u fc Ja p r Smjz p fy gw , f/ w u , fv dkU o i fht a e e JU frequency analysis u dkt o Hk; jy Kr , fq dk& i f b , fp mv Hk; [ m t
v Jv dkU a jy m& c u fa e r Smjz p fy gw , f/ Vigenre & JUa w GU& Sdr Iu dk 1 5 8 6 - c kE Sp fr Sm Tracict des Chiffres
r Smx kw fa z mfc Jha y r , fhv JE Sp fa y gi f; 2 0 0 a v mu fx dt o Hk; r sm; w Jht q i fha & mu fr v mc Jhy gb l; /
( 5 ) Charles Babbage & Vigenre
Vigenre crypto & JUt p Gr f; [ m e n f; v r f; a y gi f; p Hke JU crypt v ky fE dki fw Jhp mv Hk; w p fv Hk; jz p fy gw , f/ w u , f
v dkU KING q dkw Jh keyword u dkt o Hk; jy Kr , fq dk& i f o w fr Sw fx m; w Jhp mv Hk; w p fv Hk; u dk crypt v ky fz dkU e n f; ( 4 ) e n f;
jz p fE dki fy gw , f/ p u m; v Hk; a w Gu dk crypt v ky f& mr Smv J ' Dv dky gy J/ "the" q dkw Jh p u m; v Hk; u dk crypt v ky fr , fq dk& i f
a w GUE dki fw mu a w mh DRQ? BUK? GNO e JU ZRM w dkUjz p fy gw , f/ ' gu dk decrypt v ky fz kdUy dkjy D; c u fc JE dki fa y r , fh
r jz p fE dki fb l; a w mhv Jr [ kw fy gb l; /
1 7 9 1 - c kE Sp fz Gm; Charles Babbage u a w mh ' Dv dk crypto r sdK; u dk y x r q Hk; a z mfE dki fc Jhw Jho ljz p fy gw , f/
o l[ m p m& i f; Z , m; a w Ge JUy w fo u fjy D; b 0 u dkt c sde fjy n fhjr Ky fE SHc Jhy gw , f/ ' Da e U t o u ft mr c Hu kr P Dr Sm w Gi fu s, f
p Gmt o Hk; jy Ka e Mu w Jh a r G; ^ a o q u fE T, fr Ie JUy w fo u fw Jh p m& i f; a w Gu dk jy Kv ky f& mr Sm o l[ m w p fOD; t y gt 0 i f jz p fc Jh
y gw , f/
o lp Of; p m; r dw mu a w mhw u , fv dkU "the" u dk crypt v ky fz dkU& m e n f; v r f; ( 4 ) r sdK; o m & Sdc Jhr , fq dk& i f 0 Su fp m
x Jr Sm t Mu dr fa jr mu fr sm; p Gm t o Hk; jy Kx m; w Jh p u m; v Hk; a w G[ m w ln Dw Jh crypto e n f; u dk t Mu dr fMu dr f t o Hk;
jy Kr Smy Jv dkU c e fUr Se f; r dc Jhw my g/ p mo m; a w G& Sn fa v a v t c Gi fht a & ; y dka v a v y g/ ' Dv dkt Mu dr fMu dr f t o Hk; jy Kjc i f; u
Babbage u dkVigenre crypto t w Gu f decryption e n f; v r f; u dka w GU& Sda p c Jhw mjz p fy gw , f/
Babbage & JUe n f; v r f; u a w mh & dk; & Si f; y gw , f/ 0 Su fp ma w Gx Jr Sm w p fMu dr fx u fr u t o Hk; jy Kx m; w Jh
p mv Hk; w GJa w Gu dk & Smc dki f; y gw , f/ 0 Su fp mt p & JUt u Gmt a 0 ; e JU p mv Hk; w GJE Sp fc kw ln Dw Jht c g i f; w dkUMu m; t u Gmt a 0 ; u
o i fhu dk keyword t v Hk; t a & t w Gu fe JUy w fo u fw Jh o Jv Ge fp a w Gu dk a y ; r Smjz p fy gw , f/ w u , fv dkU keyword
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 329 -

t v Hk; t a & t w Gu fu dko dc Jh& i f r lv p mo m; u dk crypt v ky f& mr Sm crypto t u & m b , fE Sp fv Hk; t o Hk; jy Ko v Jq dkw m
w Gu fc su fE dki fr Sm jz p fy gw , f/ ( a & SUy dki f; r Sm u Re fa w mf e r le mjy c Jhw mu a w mh crypto t u & m ( A-Z) 2 6 v Hk; e JUy g/ )
w u , fv dkU o i ft o Hk; jy Kc Jhw mu crypto t u & m w p fv Hk; w n f; q dk& i f monolaphabetic crypto jz p fjy D; b , fv dk
decrypt v ky f& r v Jq dkw m o i fo dr Smjz p fy gw , f/
w u , fv dkU keyword [ m 5 v Hk; jz p fa e w , fq dk& i f o i fht a e e JU y x r q Hk; t u & mt w Gu f 1? 6? 11 p w Jh
p mv Hk; a w Gu dkt o Hk; jy K& r Smjz p fy gw , f/ ' kw d, t u & mt w Gu f 2? 7? 12 p w Jh p mv Hk; a w Gu dkt o Hk; jy K& r Smjz p fy gw , f/
Keyword x Jr Sm& Sdw Jh p mv Hk; a w Gv dky J o i fht a e e JU a jr mu fr sm; v Sp Gma o m t u & ma w Gu dkt o Hk; jy K& r Sm jz p fy gw , f/
b , ft u & mu dkt o Hk; jy K& r , fq dkw m b , fv dko d& SdE dki fy go v J/ ' Dt w Gu ft a jz u a w mh o i fc e fUr Se f; r dr Smy g/
Frequency analysis jz p fy gw , f/ w u , fv dkU o i fht a e e JU keyword & JUt v Hk; t a & t w Gu fu dk o dr , fq dk& i f o i f
t o Hk; jy K& r Smu frequency analysis y g/ r Sw fx m; & r Smu a w mh crypto t u & m[ m t & i ft w e f; u p mv Hk; a w Gu dk
a e & ma & TUx m; w Jh& dk; & dk; t u & m w p fv Hk; o mjz p fy gw , f/
Vigenre u dk assembler w Gi fp r f; o y fjc i f;
Vigenre crypto u dk assembler r Smp r f; o y fz dkU r Sw fOmP fr Sm Vigenre Z , m; t a jr mu ft r sm; v dkt y f
y gw , f/ u Re fa w mfw dkUt a e e JU index e JU key char pointer a w Gt r sm; Mu D; v dkt y fy gw , f/ e r le my & dk* & r fw p fy k' f
u dkMu n fhMu & a t mi f/
Crypting:
add al,ah ;al is clear char and ah is key char
sub al,"A"+"A"
cmp al,25
jng @F
sub al,26 ;Overflow, wrap around
@@:
add al,"A" ;al is now crypted char
Decrypting:
sub al,ah ;al is crypt char and ah is key char
cmp al,0
jge @F
add al,26 ;Underflow, wrap around.
@@:
add al,"A" ;al is now clear char
' D Assembly u k' fa w Gu dk e m; v n fz dkUt w Gu f Vigenre Z , m; r Sm t u & m 2 6 v Hk; & Sdw m t r Sw f& y g/
w p fv Hk; p D[ m jy D; c Jhw Jht w e f; u dkw p fa e & mp m a & TUy gw , f/
w u , fv dkU "the" q dkw Jhp u m; v Hk; u dk KING q dkw Jh keyword e JU crypt v ky fr , fq dk& i f y x r p mv Hk; t
t w Gu f 0 Su fx m; jy D; o m; p mv Hk; [ m t w e f; ( 1 0 ) K e JU t p mv Hk; w dkUw p fx y fw n f; u sw Jha e & m D jz p fv my gr , f/
' gu dkMu n fhz dkU a e mu fw p fe n f; u a w mh A e JUp w Jht w e f; u K & Sdw Jh column u dko Gm; y g/ Column 10
jz p fy gw , f/ ( A column u a w mhcolumn 0 jz p fy gw , f/ ) T column & Sd& mjz p fw Jhcolumn 19 u dk K column
& Sd& m column 10 e JYa y gi f; & i f 29 & y gr , f/ t * Fv dy ft u & mr Sm p mv Hk; 2 6 v Hk; y J& Sdw Jht w Gu f overflow jz p fa e y g
w , f/ 29 jz p fw Jht w Gu f a e mu fw p fMu dr fq dk& i f 0(A)? 27(B)? 28(C)? 29(D)? 30(E) p o n fjz i fhjz p fw Jht w Gu f
D column & Sd& mu dk& y gw , f/ ' gu a w mhT p mv Hk; u dk K key t o Hk; jy Kw Jht c g t p m; x dk; r , fhp mv Hk; w Gu fc su fy Hky g/
u Re fa w mfw dkUt a e e JU decryption v ky f& mr Smv J ' Dw ln Dw JhOy a ' o u dk t o Hk; jy Ky gw , f/ ' ga y r , fh ' Da e & m
r Sma w mh crypt v ky fx m; w Jhp mv Hk; u a e key p mv Hk; u dk E Iw f, ly gw , f/ ' ga Mu mi fh overflow u dk& Smr , fht p m;
underflow u dko m& Smy gw , f/ ' Da v mu fq dk& i f Vigenre crypto u dke m; v n fa v mu fjy Dx i fy gw , f/ ' ga Mu mi fh
decrypt v ky fx m; w Jha t mu fy gu k' fu dka z mfMu n fhy g/
BBLM RS VRJ XTYOETOSWP UNTYOJH XBLHCOQ DLVTSQX FHO T PRQMJLJ UJG?
QXJ CD FJDG YK JWTBTKM FHO BB DCXLYCHDS HYW WSBUDTOS NZ IUAA GNNS,
MQE QDMYC BB UUOI NZ VJRTI LLZVNRKOX.

QSTC IU DMY OBOFGBJHNX KEVGJYY XAOVSH UYW TIPUD?
YCHCIE SX ODBWG C PJUEANR....MSSEJ BB UUSSA EAN WJYQY NARCMOS.
Vigenre u dka & Smi f& Sm; jc i f;
Vigenre crypto t p Gr f; x u fjc i f; u o lUu dkt o Hk; jy K& w m y dkr dkc u fc Ja p y gw , f/ Monoalphabetic
crypto x u fy dkr dkt p Gr f; x u fjy D; Vigenre crypto x u ft o Hk; jy K& w m y dkr dkv G, fu lw mu a w mh homophonic
substitution crypto y Jjz p fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 330 -

' D crypto r Sma w mh o i fht a e e JU p mv Hk; w p fv Hk; u dk p mv Hk; a w Gt r sm; Mu D; e JU t p m; x dk; E dki fjy D; t p m; x dk; w Jh
p mv Hk; t a & t w Gu f[ m p mv Hk; t o Hk; jy Kr Ie JU t c sdK; u sy gw , f/ w u , fv dkU p mv Hk; a u dkt o Hk; jy Kr I[ m 9 % & Sdr , fq dk
& i f? u Re fa w mfw dkUt a e e JU a p mv Hk; t w Gu f t p m; x dk; & r Smu t u & m 8 v Hk; jz p fy gw , f/ 0 Su fr , hfp mo m; x Jr Sm a
q dkw Jh p mv Hk; u dka w GUw dki f; u Re fa w mfw dkUt a e e JU a e JU assign v ky fx m; w Jh b , ft u & m 8 v Hk; e JUr q dk t p m; x dk; & r Sm
jz p fy gw , f/ ' D8 v Hk; r Sma w mh b , fp mv Hk; jz p fjz p f t a & ; r Mu D; y gb l; / p mo m; u dk 0 Su fjy D; w Jht c sde fr Sma w mh a t w Gu f
t p m; x dk; v dku fw Jh p mv Hk; w dki f; [ m 0 Su fp mx Jr Sm t o Hk; jy Kr IE Ie f; [ m 1 % y J& Sdr Smjz p fy gw , f/ w u , fv dkU b ( o dkU)
t jc m; p mv Hk; a w Gq dk& i fv J t o Hk; jy Kr IE Ie f; [ m 1 % y J& Sdr Smjz p fy gw , f/ b q dk& i fa w mh u Re fa w mfw dkUt a e e JU t u & m
2 v Hk; x d t p m; x dk; & r Sm jz p fy gw , f/ r lv p mo m; x Ju b , fp mv Hk; u dk 0 Su fv dku f& i fy Jjz p fjz p f? 0 Su fp mx Jr Sma w mh
o lw dkU& JU t o Hk; jy Kr IE Ie f; u 1 % y J& Sda e r Smy g/
a t mu fr Sma z mfjy x m; w mu a w mh homophonic substitution crypto e JUy w fo u fw Jhe r le my g/ ' D* P e f;
a w Gu dkt o Hk; jy Ky gw , f/
a b c d e f g h i j k l m n o p q r s t u v w x y z
09 48 13 01 14 10 06 23 32 15 04 26 22 18 00 38 94 29 11 17 08 34 60 28 21 02
12 81 41 03 16 31 25 39 70 37 27 58 05 95 35 19 20 61 89 52
33 62 45 24 50 73 51 59 07 40 36 30 63
47 79 44 56 83 84 66 54 42 76 43
53 46 65 88 71 72 77 86 49
67 55 68 93 91 90 80 96 69
78 57 99 75
92 64 85
74 97
82
87
98
t o Hk; jy KE Ie f; 1 % & Sdw Jh t u & mw dki f; t w Gu f 0 Su fp mx Jr Sm frequency analysis u dkt o Hk; jy Kz dkUe n f; v r f;
r & Sdy gb l; / ' gq dkjy e fa z mfv dkUr & a w mhb l; v m; / ' Dv dka w mhv Jr [ kw fy gb l; /
Decrypter r Smv J o Jv Ge fp a w G& Sdy gw , f/ b mo mp u m; w dki f; & JU p mv Hk; w dki f; r Sm o lU& JUy i fu dkt & n ft c si f;
e JU t jc m; p u m; v Hk; a w GMu m; q u fE G, fr I & Sdy gw , f/ w u , fv dkU homophonic substitution crypto u dko Hk; c Jh& i f
a w mh' gu dkc GJjc m; E dki fy gw , f/
Oy r mjy & & i f t * Fv dy fb mo mp u m; q a e mu fr Smq dk& i f u t jr Jw r f; v dku f& y gw , f/ t jc m; b , fp mv Hk; r S
v dku fv dkU r & y gb l; / w u , fv dkU homophonic substitution crypto e JU 0 Su fx m; w Jht * Fv dy fp mo m; u dk decrypt
v ky fr , fq dk& i f u Re fa w mfw dkUt a e e JU q q dkw Jhp mv Hk; u dk& Smjy D; t u & mw p fv Hk; ( o dkU * P e f; w p fv Hk; ) e JU t & i ft p m; x dk;
& r Smjz p fy gw , f/ u u dkt o Hk; jy KE Ie f; [ m p mv Hk; a w Gt m; v Hk; & JU 3 % jz p fa Mu mi f; o dx m; w Jht w Gu f u a e & mr Sm t u & m
3 v Hk; e JU t p m; x dk; & a u mi f; x dk; & y gv dr fhr , f/
w u , fv dkU 0 Su fp mx Jr Sm w ln Dw Jht u & m 3 v Hk; v dku fw Jh p mv Hk; w p fv Hk; u dk a w GUc Jh& i f u Re fa w mfw dkUt a e e JU
, HkMu n f& r Smu ' Dt u & ma w G[ m u u dkq dkv dkc si fw mjz p fjy D; y x r p mv Hk; u a w mh q jz p fy gw , f/ t jc m; p mv Hk; a w G
u dka w mh a & G; x kw fz dkU c u fy gv dr hfr , f/ ' ga y r , fh o lw dkUt c si f; c si f; q u fE G, fr Ia w Gu b , fp mv Hk; jz p fw , fq dkw m
w Gu fx kw fE dki fy gv dr fhr , f/ ' Dv kdcrypto r sdK; u dkjy e fa z mfE dki fz dkU jz p fE dki fa y r , fh& dk; & Si f; v Sw Jhmonoalphabetic crypto
x u fp m& i fa w mht r sm; Mu D; p dw fc s& y gw , f/
o mr e fu mv QHu mMu n fhr , fq dk& i fa w mh homophonic substituion crypto [ m polyalphabetic
crypto t r sdK; t p m; t c sdKUe JU w lo a , mi fa , mi f & Sdy gw , f/ r lv p mo m; & JU p mv Hk; w dki f; u dk t u & mw p fc kc ke JU t p m;
x dk; E dki fa y r , fho lw dkUr Sm x i f& Sm; w Jhu GJjy m; jc m; e m; c su f & Sdy gw , f/
t a y : u Oy r mr Sm a p mv Hk; u dk r w ln Dw Jh* P e f; 8 v Hk; e JU a z mfjy c Jhy gw , f/ ' D* P e f; a w G[ m a u dka z mfjy jy D;
a w p fv Hk; w n f; u dko m a z mfjy E dki fMu y gw , f/ Polyalphabetic crypto r Sma w mhr lv p mo m; x Ju p mv Hk; w p fv Hk; u dk
p mv Hk; a jr mu fr sm; p Gme JU a z mfjy E dki fy gw , f/ ' ga y r , fh t p m; x dk; r , fh p mv Hk; a w Gu dka w mh r lv p mo m; x Jr Smy gw Jh p mv Hk;
a w Ge JUy J t p m; x dk; E dki fy gw , f/ ' ga Mu mi fhr dkUv J homophonic substituion crypto u dk monoalphabetic crypto
v kdUy J a jy mE dki fw my g/ Crypto t u & mw p fv Hk; u dk z e fw D; jy D; c sde fr Sma w mh w p fa v Qmu fv Hk; t o Hk; jy Ko Gm; r Smjz p fy g
w , f/ p mv Hk; w p fv Hk; u dk t p m; x dk; z dkUt w Gu f p mv Hk; w p fv Hk; t p m; x dk; & mr Sma w mh u GJjy m; r Ir & Sdy gb l; / w u , fv dkU
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 331 -

poly alphabetic crypto u dko Hk; r , fq dk& i fa w mh r w ln Dw Jh crypto t u & ma w Gu dk t q u fr jy w f a jy mi f; a y ;
a e & r Sm jz p fy gw , f/
Homophonic substituion crypto e JU decrypt v ky fx m; w Jha t mu fy gu k' fu dka z mfMu n fhy g/
HNE 0IQWtG OY98CK5u YfTB7| pA v2] J 1W[UZjweh3 X i
gv qmV-sSkboDI6 }dcaYz x L t2W SDT
2.2, 9u ]H0|C X13-5 Z7gycK. Ul px8MEeikI tDQw1GB o
J A 3VAObfuch[ jqvsz| W2] mV-Sd}x 2.2 g
vI2 A-SHDK0T ]EZ5t9Q GU7u, rWc{ B |xy1O3 ve
kNJ Dpn V 2W].
( 6 ) Playfair
Playfair crypto u kdz e fw D; c Jhw mu a w mhLyon Playfair jz p fy gw , f/ ' Dcrypto [ m r lv p mo m; x Jr Sm
& Sdw Jhp mv Hk; E Sp fv Hk; w dki f; u dk t jc m; p mv Hk; w GJe JU t p mx dk; w mjz p fy gw , f/ p mo m; u dk crypt v ky f& mr Sme JU decrypt v ky f
& mr Sma w mh a y ; y dkUo le JU v u fc H& & Sdo lw dkU[ m keyword w p fc ku dkt o Hk; jy Kz dkU Mu dKw i fo a b mw ln Dx m; & r Sm
jz p fy gw , f/
' Dcrypto u dkt o Hk; jy Ky Hku a w mh' Dv dky g . . .
p mv Hk; a w Gu dk 5x5 (a-z) p w k& e f; y Hkc sa & ; y g/ I e JU J u a w mhw ln Dw Jha e & mr Sm & Sda e & y gr , f/ Keyword u a e
p w i fy g/ Keyword t a e e JU CHARLES u dko Hk; r , fq dk& i f & & Sdr Smu a w mh-
C H A R L
E S B D F
G I/J K M N
O P Q T U
V W X Y Z
' Dha e mu fr Sma w mh o i fht a e e JU message p mo m; u dk bigram v dkUa c : w Jh p mv Hk; w GJa w Gt a e e JU y dki f; v dkU& jy D
jz p fy gw , f/ Bigram w kdi f; r Sm r w ln Dw Jhp mv Hk; a w Gy g0 i f& y gr , f/ ' gha Mu mi fh o i fht a e e JU x u dk p mv Hk; w ln Dw Jh
t w GJr Smx m; & y gr , f/ ' Dv dkr Sr [ kw f& i fa w mhw ln Dw Jhbigram r Sm t q Hk; o w f& y gv dr fhr , f/
r lv p mo m;
We meet at hammersmith bridge at seven.
Bigram x J& Sdp mo m;
we-me-et-at-ha-mx-me-rs-mi-th-br-id-ge-at-se-ve-nx
' Dha e mu fr Sma w mh p m0 Su fw m p w i fy gw , f/ Bigram w dki f; u a w mh a t mu fy gt ky fp kw p fc kc kx Ju
jz p fE dki fy gw , f/
1 / p mv Hk; w GJ[ m w ln Dw Jhr sOf; w p fa Mu mi f; w n f; a y : r Sm jz p fy gw , f/
2 / p mv Hk; w GJ[ m column w p fc kw n f; r Sm jz p fy gw , f/
3 / t a y : E Sp fc kp v Hk; r jz p fE dki fb l; /
1 / w u , fv dkU p mv Hk; E Sp fv Hk; v Hk; [ m w ln Dw Jh row w p fc kw n f; r Sm & Sda e c Jh& i f? o lw dkUu dk n mz u fu w p fv Hk; p De JU
t p m; x dk; & y gr , f/ MI q dk& i f NK jz p fv my gr , f/ w u , fv dkU p mv Hk; w p fv Hk; [ m a e mu fq Hk; p mv Hk; jz p fa e c Jh& i f ' D
row r Sm& Sdw Jhy x r q Hk; p mv Hk; e JU t p m; x dk; & r Sm jz p fy gw , f/
2 / w u , fv dkU p mv Hk; w GJ[ m w ln Dw Jh column w p fc kw n f; r Sm & Sda e c Jh& i f? o lw dkU& JU a t mu fu p mv Hk; w p fv Hk; p De JU
t p m; x dk; & y gw , f/ GE q dk& i f OG jz p fv my gr , f/ w u , fv dkU p mv Hk; w p fv Hk; [ m a e mu fq Hk; row r Smo m & Sda e
c Jh& i f y x r q Hk; row u p mv Hk; e JU t p m; x dk; & r Smjz p fy gw , f/ YR q dk& i f RD jz p fv my gr , f/
3 / ' DE Sp fc kv Hk; x Ju r [ kw fc Jh& i f ' Dv dk v ky fa q mi f& r Sm jz p fy gw , f/ y x r p mv Hk; u dk0 Su fz dkU ' kw d, p mv Hk; & Sd& m
column r a & mu fc i f row u dkMu n fh& r Smjz p fy gw , f/ ' Dp mv Hk; E Sp fv Hk; w dkU q Hk& ma e & m[ m y x r p mv Hk; u dk t p m; x dk; z dkU
jz p fy gw , f/ ' kw d, p mv Hk; u dk0 Su fz dkUt w Gu fu a w mhy x r p mv Hk; & JU column r a & mu fc i f row jz p fy gw , f/ ' Dp mv Hk;
E Sp fv Hk; w dkU q Hk& ma e & m[ m ' kw d, p mv Hk; u dk t p m; x dk; z dkU jz p fy gw , f/ ' ga Mu mi fh VI [ m WG jz p fv mjy D; SV
u a w mhEW jz p fv my gw , f/
w u , fv dkU r lv p mo m; & JU p mv Hk; a w Gu dk a v ; a x mi fhu Gu fw p fc k& JU a x mi fha w Gt a e e JU a w GUjr i fE dki fjy D; t p m;
x dk; v dku fw Jhp mv Hk; a w Gu dka w mhq e fUu si fb u f a x mi fha w Gr Sm a w GUjr i f& r Smjz p fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 332 -

Bigram p mo m;
we me et at ha mx me rs mi th br id ge at se ve nx
Crypt v ky fx m; a o mp mo m;
VSDGODQRARKYDGDHNKRPADSMOGQRBSCGKZ
( 7 ) ADFGX crypto
ADFGVX crypto r Sma w mh a e & mv Jw ma & m? t p m; x dk; w my g t o Hk; jy Ky gw , f/ Crypto u dk t o Hk; jy Ky Hk
u ' Dv dky g/ p w k& e f; y Hk& JU a e & m 3 6 c kr Sm A-Z e JU 0-9 u dk Mu HK& ma & ; c sy g/ Row e JU column r Sm ADFGVX v dkU
t r n fw y fy g/ p w k& e f; u Gu fx Ju p mv Hk; a w Gu a w mh key & JUw p fp dw fw p fa ' o jz p fjy D; ' D0 Su fp mu dka z mfr , fho lq Dr Sm
' Dp w k& e f; u Gu f & Sd& y gr , f/
A D F G V X
A 8 p 3 d l n
D l t 4 0 a h
F 7 k b c 5 z
G j u 6 w g m
V x s v i r 2
X 9 e y 0 f q
y x r t q i fhu b , f row e JU b , f column r Sm 0 Su fr , fhp mo m; x Ju p mv Hk; & Sda e o v Jq dkw m Mu n fh& y g
r , f/ ' Dha e mu fr Sma w mh' Dp mv Hk; & Sd& ma e & mu dk a & G; c s, f& y gr , f/ ' DOy r mt w Gu fq dk& i f 8 u dk AA e JUt p m; x dk; E dki fjy D; p
u dkAD e JU t p m; x dk; & r Smjz p fy gw , f/
r lv p mo m;
Attack at 2230
Crypt v ky fx m; a o mp mo m;
DV DD DD DV FG FD DV DD VX VX AF XG
' g[ m & dk; & Si f; v Sw Jh monoalphabetic substitution crypto jz p fw Jht w Gu f frequency analysis e JU
t v G, fw u l jy e fa z mfE dki fy gw , f/ ' kw d, t q i fhu a w mh a e & mc si f; v Jz dkU jz p fy gw , f/ a e & mc si f; v Jw mu a w mh key
w p fc ka y : r lw n fy gw , f/ ' DOy r mr Sma w mh MARK q dkw Jh key u dko Hk; y gw , f/ ' D key u dka w mh v u fc H& & Sdw Jh
o lu y g o dx m; & r Smjz p fy gw , f/
a e & mv Jw mu dka w mha t mu fy gt w dki f; jy Kv ky f& r Sm jz p fy gw , f/
p w k& e f; u Gu f t o p fx Jr Sm& Sdw Jh y x r q Hk; row r Sm key p mv Hk; a w Gu dkc sa & ; y g/ ' Dha e mu fr Sma w mh y x r
t q i fhw ke f; u 0 Su fv dku fw Jhp mo m; a w Gu dk key & JUt a & t w Gu ft w dki f; c sa & ; y g/ Key x Jr Sm& Sdw Jhp mv Hk; a w Gu dk
i , fp OfMu D; v dku fp Dy g/ ' gq dk t jc m; column w p fc k& & Sdv my gv dr fhr , f/
M A R K
D V D D
D D D V
F G F D
D V D D
V X V X
A F X G
A K M R
V D D D
D V D D
G D F F
V D D D
X X V V
F G A X
a e mu fq Hk; crypt v ky fv dku fa o mp mo m;
VD DD DV DD GD FF VD DD XX VV FG AX
b ma Mu mi fh A? D? F? G? V e JU X u dk t o Hk; jy K& o v Jq dk& i fa w mh ' Dp mv Hk; a w Gu dk Morse t u & mt a e e JU
t o Hk; jy Kv dkUjz p fy gw , f/ ' Dv dkjy Kv ky fjc i f; t m; jz i fh0 Su fp mu dka y ; y dkUw Jht c sde fr Sm t r Sm; e n f; E dki fv dkUjz p fy gw , f/
a u mi f; jy D/ Crypto o a b mw & m; a w Gu dk o djy D; w Jha e mu fr Sma w mh crypto algorithm t c sdKUu dk a v hv m
Mu n fhy gr , f/ t o Hk; t r sm; q Hk; crypto algorithm a w Gu a w mh ADELR32? AES? BLOWFISH? CAST?
CRC16/32? DES? DESX? FROG? GOST? HAVAL? ICE? ICELOCK? MARS? MD4/5? MISTY?
NEWDES? Q128? RC2/5/6? RIJNDAEL? RIPEMD? RSA? SHA? SHARK? SKIPJACK?
SNEFRU? SQUARE? TIGER? TWOFISH e JU ZLIB p o n fw dkUjz p fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 333 -

' D algorithm a w Gt m; v Hk; x Jr Smr S MD5 u dka v hv mMu n fhy gr , f/ Xilisoft u x kw fw Jh application
t m; v Hk; [ m MD5 u dkt o Hk; jy Kjy D; registration routine u dka & ; o m; x m; Mu w m jz p fy gw , f/ ' ga Mu mi fh MD5 u dk
t o Hk; jy Kx m; w JhXilisoft Audio Converter 2.1.x & JU registration routine u dka v hv mMu n fhMu & a t mi f/
( 8 ) MD5 q dko n fr Sm . . .
MD5 (Message Digest 5) u dk 1 9 9 2 - c kE Sp fr Sm y ga r mu Ronald L. Rivest u z e fw D; c Jhw mjz p fy g
w , f/ MD5 hash algorithm u a w mhone-way hash algorithm a w Gx Ju w p fc kjz p fa y r , fht o Hk; t r sm; q Hk; ?
, HkMu n f& q Hk; ? e mr n ft Mu D; q Hk; jz p fy gw , f/
Hash algorithm q dkw mu a w mh t c su ft v u fa w Gu dk u sp fv sp fp Gmjz p fE dki fa & ; t w Gu f x kw fv ky fx m; w Jh?
t w dkc sHK; x m; w Jho c sFm function w p fc ko mjz p fy gw , f/ ' Dv kdt w dkc sHK; jy D; & v mw Jht c su ft v u fa w Gu dk hash w e fz dk;
( o dkU) hash v dkUa c : y gw , f/ ' Dw e fz dk; u dk w Gu fc su fw Jhjz p fp Ofu dka w mh hashing v dkUa c : y gw , f/ Hash algorithm
a w Gt m; v Hk; & JU t a jc c Hu a w mh w ln Dw Jh o c sFm function u dkt o Hk; jy Kjy D; w Gu fc su fx m; w Jh hash E Sp fc k[ m r w ln Dc Jh
& i f input a w G[ m w e n f; e n f; e JU r w ln Dv dkUjz p f& y gr , f/ Hash algorithm a w Gu dk "one-way" v dkUa c : q dk& jc i f;
t a Mu mi f; u a w mhhash w e fz dk; u a e r lv a ' w ma w Gu dkjy e fv n fr & , lE dki fa w mhv dkUy g/
MD5 [ m message w p fc k ( o dkU) a ' w mz dki fw p fc kt w Gu f hash w p fc ku dkw Gu fc su f& ma w mh t v Ge f
a u mi f; r Ge fw Jh hash algorithm a u mi f; w p fc kjz p fy gw , f/ MD5 & JU w du sw Jhp mv Hk; t a & t w Gu f& Sdw Jh u sp fv sp fp Gm
a z mfjy jc i f; u dk message digest ( o dkU) fingerprint ( o dkU) MD5 hash v dkUa c : y gw , f/ MD5 message digest
[ m t a o o w fr Sw fx m; w Jh 128-bits jz p fy gw , f/ (128-bits = 16 Bytes = 4 DWords) MD5 t a Mu mi f;
t a o ; p dw fo dc si f& i fa w mh Google t o Hk; jy Kjy D; ]RFC 1321 - The MD5 Message-Digest Algorithm}
p mw r f; u dk & Sma z Gz w f& IE dki fy gw , f/ ' Dp mw r f; r Sm message digest w Gu fc su fy Hk? MD5 & JUt m; o mc su fe JU t m; e n f;
c su fa w Gu dka w GU& SdE dki fy gw , f/
( 9 ) Xilisoft Audio Converter \ serial u dk& Sma z Gjc i f;
Xilisoft & JU application a w Gr Sm registration routine u dk UILib71.dll? UILib8_MFCDll.dll z dki fr Sm
a & ; o m; x m; a Mu mi f; ]Teleport Pro 1.61} o i fc e f; p me d* Hk; r Sm a jy mc Jhw m jy e ft r Sw f& y g/ Xilisoft Audio
Converter r Sma w mh registration routine t w Gu f UILib71.dll z dki fu dk t o Hk; jy Ky gw , f/ ' ga Mu mi fh UILib71.
dll u dkPEiD e JUp p fa q ; Mu n fhy gr , f/ y Hk( 1 ) /

y Hk( 1 )
y Hk( 1 ) r Smjr i f& w Jht w dki f; UILib71.dll u dk Visual C++ 7.x e JUa & ; o m; x m; w mjz p fy gw , f/ b , f
protector e JUr S protect v ky fx m; jc i f; r & Sdy gb l; / u dkE Sdy fjy D; Krypto Analyzer u dka & G; v dku fw Jht c sde fr Sma w mh
y Hk( 2 ) t w dki f; jr i f& y gw , f/

y Hk( 2 )
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 334 -

y Hk( 2 ) t & q dk& i fa w mh UILib71.dll z dki fr Sm MD5 algorithm u dkt o Hk; jy Kx m; y Hk& y gw , f/ MD5 routine
& Sd& ma e & mu dkv Jjy x m; y gw , f/ ' Da e & mu dkMu n fhv dku fMu & a t mi f/ y Hk( 3 ) /

y Hk( 3 )
y Hk( 3 ) & JU t a y : z u fu dk scroll e n f; e n f; q GJjy D; Mu n fhr , fq dk& i fa w mh MD5 routine & JUt p u dk a w GU& r Smy g/
y Hk( 4 ) /

y Hk( 4 )
VA 1001E790 a e & mu dk r Sw fx m; y g/ MD5 algorithm u dk o i fa v hv mv dkw Jht c g ' Da e & mr Sm v mMu n fh
E dki fv dkUy g/ u Re fa w mfu a w mh MD5 algorithm u kd p dw f0 i fp m; jc i f; r & Sdy gb l; / / b ma Mu mi fhv Jq dka w mh
Xilisoft application a w Gr Sm algorithm w p fc ke JUw p fc kw ln Djc i f; r & Sdv dkUy g/
a u mi f; jy D/ Xilisoft Audio Converter & JU exe z dki fjz p fw Jh audioenc.exe z dki fu dk Olly r Smz Gi fhy gr , f/
y Hk( 5 ) /

y Hk( 5 )
' gq dk y Hk( 5 ) r Smjr i f& w Jht w dki f; entrypoint & Sd& mu dk a & mu fv my gr , f/ F9 u dkE Sdy fjy D; y & dk* & r fu dk run y g/
jy D; & i f register v ky fMu n fhy g/ y Hk( 6 ) /

y Hk( 6 )
y Hk( 6 ) t w dki f; register v ky fjy D; c sde fr Sma w mhy Hk( 7 ) t w dki f; jr i f& y gw , f/

y Hk( 7 )
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 335 -

' gq dk& i fa w mho i fb mv ky f& r , fq dkw m o do i fhy gjy D/ Olly r Sm F12 (Pause) u dkE Sdy fjy D; y & dk* & r f t v ky fv ky f
a e w mu dkc P & y fy gr , f/ jy D; & i f Ctrl+K (Call Stack) u dkE Sdy fjy D; y Hk( 7 ) u BadBoy message box u dk b , fu a e
a c : o Hk; a e w mv Jq dkw m Mu n fhy gr , f/ y Hk( 8 ) /

y Hk( 8 )
y Hk( 8 ) r Sm p dw f0 i fp m; p & ma w Ga w GU& y gw , f/ ' Dmessage box u dk UILib71.dll z dki fu a e a c : o Hk; w my g/
t w dt u sa jy m& & i fa w mh ImRegDlg dialog & JU OnOK function u a e a c : o Hk; x m; w my g/ ' ga Mu mi fh <JMP.
&MFC71.#1123> a e & mr Sm right-click E Sdy fjy D; Execute to return (F4) u dka & G; v dku fy g/ jy D; & i f y Hk( 7 ) u OK
button u dkE Sdy fv dku f& i f y Hk( 9 ) t w dki f; jr i f& y gr , f/

y Hk( 9 )
y Hk( 9 ) u dk a o a o c smc smMu n fhy g/ o i f& dku fx n hfv dku fw Jh name e JU license code a w Gu dk SaveRegInfo
function o Hk; jy D; registry x Jr Sm y x r q Hk; o dr f; y gw , f/ ' Dha e mu fr Sma w mh y Hk( 6 ) r Sm o i f& kdu fx n hfv dku fw Jh key u dk
IsValidRegInfo o Hk; jy D; r Se f^ r r Se f p p fw mjz p fy gw , f/ w u , fv dkU key r r Se fc Jh& i fa w mh y Hk( 7 ) u BadBoy
message u dk jy r Smjz p fy gw , f/ y & dk* & r f t v ky fv ky fy Hku dk o dE dki fa t mi fv dkU SaveRegInfo e JU IsValidRegInfo u dk
p p fa q ; Mu n fh& a t mi f/
SaveRegInfo a e & mu dka & G; v dku fjy D; Enter key u dkE Sdy fv dku fy g/ y Hk( 1 0 ) t w dki f; routine & Ju t p u dk
jr i fy gr , f/

y Hk( 1 0 )
y Hk( 1 0 ) & JU a t mu fe m; u dkscroll q GJjy D; Mu n fhc sde fr Sma w mhy Hk( 1 1 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 1 1 )
y Hk( 1 1 ) u String2HexA u a w mh o i f& dku fx n fhv dku fw Jh license code u dk HEX * P e f; t a e e JU
a jy mi f; v Ja y ; w m jz p fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 336 -


y Hk( 1 2 )
y Hk( 1 2 ) u a w mh string u a e hex u dka jy mi f; a y ; w Jh loop y g/ ' D loop u dk v ky fa q mi fjy D; c sde fr Sma w mh
MyanmarCrackingTeam-1234-5678-9012-3456 [ m BF A7 26 FF 5B A1 AD CF 43 A7 94 F1 82 16
6F 9C 6E 2C 4C DB 51 20 47 4A F5 B0 45 D3 CC 20 47 3D DF FD 19 53 D7 B7 jz p fo Gm; y gw , f/
y Hk( 1 3 ) /

y Hk( 1 3 )
' Dha e mu fr Sma w mhRegSetValueExA API o Hk; jy D; ' Dhex w e fz dk; a w Gu dk registry r Sm o Gm; o dr f; w m jz p fy g
w , f/ y Hk( 1 4 ) /

y Hk( 1 4 )
ImRegDlg:SaveRegInfo() function & JUv ky fa q mi fc su fu a w mh ' Dt x dy gy J/ ImRegDlg:IsValid
RegInfo() function & JU t v ky fv ky fy Hku dk q u fjy D; a v hv mMu n fhy gr , f/
IsValidRegInfo a e & mu dka & G; v dku fjy D; Enter key u dkE Sdy fv dku fy g/ y Hk( 1 5 ) t w dki f; routine & JUt p u dk
jr i fy gr , f/

y Hk( 1 5 )
y Hk( 1 5 ) & JU a t mu fe m; u dkscroll q GJjy D; Mu n fhc sde fr Sma w mhy Hk( 1 6 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 1 6 )
1 / RegQueryValueExA API u dko Hk; jy D; registry x Jr Sm& Sdw Jh code key u dkz w fy gw , f/ ' Dha e mu fr Sma w mh
z w fv dkU& w JhHEX key u dkHex2StringA function o Hk; jy D; string t jz p fjy e fa jy mi f; y gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 337 -


y Hk( 1 7 )
2 / MFC71.3997 function u dkv ky fa q mi fjy D; c sde fr Sma w mhkey u dk MyanmarCrackingTeam-1234-5678-9012-
3456 t p m; MyanmarCrackingTeam- t jz p fa jy mi f; v Jy gw , f/

y Hk( 1 8 )
3 / MFC71.781 function u a w mha q mhz f0 Jv f& JU internal name jz p fw Jhaudioconverter u dkz w fw mjz p fy gw , f/

y Hk( 1 9 )
4 / MFC71.4085 function u dkv ky fa q mi fjy D; c sde fr Sma w mh MSVCR71.dll & JU _mbsupr() API a Mu mi fh
MyanmarCrackingTeam- t p m; MYANMARCRACKINGTEAM- t jz p fa jy mi f; v Jo Gm; y gw , f/

y Hk( 2 0 )
5 / CALL UILib71.00342170 u a w mhmemcpy() API u dkE Sp fc go Hk; jy D; MYANMARCRACKINGTEAM
e JU audioconverter w dkUu dk a e & mc sy gw , f/ jy D; & i f o lw dkUE Sp fc ku dk a y gi f; y gw , f/ ' Dt c g MYANMAR
CRACKINGTEAM-audioconverter & v my gw , f/

y Hk( 2 1 )
6 / CALL UILib71.0035E730 u a w mh o i fv dkc si fw Jh hash u dkw Gu fx kw fa y ; r Smjz p fy gw , f/ CALL
UILib71.0035E730 a e & mu dka & G; v dku fjy D; Enter key u dkE Sdy fv dku fy g/ y Hk( 2 2 ) t w dki f; routine & JUt p u dkjr i fy gr , f/

y Hk( 2 2 )
6 . 1 / CALL UILib71.0035E680 a e & mu dka & G; v dku fjy D; Enter key u dkE Sdy fv dku fy g/ y Hk( 2 3 ) t w dki f; routine
& JUt p u dkjr i fy gr , f/
y Hk( 2 3 )
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 338 -

y Hk( 2 3 ) & JU CALL 3 c ku dk r Sw fo m; y g/ CALL 0035E760 u a w mh hash w e fz dk; u dk initialize v ky fw my g/
CALL 0035F070 e JU CALL 0035F130 u a w mhhash u dkw Gu fx kw fa y ; w JhCALL u dka c : o Hk; w mjz p fy gw , f/
6 . 1 . 1 / CALL UILib71.0035E760 a e & mu dka & G; v dku fjy D; Enter key u dkE Sdy fv dku fy g/ y Hk( 2 4 ) t w dki f; routine
& JUt p u dkjr i fy gr , f/

y Hk( 2 4 )
y Hk( 2 4 ) r Smjr i f& w Jhu k' fa w Gu dk execute v ky fjy D; c sde fr Sma w mhy Hk( 2 5 ) t w dki f; jr i f& y gw , f/

y Hk( 2 5 )
6 . 1 . 2 / ' Dw p fc gr Sma w mh y Hk( 2 3 ) u CALL UILib71.0035F070 a e & mu dka & G; jy D; Enter key u dkE Sdy fy gr , f/ ' gq dk
y Hk( 2 6 ) t w dki f; routine & JUt p u dkjr i fy gr , f/

y Hk( 2 6 )
y Hk( 2 6 ) & JU a t mu fe m; u dkscroll q GJjy D; Mu n fhc sde fr Sma w mhy Hk( 2 7 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 2 7 )
6 . 1 . 2 . 1 / y Hk( 2 7 ) u CALL UILib71.0035E790 a e & mu dka & G; jy D; Enter key u dkE Sdy fc sde fr Sma w mh MD5 hash
u dkw Gu fw Jhroutine & JUt p u dkjr i fy gw , f/ y Hk( 2 8 ) /

y Hk( 2 8 )
y Hk( 2 8 ) e JU y Hk( 4 ) w dkU w ln Da e w m o w dx m; r dy go v m; / MD5 hash algorithm u EBX? EBP? ESI e JU
EDI w dkUu dkvariable t jz p fx m; jy D; hash w e fz dk; w Gu fc su fr , fhy Hky g/
y Hk( 2 8 ) & JU a t mu fq Hk; e m; u dkscroll q GJjy D; Mu n fhc sde fr Sma w mhy Hk( 2 9 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 2 9 )
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 339 -

y Hk( 2 9 ) u MD5 algorithm & JUt q Hk; u dk Mu n fhv dku fc sde fr Sma w mh EAX u dkr la o x m; jy D; w Gu fc su fv dkU& v m
w Jh w e fz dk; a w Gu dk DS:[ESI] r Smv mx m; r , fhy Hky g/ ' Da e & mr Sm ESI & JUw e fz dk; u 12BAB0 jz p fw Jht w Gu f EAX
r Sm& Sdw Jhw e fz dk; u dk DS:[12BAB0] r Smv mo dr f; r Smy g/ y Hk( 3 0 ) /

y Hk( 3 0 )
y Hk( 2 9 ) u u k' fu dk& Si f; v i f; & r , fq dk& i fa w mha t mu fy gt w dki f; jz p fy gw , f _ _ _
EAX = ECX = EE5B36A2;
EBX = DS:[ESI+4] = DS:[12BAB4] = EFCDAB89;
EAX = EAX << 15 = D4400000;
ECX = ECX >> 0xB = 001DCB66;
EAX = EAX | ECX = D45DCB66;
EAX = EAX + EBX = C42B76EF;
EAX = EAX + EDI = 807A79F8;
' Dha e mu fr Sma w mh EAX & JUw e fz dk; 807A79F8 u dk DS:[ESI+4] = DS:[12BAB4] q D u l; x n fhr Sm
jz p fy gw , f/ Endian e JUp Dw m t r Sw f& y g/ y Hk( 3 1 ) /

y Hk( 3 1 )
u se fw Jhu k' fa w Gu dk w p fa Mu mi f; c si f; v dku fv Hp p fa q ; r , fq dk& i fa w mh a e mu fq Hk; r Sm a w GU& r Smu a w mh y Hk( 3 2 )
t w dki f; jz p fy gw , f/

y Hk( 3 2 )
' gu a w mh12BAB0 r Sm initialize v ky fv dku fw Jh01234567 89ABCDEF FEDCBA98 76543210 u dk
MD5 algorithm e JUw Gu fc su fv dkU& v mw Jh5D9BEC3D F8797A80 07E00955 4A973B68 t a jz y g/
6 . 1 . 3 / y Hk( 2 3 ) u CALL UILib71.0035F130 a e & mu dka & G; jy D; Enter key u dkE Sdy fy g/ y Hk( 3 3 ) t w dki f; routine
& JUt p u dkjr i fy gr , f/

y Hk( 3 3 )
y Hk( 3 3 ) & JU a t mu fq Hk; e m; u dkscroll q GJjy D; Mu n fhc sde fr Sma w mhy Hk( 3 4 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 3 4 )
6 . 1 . 3 . 1 / CALL UILib71.0035F070 [ m MD5 hash algorithm u dka c : o Hk; w Jh CALL jz p fw , fq dkw m
o i fo dr Smy g/ y Hk( 3 4 ) & JU VA 0035F197 u CALL UILib71.0035F070 u a w mh MD5 hash algorithm u dk
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 340 -

a c : o Hk; jc i f; r & Sdy gb l; / ' ga y r , fh VA 0035F1A4 u CALL UILib71.0035F070 u a w mh MD5 hash
algorithm u dka c : o Hk; y gw , f/
6 . 1 . 3 . 1 . 1 / y Hk( 3 4 ) u CALL UILib71.0035F070 a e & mu dka & G; jy D; Enter key u dkE Sdy fy g/ ' gq dk y Hk( 2 6 ? 2 7 ? 2 8 ?
2 9 ? 3 0 ? 3 1 ? 3 2 ) r Sm a w GYc Jh& w Jht w dki f; Mu HK& r Smjz p fy gw , f/
12BAB0 r Sm c ke u w Gu fv dku fw Jh 5D9BEC3D F8797A80 07E00955 4A973B68 u dk MD5 hash
algorithm e JU x y fr Hw Gu fc su fw Jht c gr Sma w mh AB6801EF DD311D00 C7A5A08B 983315D0 t a jz y g/
y Hk( 3 5 ) /

y Hk( 3 5 )
7 / y Hk( 3 6 ) u CALL UILib71.0035E730 u dkv ky fa q mi fjy D; c sde fr Sma w mh AB6801EF DD311D00 C7A5A08B
983315D0 w e fz dk; u dk& v my gw , f/

y Hk( 3 6 )
8 / ' Dha e mu fr Sma w mh CALL UILib71.0035E670 u dkv ky fa q mi fy gw , f/ ' D CALL u a w mh u Re fa w mfw dkU
& & Sdv mw Jhhash w e fz dk; u dkstack a y : u l; w i fy gw , f/ y Hk( 3 7 ) /

y Hk( 3 7 )
a & SUw a v Qmu fr Sma w mhstack window u dko m t " du Mu n fho Gm; y g/ Stack window r Sm license code e JU
y w fo u fw Jhjy D; jy n fhp Hkw Jht c su ft v u fa w Ga y ; E dki fv dkUy g/
9 / y Hk( 3 6 ) r Sm F8 E Sdy fjy D; q u fp p fv mc sde fr Sma w mhy Hk( 3 8 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 3 8 )
y Hk( 3 8 ) r Sma w mh hash w e fz dk; u dk 4 v Hk; p Dw GJjy D; c GJx kw fa y ; r Smy g/ ' D loop u dkv ky fa q mi fjy D; c sde fr Sma w mh
u Re fa w mfw dkU& JU license code [ m ab6801efdd311d00c7a5a08b983315d0 t p m; a60e-d310-caa8-931d
jz p fv mr Smy g/ y Hk( 3 9 ) /

y Hk( 3 9 )
License code u dkMu n fh& i f y & dk* & r fu w p fv Hk; a u smf , lo Gm; w ma w GU& r Smy g/
9 / y Hk( 3 8 ) r Sm F8 E Sdy fjy D; q u fp p fv mc sde fr Sma w mhy Hk( 4 0 ) t w dki f; jr i f& r Smjz p fy gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 341 -


y Hk( 4 0 )
y Hk( 4 0 ) u CALL MFC71.4085 [ m MSVCR71.dll z dki f& JU _mbsupr() API u dko Hk; jy D; a60e-d310-
caa8-931d- u dkA60E-D310-CAA8-931D- t jz p f a jy mi f; v Ja y ; v dku fy gw , f/
1 0 / y Hk( 4 1 ) u CALL MFC71.1916 u a w mhMSVCR71.dll z dki f& JU memmove() API u dko Hk; jy D; A60ED310-
CAA8-931D- u a e hyphen u dk z , f& Sm; v dku fjy D; A60E-D310-CAA8-931D t jz p f a jy mi f; v Ja y ; v dku f
y gw , f/

y Hk( 4 1 )
1 1 / y Hk( 4 2 ) u CALL MFC71.876 u a w mhDS:[ECX] = DS:[12BB34] r Smo dr f; x m; w JhMyanmarCracking
Team- p mo m; u dk EAX x Jjy e fu l; y gw , f/

y Hk( 4 2 )
1 2 / y Hk( 4 2 ) u CALL MFC71.3850 u a w mh memmove() API e JU memcpy() API w dkUu dkt o Hk; jy Kjy D;
MyanmarCrackingTeam- e JU A60E-D310-CAA8-931D w dkUu dkt w la e & mc sx m; y gw , f/

y Hk( 4 3 )
' gu dkstack window r Sm Mu n fhv dku fr , fq dk& i fa w mhy Hk( 4 4 ) t w dki f; a w GU& r Smjz p fy gw , f/

y Hk( 4 4 )
' Da v mu fq dk& i fa w mh y & dk* & r ft v ky fv ky fy Hk & Si f; a v mu fjy Dv dkU x i fy gw , f/ MyanmarCrackingTeam-
A60E-D310-CAA8-931D e JU MyanmarCrackingTeam-1234-5678-9012-3456 u dk E dIi f; , SOfjy D; r n Dc Jh& i f
BadBoy Message u dkjy r Smjz p fy gw , f/
Xilisoft application a w Ge JUy w fo u fjy D; r Sw fc su fjy K& r , fq dk& i fa w mh. . .
1 / Xilisoft application a w G[ m serial r Se f^ r r Se fp p fa q ; z dkU MD5 u dkt o Hk; jy Ky gw , f/
2 / Serial a w G[ m 3 9 v Hk; w dw d& Sd& y gr , f/ ( Oy r m - MyanmarCrackingTeam-1234-5678-9012-3456)
3 / Serial & JU y x r w p f0 u f[ m Mu dKu f& mp mv Hk; jz p fE dki fy gw , f/ ( Oy r m - MyanmarCrackingTeam-? 1234-
5678-9012-3456-? AB124BCDE-7890-00002? Dead-beef-Cafe-Babe-)
4 / Serial & JU ' kw d, w p f0 u fu dka w mhhash w e fz dk; w Gu fc su f& mr Sm t o Hk; jy Ky gw , f/ ( Oy r m - 1234-5678-9012
-3456)
5 / Serial & JU y x r w p f0 u fu dk hash v ky fz dkU Mu dKw i fo w fr Sw fx m; w Jh string E Sp fc k& JUt v , fr Sm x m; y gw , f/
( Oy r m - 1adoov.re.uicne.t.r00MYANMARCRACKINGTEAM-audioconverte)
6 / & & Sdv mw Jhhash w e fz dk; u dk p mv Hk; a o ; t jz p fa jy mi f; y gw , f/ ( Oy r m - ab6801efdd311d00c7a5a08b983315
d0)
7 / Hash w e fz dk; x Ju r * P e f; a w Gu dk, ljy D; 4 v Hk; p Dw GJy gw , f/ ( Oy r m - a60e-d310-caa8-931d) jy D; a w mhp mv Hk;
t Mu D; a jy mi f; y gw , f/ ( Oy r m - A60E-D310-CAA8-931D)
8 / w GJv dkU& w Jhw e fz dk; a w Gu dk y x r w p f0 u fe JU jy e fa y gi f; y gw , f/ ( Oy r m - MyanmarCrackingTeam-A60ED31
0-CAA8-931D)
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 342 -

' Dw p fc gr Sma w mh Xilisoft Audio Converter t w Gu f key v Sv Sa v ; a w Gu dk keygen r a & ; o m; b J
y & dk* & r fu t v dkt a v smu f b , fv dkx kw fa y ; r v Jq dkw m Mu n fhMu & a t mi f/

y Hk( 4 5 )
y Hk( 4 5 ) r Smjr i f& w JhVA 00358769 a e & mw p fc kw n f; u dk breakpoint o w fr Sw fjy D; y & dk* & r fu dk run v dku fy g/
jy D; & i f register v ky fMu n fhy g/ y Hk( 4 6 ) / u Re fa w mfa & SUy dki f; r Sm a q G; a E G; c Jho v dky J key & JU a & SUy dki f; 1 9 v Hk; ^ 2 0 v Hk; u dk
Mu dKu fE Sp fo u fo v dka jy mi f; v Ja y ; v dkU& y gw , f/

y Hk( 4 6 )
y Hk( 4 6 ) t w dki f; register v ky fv dku f& i fa w mh Xilisoft u key u dk t v dkt a v smu f x kw fa y ; r Smjz p fy gw , f/
y Hk( 4 7 ) /

y Hk( 4 7 )
y Hk( 4 7 ) r Smjr i f& w Jht w dki f; Xilisoft u stack window r Sm license code jz p fw Jh Myo Myint Htike----
>65A3-6021-4C6D-A6C5 u dkx kw fa y ; v dku fy gw , f/
License code r Se fr Se fo d& a t mi f Myo Myint Htike---->65A3-6021-4C6D-A6C5 u dk register
v ky fMu n fhy gr , f/ y Hk( 4 8 ) /

y Hk( 4 8 )
y Hk( 4 8 ) r SOK button u dkE Sdy fv dku f& i fa w mhRegistered successfully! q dkw Jhp mw e f; a y : v mr Smjz p fy gw , f/
( 1 0 ) Exe Password 2004 jz i fhprotect v ky fx m; a o m password t m; jy e fa z mfjc i f;
' Dw p fc gr Sma w mh ]Patch v ky fjc i f; } o i fc e f; p mu ]Beginner t q i fh patch v ky fjc i f; } t c e f; r Sm protect
v ky fc Jhw Jhpassword u dkjy e fa z mfMu n fhy gr , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 343 -

' Dw p fc gr Sma w mh t a jy mi f; t v Ja v ; jz p fa t mi f calc.exe u dk protect r v ky fb J notepad.exe u dko m
protect v ky fMu n fhy gr , f/ y Hk( 4 9 ) /

y Hk( 4 9 )
y Hk( 4 9 ) r Smjr i f& w Jht w dki f; notepad.exe u dkrhythm q dkw Jhpassword a y ; jy D; protect v ky fv dku fy gr , f/
Password a y ; x m; w Jhy & dk* & r fu dk Olly r Smz Gi fhjy D; run (F9) v dku fy gr , f/ y Hk( 5 0 ) /

y Hk( 5 0 )
y Hk( 5 0 ) & JU password a e & mr Sm 123456 v dkU& dku fx n fhjy D; OK u dkE Sdy fv dku f& i f y Hk( 5 1 ) t w dki f; BadBoy
message u dkjr i f& r Smjz p fy gw , f/
y Hk( 5 1 )
y Hkr Se ft & q dk& i fa w mh' Dmessage box a y : w Jht c gr Sm F12 u dkE Sdy fjy D; Olly u dk c P & y fc dki f; & r Smjz p fy gw , f/
b ma Mu mi fh ' De n f; v r f; u dk r o Hk; o v Jq dk& i fa w mh u Re fa w mfw dkU& JU y & dk* & r fu dk Delphi e JU protect v ky fx m; v dkUy g/
' ga Mu mi fh"Password is incorrect." q dkw Jhp mo m; u dk& dk; & dk; w e f; w e f; Search u a e y J& Smr Smjz p fy gw , f/

y Hk( 5 2 )
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 344 -

"Password is incorrect." u dk& Sma w GUw Jht c g y Hk( 5 2 ) r Smjr i f& w Jht w dki f; breakpoint o w fr Sw fy g/
a e mu fx y f breakpoint o w fr Sw fz dkU v dkw mu a w mhVA 0054C86E r Smy g/ jy D; & i f y & dk* & r fu dkOlly r Smjy e fz Gi fhy g/

y Hk( 5 3 )
y & dk* & r fu dk Olly r Smjy e fz Gi fhjy D; password a w mi f; w Jht c g abcdef v dkU& dku fx n fhv dku f& i f y Hk( 5 3 ) t w dki f;
breakpoint & Sd& mu dk w e f; a & mu fv mr Smy g/ ' Dt c g register window u dkMu n fhv dku fy g/ y Hk( 5 4 ) /

y Hk( 5 4 )
u Re fa w mfw dkU breakpoint o w fr Sw fx m; w Jh VA 0054C86E u dkr a & mu fc i fr Sm CALL 005532AC
u dkv ky fa q mi fc Jhy gw , f/ ' DCALL u dkv ky fa q mi fjy D; c sde fr Sm u Re fa w mfw dkU& dku fx n fhv dku fw Jh abcdef u dk RVV]PV
t jz p fa jy mi f; a y ; v dku fy gw , f/ jy D; & i f EAX x Jr Smo dr f; y gw , f/ a e mu fw p fc ku a w mh y & dk* & r f& JU data segment
x Ju w e fz dk; w p fc ku dk x kw f, ljy D; EDX x Jx n fhw my g/ ' Dx kw f, lv dku fw Jht & mu a w mh u Re fa w mfw dkUv dkc si fw Jh
password y gy J/ y Hk( 5 4 ) u dkMu n fhy g/ EDX x Ja & mu fa e w m[ m A\\LM]] jz p fa e y gw , f/ ' gu dk
o dy fr o u Fmy gb l; /
b ma Mu mi fhv Jq dka w mh u Re fa w mfw dkUa y ; x m; c Jhw Jh password jz p fw Jh rhythm [ m 6 v Hk; y J& Sdjy D; t c k
7 v Hk; jz p fa e v dkUy g/ ' ga Mu mi fhdump window r SmMu n fhv dku fMu & a t mi f/ y Hk( 5 5 ) /

y Hk( 5 5 )
Dump window u dka o c smMu n fhv dku fa w mhr S & Si f; o Gm; y gw , f/ w u , fo dr f; x m; w mu A\LM]] y g/
Debugger u escape sequence a w Ge JUa & ma x G; r Sm p dk; & dr fw Jht w Gu f slash (\) w p fc kx y fw kd; a y ; v dku fjc i f;
jz p fy gw , f/ u Re fa w mfw dkUv ky f& r Smu a w mh A\LM]] u dk encrypt r v ky fc i fu & Sdc Jhw Jh r lv password u dk jy e f& & Sd
E dki fz dkUy g/ ' gr So m patch r v ky fb J password u dkjy e fa z mfE dki fr Smy g/ ' ga Mu mi fh password u dk encrypt v ky fa y ; w Jh
routine & Sd& m VA 0054C860 r Sm breakpoint o w fr Sw fjy D; y & dk* & r fu dk jy e fp v dku fy g/ y & dk* & r fu dk Olly r Sm run
jy D; password dialogbox r Sm abcdef u dk& dku fv dku f& i f y Hk( 5 6 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 5 6 )
Register window u dkMu n fhr , fq dk& i fa w mhy Hk( 5 7 ) t w dki f; jr i f& r Smjz p fy gw , f/
y Hk( 5 7 )
abcdef u u Re fa w mfw dkU & dku fx n fhv dku fw Jh password jz p fjy D; ? 3459501211xSSSFDb u a w mh
password u dk encrypt v ky f& mr Smt o Hk; jy Kr , fh hash w e fz dk; jz p fy gw , f/ CALL 005532AC & Sd& ma & mu fw Jht c g
F7 u dkE Sdy fjy D; CALL x Ju dk0 i fMu n fhy gr , f/ y Hk( 5 8 ) /
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 345 -


y Hk( 5 8 )
y Hk( 5 8 ) u dka w mhp dw fr 0 i fp m; y gb l; / ' ga Mu mi fha t mu fu dkscroll e n f; e n f; q GJjy D; Mu n fhv dku fy g/

y Hk( 5 9 )
[LOCAL.1] q dkw mu a w mh abcdef u dk q dkv dkjc i f; jz p fy gw , f/ [LOCAL.2] q dkw mu a w mh 34595012
11xSSSFDb u dkq dkv dkjc i f; jz p fy gw , f/ y & dk* & r f& JU t Mu r f; z si f; t v ky fv ky fy Hku a w mh-
1 / MOV EDX, [LOCAL.1]
EDX x Jr Sm abcdef u dkx m; y gw , f/
2 / MOV DL, BYTE PTR DS:[EDX+ESI-1]
' Dt c sde fr Sm ESI & JUw e fz dk; [ m 1 jz p fw Jht w Gu f *EDX=EDX[0] x Ju y x r p mv Hk; u dk DL x J u l; y dkUy g
w , f/ ' ga Mu mi fhDL x Jr Sm a a & mu fv my gw , f/
3 / MOV ECX, [LOCAL.2]
ECX x Jr Sm 3459501211xSSSFDb u dkx m; y gw , f/
4 / MOV CL, BYTE PTR DS:[ECX+EBX-1]
' Dt c sde fr Sm EBX & JUw e fz dk; [ m 1 jz p fw Jht w Gu f *ECX=ECX[0] x Ju y x r p mv Hk; u dk CL x J u l; y dkUy g
w , f/ ' ga Mu mi fhCL x Jr Sm 3 a & mu fv my gw , f/
5 / XOR DL, CL; DL = DL ^ CL = a ^ 3 = R
DL x Jr Sm& Sdw Jh a e JU CL x Jr Sm& Sdw Jh 3 w dkUu dk XOR v ky fy gw , f/ & v ' f R u dka w mh DL x Jr Sm
o dr f; y gw , f/
6 / MOV BYTE PTR DS:[EAX+ESI-1], DL
DL x Jr Smo dr f; x m; w Jh R u dk *EAX= EAX[0] x Ja & TYy gw , f/ ' ga Mu mi fh EAX r Sm Rbcdef jz p fv my g
w , f/ Rbcdef w e fz dk; u dkdata segment u B858E0 r Smo dr f; w mjz p fy gw , f/
7 / INC EBX
ECX x Jr Sm& Sdw Jha e mu fx y fp mv Hk; a w Gu dk z w fE dki fz dkUt w Gu f EBX w e fz dk; u dkw p fa y gi f; y gw , f/
8 / INC ESI
EDX x Jr Sm& Sdw Jha e mu fx y fp mv Hk; a w Gu dk z w fE dki fz dkUt w Gu f ESI w e fz dk; u dkw p fa y gi f; y gw , f/
- ' Dv dke JU w p fv Hk; c si f; u dkv ky fy gw , f/
XOR DL, CL; DL = DL ^ CL = b ^ 4= V
XOR DL, CL; DL = DL ^ CL = c ^ 5= V
XOR DL, CL; DL = DL ^ CL = d ^ 9= ]
XOR DL, CL; DL = DL ^ CL = e ^ 5= P
XOR DL, CL; DL = DL ^ CL = f ^ 0= V
- t m; v Hk; u dk XOR v ky fjy D; c sde fr Sma w mh DWORD PTR SS:[EBP-4] = [LOCAL.1] x Jr Sm ' D& v ' fu dk
o dr f; q n f; y gw , f/
t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 346 -

' gu a w mhencryption v ky fw Jhv ky fi e f; p Ofy g/ ' gq dk password u dk decrypt v ky fa y ; r , fhy & dk* & r fu dk C e JU
a & ; Mu n fhMu & a t mi f/
#include<stdio.h> // Copyright Myo Myint Htike, September 20 2009
#include<conio.h> // Compiler - Borland C++ 5.02
#include<string.h> // C Console Application
int main()
{
int index = 0;
char encrypted_password[30] = {0};
char decrypted_password[30] = {0};
char hash_value[20] = "3459501211xSSSFDb345";
scanf("%s", encrypted_password);
while(index < strlen(encrypted_password)){
decrypted_password[index] = encrypted_password[index] ^ hash_value[index];
index++;
}
printf("Serial is = %s", &decrypted_password[0]);
getch();
return 0;
}
y Hk( 6 0 )
y Hk( 6 0 ) u u k' fu dkBorland C++ compiler r Sm run v ky fv dku f& i fa w mhy Hk( 6 1 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 6 1 )
u Re fa w mfw dkU decrypt v ky fc si fw Jh password u dk& dku fx n hfv dku fw Jht c gr Sm r lv password u dky & dk* & r fu
jy e fx kw fa y ; r Smjz p fy gw , f/
w u , fv dkU password a y ; x m; w Jhz dki fr Sm y Hk( 6 2 ) t w dki f; breakpoint a e & mu dka & mu fv dkU register window
r Sm encrypt v ky fc H& w Jhpassword a w Gu dkr jr i f& b l; q dk& i f. . . .

y Hk( 6 2 )
' gq dk& i fa w mho i f& dku fx n fhv dku fw Jhpassword u dkencrypt v ky fx m; w Jha e & mu dk& Smz dkU y Hk( 6 3 ) u dkMu n fhy g/

y Hk( 6 3 )
y Hk( 6 3 ) u VA 0054C865 u dkE Sdy f& i f Olly pane window r Sm Stack SS:[0012F668] = 0118F48
v dkUa y : v my gv dr fhr , f/ ' Da e & mr Sm right-click E Sdy fjy D; Follow value in Dump u dka & G; v dku f& i f dump window
r Sm encrypt v ky fx m; w Jh password u dkjr i f& r Smjz p fy gw , f/ ' ga y r , fh ' D password [ m u Re fa w mfw dkUt w Gu f
t a & ; r y gw Jht w Gu f v sp fv sL& Ix m; v dkU& y gw , f/
w u , fhpassword u dkencrypt v ky fx m; w Jha e & mu dk& Smz dkU y Hk( 6 4 ) u dkMu n fhy g/

t c e f; ( 2 2 ) - Crypto u k' fr sm; u dka v hv mjc i f;
- 347 -


y Hk( 6 4 )
y Hk( 6 4 ) u VA 0054C868 u dkE Sdy f& i f Olly pane window r Sm DS:[005677BC] = 00FA7774
v dkUa y : v my gv dr fhr , f/ ' Da e & mr Sm right-click E Sdy fjy D; Follow value in Dump u dka & G; v dku f& i f dump window
r Sm encrypt v ky fx m; w Jhpassword u dkjr i f& r Smjz p fy gw , f/ Encrypt v ky fx m; w Jhpassword u a w mhjz p fy gw , f/
' gu dkC e JUa & ; x m; w Jhy & dk* & r fu dko Hk; jy D; password u dkjy e fa z mfr , fq dk& i fa w mhy Hk( 6 5 ) t w dki f; jr i f& r Smy g/

y Hk( 6 5 )
EXE Password 2004 r Sm password u dk t v Hk; 2 0 x u fy dka y ; v dkUr & y gb l; / ' ga Mu mi fh password u dk
a y ; w ke f; u Myanmar Cracking Tea v dkUa y ; c Jhw mjz p fy gw , f/ Encrypt v ky fx m; w Jh password u dk& dku fx n fh
w Jht c gr Sm a w GU& w Jh ^R (Device Control 2) e JU ^Y (End of Medium) w dkUu dk & dku fx n hfc si f& i f Ctrl key e JU
w GJE Sdy f& r Smjz p fy gw , f/
w u , fv dkU o i fa y ; x m; w Jh password [ m * P e f; a w Gy Jjz p fr , fq dk& i f keyboard u a e & dku fx n fh& w m
c u fc Jr Smjz p fy gw , f/

y Hk( 6 6 )
y Hk( 6 6 ) u encrypt v ky fx m; w Jh password u dk decrypt jy e fv ky fr , fq dk& i f c ke u u Re fa w mfw dkUa & ; c Jhw Jh
keygen u dk t o Hk; jy Kv dkU& a w mhr Smr [ kw fy gb l; / b ma Mu mi fhv Jq dka w mh 0D [ m return keystroke e JU w ln Da e w m
jz p fw Jht w Gu f ^B^F^F (020606) w dkUu dk& dku fx n hfjy D; ^M (0D) u dk& dku fx n hfc sde fr Sm y & dk* & r fu password u dk
& dku fx n fhjy D; jy Dv dkU, lq jy D; t a jz x kw fa y ; v dkUy g/ ' Dt w Gu f y & dk* & r fu dkjy i fa & ; & y gr , f/
#include<stdio.h> // Copyright Myo Myint Htike, September 20 2009
#include<conio.h> // Compiler - Borland C++ 5.02
int main()
{
int index = 0;
int encrypted_password[7] = {2, 6, 6, 0xD, 0, 6, 6};
char decrypted_password[30] = {0};
char hash_value[20] = "3459501211xSSSFDb345";
while(index < 7) {
decrypted_password[index] = encrypted_password[index] ^ hash_value[index];
index++;
}
printf("Serial is = %s", &decrypted_password[0]);
getch();
return 0;
}
y Hk( 6 7 )
y Hk( 6 7 ) u u k' fu dkrun v dku f& i fa w mhy Hk( 6 8 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 6 8 )
., Polymorphic - ...- . ._ .
.

tcef;(23) - Polymorphic uk'frsm;udk avhvmjcif;
-. . ..-. cracker .- ..._....... polymorphic -.-._-..- ...._..
-. -. ....-.-.-. -.. pack/protect .._. .-. Assembly
.- .- .. .......-._.. - - - PEiD ... .-. - . -. ReverseMe Tutorial.
exe,- .......- -...-.-. Lena151 _.. -. SND Team download section . .
-.- download ..-. .-.._ -. ..-..-.- .._-_-_-..
-.-.--...-. ,-. nag -_.-. "You need to remove the nag.
Try to do ".-.....-.-..

,
,- OK button -.-.-. ,-._...

,
Nag window - .. .. . . . ._ . patch ...-. .-.- nag window - ..
.. .-. ...-.- . ...- ...
-.- patch .. Olly .. ._......_-_-_-.. ,

,
_..-. -.-.-.-..- "You need to remove the nag. Try to do " .....-
-._-_

,
,. ._. - - . - .-. - ..- .....- .- -. Double-click .- ,

,
., Polymorphic - ...- . ._ .


,.._.-.-.-. VA 00403134 .......- "You need to remove ..." .....-
MessageBox -. - .. . MessageBox -. - .-. - .. .... nag window _..
-. ._-. MessageBox ... . breakpoint .-.-_. -.- run (F9) _-_-_-
..

,
-.- F9 ._. run _-_-...-. -.-.- .-.-..- breakpoint ... .
-.-.- ,- nag window - _. .-.
.-. .-. .. ..-. . nag window - -. -...-.. ._.. - .
.. -. - Olly . ._ . _-_ - _-.. (Ctrl+F2) . ,-. _...

,
,- ..._-_ VA 0040128A -. VA 00401290 -. - .- ... .-..- _..
.-. F8 -._. -._....-. .-_-_ .,

.,
Olly - VA 0040128F ....-.-. .,-. breakpoint .- . - ... ...-.
Yes button -.._. F8 - .- . Olly ..- - scroll _._.._._-_....-.
,-. _.-.

,
., Polymorphic - ...- . ._ .


,- .. ..-. -.- . ..- - . ._-. . . mnemonics .--_.
.. Olly analysis -_.-- ,
INFO: : Olly - - .- - .-.. _. .-. .- .-. .. ... .,

,
,-. Remove analysis from module -.._. analysis -.-_.--.-.
,-. _...

,
_-_-.-.-. _.__...- junkcode .-_..-. Olly - - unknown
command _.-. Olly - -.-.-- ...._....-. .-.._ analysis - .-.
. -.-.-... ._-. auto-analysis - ..--. _.-- ,

,
,-. auto-analysis -_.-_..-. Olly .. -.- _.-

,
., Polymorphic - ...- . ._ .


Ctrl+F2 (Restart) ._. -.- _._-_-.-. EP ...- ,- ._.
. . -. . ..-. analysis - . ...-.- .. _ ._ ....._ .-. F9 - . _ .
-.- run _-_.. ,- breakpoint .- . - ..- ... . -. - -.._-. . .
. - ._-. . ._..
._.-.-. .-. .-.--. diversion -.-_... ..-. cracker .- -
- .- ... _ .... - .- - _ .._ ._.. -. . .-. - .- -. . .. - .
- .- - -. .-. . .. . ._. ..- - - . ._-. breakpoint .- . - ..- ...- -
..- ..-. . . . _. -.- . _-_ ..
INFO: : MessageBoxA -... -... _.. ...._- . -. .._ commandbar
plug-in -.._. MessageBoxA .. breakpoint .-.- _. breakpoint .-..-... F9
-. ..-...-. Alt+ F9 -._. user -...-..-. , ..--
Call Stack (Ctrl+K) -. MessageBoxA ...- ._. . -. ,

,
,-. nag window .-..... .....-. -.-.-. -.--
-.._-.......... ,-__-_

,
, EP ..-. F8 -._. -.-- .._-_.. Breakpoint .-- ..-.-
-- ....- VA 0040128A - GetModuleHandle ._-..-.._-_..
The GetModuleHandle function returns a module handle for the specified module if the file has been
mapped into the address space of the calling process.
HMODULE GetModuleHandle(
LPCTSTR lpModuleName // address of module name to return handle for
);
Parameters
lpModuleName
Points to a null-terminated string that names a Win32 module (either a .DLL or .EXE file). If the filename
extension is omitted, the default library extension .DLL is appended. The filename string can include a trailing point
character (.) to indicate that the module name has no extension. The string does not have to specify a path. The name
is compared (case independently) to the names of modules currently mapped into the address space of the calling
process.
If this parameter is NULL, GetModuleHandle returns a handle of the file used to create the calling process.
Return Values
If the function succeeds, the return value is a handle to the specified module.
If the function fails, the return value is NULL. To get extended error information, call GetLastError.
function . . return -..-.-. EAX ..- imagebase -.._.... ,

,
MOV EDI, 00401011; // EDI .. VA 00401011 -..-. .-.-.-. -.- _.
.-. _.. ..- -. ..- .- _-_ ,
., Polymorphic - ...- . ._ .


CALL 0040130F; // -.-. .-......-..-. F7 - . _ . CALL _-_ ,

,
,. ._. - - . - section VA .- EAX . ...-. .- .._ ._-_ .. .
.-. GetModuleHandle - cracker .-- .- diversion - _.. .-..- -.

.,
..-...-. EAX -..-- 401000 . . - data segment --.. E2' -, 5A
XOR -. EAX -..- -...-. _..-. EAX -..- jmp.&user32.
BeginPaint ...-. ,

,
,.._.--. EAX ...-.-.-. 401218 _.. -. ,

,
--. - EAX -.. (401001) jmp.&user32. BeginPaint -.- EAX - . .
(401218) --...... -..-..... VA 00401314 - XOR BYTE PTR DS:[EAX],
5A; ...-..._. XOR .. ._.. -. ,- Assemble button -..-
EAX - 401218 -.._-. . .. . . -. _ ._ ._-_ - _-.. ,

,
., Polymorphic - ...- . ._ .


--. .-. VA 00401000 -. VA 00401218 code section - opcode .-- 5A
XOR -.- decrypt -. .-. -.._-. . .-. - . - - encrypt ..

INFO: : Encryption/Decryption . -.-.-. .- .- - .- - --.-.. ...
..-_...-._.-. Encryption - _ ... .- . .- . . . ._... - -
.- . .. - - . .. .... . _.._ ._. .- .- . Encryption ., ....
- obfuscation -.-. cracker .- - -.- . . . . .__--.
INFO: : XOR instruction -.-. encrypt/decrypt - command -._.._. ._-...
.....-. -.._-...-. .-.-....__. decrypt . ..-...-
- . .- - _ - - .-. XOR _ ._. .. .- . .- _ . -. XOR instruction -
encryption - . . . ._ .-. . - encrypting XOR '., enxor .....-.
XOR - . .__ . -. -. ..-. .... Olly dump window
- 401000 ..-_-_-_-.. ,

,
Loop - ....--_....-. ,- ._. -. Dump window . ._. -.-
.-. code section . . opcode .- -..-- decrypt .-..-. F8 . _ . .- _-_
. ,

,
,.._.--. decrypt ..- - .- .. _.. ._. .- -. .- .. ,
- RETN . . breakpoint .- . - _ . F9 (Run) -.- ,-._...
,
., Polymorphic - ...- . ._ .


,- _-_ - code section VA 401218 ,.. decrypt _ .. ..-..- ..
RETN . ..- . - ..- breakpoint -__.-_. .- scroll .- ,-._...

,
,- .- .- junk - .- ... .- - mnemonics .- _.. ._. .- -. .- . .

INFO: : ... . - .- -. -.._-. .. ._.... .-.-.-. ,- --.-
assemble . ._-. Olly - -.-- ._....-._. ._...--.--
..-._..-._..-. ....._..-. -.-._...-...-. ._.....-
- - - .. .._-. - .-. .- .... -. --. ._. . . ..- - .- -
_- - - .. _.. ,-. __-.

,
INFO: : Code section -. ... .._. .-. .. .- . Code section . . .. -. . .-.
PE tool (LordPE, WPE, PE Tools .._ _. ) .- - . .__ . code section characteristics -
_ -.
' Dw p fc gr Sma w mha e mu fx y fp dw f0 i fp m; p & ma u mi f; w JhCALL w p fc ku dk a v hv mMu n fhy gr , f/

y Hk( 2 7 )
y Hk( 2 7 ) r Smjr i f& w JhCALL u dk a v hv mE dki fz dkU F7 (Step into) u dkE Sdy fv dku fy g/ y Hk( 2 8 ) t w dki f; jr i f& y gr , f/
., Polymorphic - ...- . ._ .



y Hk( 2 8 )
y Hk( 2 8 ) r Smjr i f& w mu a w mh decrypt function u dkv ky fa q mi ft jy D; jz p fy gw , f/ w u , fa w mh y & dk* & r fu
decrypt v ky fx m; w Jhu k' fa w Gu dkz w fjy D; nag window u dkjy o z dkUMu dK; p m; a e w mjz p fy gw , f/ u k' fa w Gu dk a o c sm
Mu n fhr , fq dk& i fa w mh MOV instruction a w mfa w mfr sm; r sm; u dk a w GUr Smjz p fy gw , f/ o lw dkUa w G[ m EDI register
e JUy w fo u fa e w mu dkv Jjr i f& r Smy g/ ' ga Mu mi fh EDI x Jr Sm VA 401011 u dkx m; w m[ m w p fc kc kv ky fz dkU jy i fq i fa e
w mjz p fa Mu mi f; a & SUy dki f; r Sm a jy mc Jhw my g/ ' Da e & mr Sm u dk, fw dki fjy e fjy i fE dki fw Jhu k' fa w Gt a Mu mi f; u dk a v hv mMu n fh
y gr , f/
INFO: : Self-modifying code q dkw mu a w mh & n f& G, fc su fw p fc kc ke JU u dk, fhu k' fu dk u dk, fw dki fjy e fjy i fw my g/
u Ge fy sLw ma c w fOD; y dki f; r Sma w mh ' Dv dku k' fa w Gu dk t u e fUt o w f& Sdw Jh r Sw fOmP fa e & mu dk a c Rw mE dki fz dkU t o Hk; jy Kc JhMu
w my g/ Instruction set a w G[ m o mr e f branch c GJw ma v mu fy J v ky fa q mi fE dki fc sde fr Sm ( o dkU) v ky fa q mi fc su fa w G
u dk a jy mi f; v Jv ky fa q mi fE dki fz dkU instruction a w Gu dk a u smfv Tm; c sde fr Sm sub-routine call a w Ge JU return a w Gu dk
p r f; o y fp p fa q ; E dki fz dkU o lw dkUa w Gu dk t o Hk; jy Kc JhMu w mjz p fy gw , f/
INFO: : Self-modifying code a w Gu dk 1 9 8 0 w ke f; u DOS * dr f; a w Gr Sm copy prtotection instruction
a w Gu dkz Hk; u G, fE dki fz dkU t o Hk; jy Kc Jhw mjz p fy gw , f/ ' ga Mu mi fh Floppy drive u dkz w fw Jh instruction jz p fw Jh INT 13
u dk exe z dki fx Jr Sm & Sma w GUE dki fr Smr [ kw fy gb l; / ' ga y r , fh y & dk* & r f run a e c sde f r Sw fOmP fx Ju image x Jr Sma w mh
& Sda e r Smy g/ ' Da e Ua c w fr Sm self-modifying code a w Gu dkt o Hk; jy Ka e Mu w mu a w mh o lw dkU& Sda e w mu dk r jy o c si fv dkU
b Jjz p fy gw , f/ Oy r mjy & & i fa w mh u Ge fy sLw mA dki f; & y fp fa w Ge JU t c sdKUa o m shell u k' fa w Gjz p fy gw , f/ A dki f; & y fp fa w Ge JU
shell u k' fa w G[ m self-modifying code u dkt o Hk; jy KMu w mjz p fjy D; r sm; a o mt m; jz i fh polymorphic code
a w Ge JUw GJo Hk; Mu w mjz p fy gw , f/ Polymorphic A dki f; & y fp fa w Gu dka w mh w c gw & Hr Sm primitive self-mutator a w G
v dkUa c : y gw , f/ o lw dkU[ m run a e w Jhu k' fw p fp dw fw p fa ' o u dk jy Kjy i fjy D; OS u dk buffer overflow jz p fa p w Jh
attack v ky fr Ia w Gjy Kv ky fy gw , f/
t x u fa z mfjy y gt c su fa w Ga Mu mi fh cracker a w G[ m ' Dv dk obfuscation t r sdK; t p m; a w Gu dk b , fv dku dki f
w G, f& r v Jq dkw m & Si f; & Si f; v i f; v i f; o dx m; z dkUv dkt y fy gw , f/ F8 u dkE Sdy fjy D; b mq u fjz p fr v Jq dkw m Mu n fhv dku fMu
& a t mi f/ y Hk( 2 8 ) u dkjy e fMu n fhy g/
XOR EAX,EAX; // EAX u dk o kn jz p fa t mi f & Si f; v i f; v dku fy gw , f/
MOV WORD PTR DS:[EDI],6A; // 401011 r Sm& Sdw Jh33C0 a e & mr Sm 6A00 e JUt p m; x dk; y gw , f/

y Hk( 2 9 )
' ga Mu mi fh VA 00401011 u XOR EAX, EAX; (33C0) a e & mr Sm PUSH 0; (6A00) jz p fo Gm; w m
a w GU& r Smy g/
ADD EDI,2; // EDI u dk 2 a y gi f; y gw , f/ (0x401013)
MOV WORD PTR DS:[EDI],40307D68; // 40307D68 w e fz dk; u dk VA 0x401013 r Smx m; y gw , f/
y Hk( 3 0 ) /
., Polymorphic - ...- . ._ .



y Hk( 3 0 )
' ga Mu mi fh VA 00401013 u MOV WORD PTR DS:[EDI],40307D68; a e & mr Sm PUSH
0040307D; jz p fo Gm; w ma w GU& r Smy g/

y Hk( 3 1 )
y Hk( 3 1 ) r Smjr i f& w Jh VA 00401052 a & mu fw Jht x d F8 u dkE Sdy fv mc Jhr , fq dk& i f VA 00401011 u VA
0040104B x d[ m y Hk( 3 2 ) t w dki f; a jy mi f; v Jo Gm; w ma w GU& y gw , f/

y Hk( 3 2 )
y Hk( 3 1 ) u CALL EDI [ m w u , fa w mhCALL 00401000 u dkjy e fn Te f; w m a w GU& y gw , f/ y Hk( 3 3 ) /

y Hk( 3 3 )
y Hk( 3 3 ) r Smjr i f& w Jht w dki f; q dk& i fa w mh c ke u z e fw D; c Jhw Jh self-modifying code u dkjy e ft v ky fv ky fa w mhr , f
x i fy gw , f/ ' ga Mu mi fhAnalyze This! plugin u dko Hk; jy D; u k' fu dk analyze v ky fMu n fhv dku fy g/ y Hk( 3 4 ) /

y Hk( 3 4 )
., Polymorphic - ...- . ._ .


y Hk( 3 4 ) u dkMu n fhr , fq dk& i f self-modifying code u MessageBox w p fc ku dkz e fw D; c Jhw m a w GU& y gw , f/
' ga y r , fh Tilte e JU Text u b ma w Ga & ; x m; r Se f; r o dy gb l; / ' ga Mu mi fh F7 u dkE Sdy fjy D; CALL x Ju dk0 i fMu n fhv dku f
Mu & a t mi f/ y Hk( 3 5 ) /

y Hk( 3 5 )
y Hk( 3 5 ) r Smv J enxor w p fc kx y fa w GU& y gw , f/ ' gu dka w mh o i fe m; v n fr , fv dkUx i fy gw , f/ EAX x Ju dk
00403000 w e fz dk; v mx n fhy gw , f/ ' Dt c sde f 403000 & JU data segment r Sm& Sdw mu a w mh E1 q dkw Jhw e fz dk; y g/
y Hk( 3 6 ) /

y Hk( 3 6 )
E1 w e fz dk; u dk B3 e JU XOR v ky fy gr , f/ jy D; & i f EAX (403000) w e fz dk; u dk 1 a y gi f; y gr , f/ EAX
w e fz dk; [ m 403128 jz p fr jz p fp p fy gr , f/ 403128 x u fi , fa o ; & i fa w mh' Dloop u dkq u fv ky fa e OD; r Smjz p fy gw , f/
' ga Mu mi fhdump window u dk Mu n fhz dkUv dkv my gjy D/ y Hk( 3 7 ) /

y Hk( 3 7 )
F8 u dkE Sdy fjy D; u k' fa w Gu dk p p fo Gm; & i f y kH( 3 7 ) t w dki f; XOR v ky fx m; c H& w Jh byte a w Gu dka w GU& r Smy g/ F8
u dkq u fw dku fE Sdy fjy D; loop x Ju x Gu fv dku f& i f y Hk( 3 8 ) t w dki f; jr i f& y gw , f/

y Hk( 3 8 )
y Hk( 3 8 ) u dkMu n fhr , fq dk& i f MessageBoxA t w Gu fv dkt y fw Jh a ' w ma w Gu dk decrypt v ky fjy D; c su fc si f;
MessageBoxA API u dka c : o Hk; w ma w GU& y gw , f/

y Hk( 3 9 )
., Polymorphic - ...- . ._ .
.

VA 0040101F a & mu fw Jht x d F8 u dkE Sdy fv mc Jh& i fa w mh y Hk( 3 9 ) t w dki f; u Re fa w mfw dkUz , f& Sm; & r , fh nag
window u dkjr i f& y gw , f/ MessageBoxA API u dk e n f; e n f; a v mu fa v hv mMu n fh& a t mi f/ a & SUy dki f; r Smv J ' D
API t a Mu mi f; a v hv mjy D; jy Dr dkU ' Da e & mr Sma w mht a & ; Mu D; w Jhargument a v mu fu dky J a v hv my gr , f/
int MessageBox(
HWND hWnd, // handle of owner window
LPCTSTR lpText, // address of text in message box
LPCTSTR lpCaption, // address of title of message box
UINT uType // style of message box
);
Parameters
hWnd
Identifies the owner window of the message box to be created. If this parameter is NULL, the message box
has no owner window.
w u , fv dkUo m u Re fa w mfw dkUt a e e JU hWnd u dk 1 jz p fa t mi fv ky fr , fq dk& i f owner u dk& Sma w GUr Smr [ kw fw Jh
t jy i f messagebox u dkv Jjy E dki fr Smr [ kw fy gb l; / ' ga Mu mi fh VA 40101D u PUSH 0; u dk PUSH 1; v dkUjy i f
v dku f& i f nag window u dkz , f& Sm; jy D; o m; jz p fo Gm; r Smy g/ ( q dkv dkc si fw mu loader z dki fw p fc ku dkz e fw D; jy D;
' Da e & mu dk jy i fv dku f& Hky gy J/ )
' ga y r , fhy & dk* & r fa & ; o m; o l Lena151 u ' Dnag u dk 2 bytes y Jo Hk; jy D; patch v ky fy gv dkU c dki f; c Jhy gw , f/

y Hk( 4 0 )
y Hk( 4 0 ) u dkMu n fhy g/ Nag window u dkv ky fa q mi fjy D; c sde fr Sm y & dk* & r f[ m VA 40106A q Djump v ky fo Gm;
y gw , f/ w u , fv dkUo m nag window r w dki fc i f VA 40106A q Djump v ky fE dki f& i fa u m . . .
q dkv dkw mu y & dk* & r fu VA 401011 u PUSH 0 u dkt v ky fv ky fa p r , fht p m; y Hk( 4 1 ) t w dki f; jy i fv dku f& i f
b mjz p fo Gm; r Smy gv J/

y Hk( 4 1 )
' ga Mu mi fh VA 40106A q Djump v ky fa y ; E dki fr , fh opcode (self-modifying code) jz p fw Jh EB 57
u dkr Sw fo m; x m; y g/
INFO: : w u , fa w mhnag u dkz , f& Sm; w Jht jc m; jz p fE dki fz G, fe n f; v r f; a w G& Sdy ga o ; w , f/ Oy r m VA 401010
u byte u dkt o Hk; jy Kjc i f; /
VA 40106A u dkq u fMu n fhy g/ Self-modifying code a w Gu dk x y fa w GU& y gr , f/ y Hk( 4 2 ) /

y Hk( 4 2 )

., Polymorphic - ...- . ._ .


VA 401075 x d F8 E Sdy fjy D; assemble v ky fc sde fr Sma w mh y Hk( 4 1 ) w ke f; u u Re fa w mfw dkUa jy mi f; c Jhw Jh JMP
a e & mr Sm y Hk( 4 3 ) t w dki f; u k' fa w Ga jy mi f; a e w mjr i f& y gw , f/

y Hk( 4 3 )
a e mu fx y fb ma w Gjz p fa o ; v Jq dkw m q u fMu n fhMu y gr , f/ y Hk( 4 4 ) /

y Hk( 4 4 )
CALL EDI u a w mh self-modifying code & JU t q Hk; jz p fy gw , f/ jy Kjy i fx m; w Jhu k' fu dk c su fc si f;
execute v ky fMu n fhE dki fa t mi fv dkU CALL EDI x Ju dk F7 E Sdy fjy D; 0 i fMu n fhMu & a t mi f/ y Hk( 4 5 ) /

y Hk( 4 5 )
Olly u t o p fa jy mi f; v Jx m; w Jh u k' fa w Gu dk analyze v ky fx m; y Hkr & y gb l; / ? a w Gjy a e y gw , f/
' ga Mu mi fht & i f analyze v ky fv dku fy g/ y Hk( 4 6 ) /

y Hk( 4 6 )
y Hk( 4 6 ) u dkMu n fhv dku f& i f self-modifying code [ m y i fr y & dk* & r ft w Gu f jy i fq i fjy D; y Hk& y gw , f/ b ma w G
jz p fr v Jo dE dki fa t mi fv dkU F8 u dkE Sdy fjy D; p p fMu n fhy g/

y Hk( 4 7 )
., Polymorphic - ...- . ._ .


INFO: : Self-modifying code & JU ' kw d, t p dw ft y dki f; u a w mh u Re fa w mfw dkUu dk b mr St c u fr a w GUa p y gb l; /
' Dt c sde fr Sma w mhu Re fa w mfw dkU[ m nag u dk a u smfv Tm; v mc Jhjy D; y gjy D/
Main window u dky dw fv dku f& i fa w mhy Hk( 4 8 ) t w dki f; jr i f& y gr , f/

y Hk( 4 8 )
y Hk( 4 8 ) u CALL 401320; r Sma w mh p dw f0 i fp m; p & ma u mi f; w ma w Ga w GUE dki fr , fv dkUx i fy gw , f/ F7 u dk
E Sdy fjy D; CALL x J0 i fMu n fhv dku fy g/ y Hk( 4 9 ) /

y Hk( 4 9 )
y Hk( 4 9 ) r Smjr i f& w Jhu k' fa w Gu a w mh y & dk* & r fe JUt w ly gv mw Jh r lv u k' fa w Gjz p fy gw , f/ ' Dv dku k' fa w Gu dk o i fh
t a e e JUjr i fz l; r Smy g/ ' Dw p fc gr Sma w mh 8D e JU XOR v ky fy gw , f/ XOR v ky fr , fha e & mu a w mh VA 403000 & JU
opcode a w G& Sd& ma e & mu a e p r Smy g/ y Hk( 5 0 ) /

y Hk( 5 0 )
VA 403000 u a e VA 403128 x dXOR v ky fjy D; c sde fr Sma w mhy Hk( 5 0 ) [ m y Hk( 5 1 ) t w dki f; jz p fo Gm; y gr , f/

y Hk( 5 1 )
y Hk( 5 1 ) r Smjr i f& w Jht w dki f; ' Dy & dk* & r fu dka & ; o m; w Jh y & dk* & r fr mu u Re fa w mfw dkUu dk t c u fa w GUa t mi fv ky fw m
y g/ a jc & mc H& r , fho u fa o a w Gt m; v Hk; u dk o lr ( Lena151) u z su fq D; v dku fy gw , f/
r Sw fc su f/ / w u , fa w mh ' Dy & kd* & r fu o i fhu dk t a jc c Ht a w G; t a c : & & Hkt w Gu f jy o w mjz p fy gw , f/ v u fa w GYr Sm
a w mh ' Dx u fy dkjy D; & Iy fa x G; w Jhy & dk* & r fa w Ge JU o i fMu HKa w GU& r Smjz p fy gw , f/ u k' fa w Gr sm; jy m; v Sw Jh Mu D; r m; w Jhy & dk* & r f
a w Gx Jr Sm & dk; & Si f; v Sw Jhenxor a w Gt p m; w u , fhu dk& Iy fa x G; v Sw Jhdecryption routine a w Gu dko m a w GU& r Smy g/ ' D
routine a w Gx Jr Sm y dkjy D; & Iy fa x G; v Sw Jhpolymorphic u k' fa w G& Sda e r Smy g/
INFO: : Polymorphic u k' fq dkw mu a w mh r lv algorithm u dk y u w dt w dki f; & Sda e a p a t mi fv ky fa e p Oft w Gi f;
t o Gi fa jy mi f; v Jo Gm; w Jh u k' fu dka jy mw mjz p fy gw , f/ ' De n f; y n mu dk w c gw & Hr Sm u Ge fy sLw mA dki f; & y fp fa w G? shell
u k' fa w Ge JU u Ge fy sLw m worm a w Gu o lw dkU& Sda e w mu dk z Hk; u G, fE dki fz dkUt w Gu f t o Hk; jy KMu w mjz p fy gw , f/ Anti-
virus a q mhz f0 Jv fe JU v Hkjc HKa & ; p e p f a w mfa w mfr sm; r sm; u a w mh u Ge fy sLw mu Ge f, u fw p fa v Qmu f y dkYv Tw fv dku fw Jh
data packet a w Ge JU u Ge fy sLw mz dki fa w Gx Ju a e malicious u k' fa w Gu dk & Smz dkUMu dK; p m; Mu y gw , f/ w u , fv dkUo m
., Polymorphic - ...- . ._ .


v Hkjc HKa & ; a q mhz f0 Jv fa w Gu o lw dkUa w Gx Jr Sm A dki f; & y fp f^ worm a w Ge JUy w fo u fw Jh o dx m; jy D; o m; signature
a w Gu dk& Sma w GUc Jhr , fq dk& i f ' Dthreat a w Gu dk t jy D; w dki f neutralize v ky fz dkUMu dK; p m; r Smjz p fy gw , f/ Polymorphic
algorithm a w Gu a w mh r a w mfr a & mfu k' fa w Gu dk & Sma z Gw Jh ' Dv dka q mhz f0 Jv fa w Gu dk t c u fa w GUa p y gw , f/ b m
a Mu mi fhv Jq dka w mho lU& JUu k' fa w G[ m t q u fr jy w fa jy mi f; v Ja e v dkUy g/
INFO: : Encryption u a w mh polymorphism u dk u k' ft o Gi fe JY & & Sda p E dki fz dkU t r sm; q Hk; t o Hk; jy Kw Jhe n f;
v r f; jz p fy gw , f/ b my Jjz p fjz p f u k' ft m; v Hk; u dka w mh encrypt v ky fy p fv dkUr & y gb l; / b ma Mu mi fhv Jq dka w mh u k' f
t m; v Hk; u dk encrypt v ky fv dku f& i f t o Hk; jy Kv dkU& a w mhr Sm r [ kw fv dkUy g/ y & dk* & r f& JU t y dki f; i , fw p fc ku dka w mh
encrypt r v ky fb Jx m; & r Smjz p fjy D; encrypt v ky fx m; w Jha q mhz f0 Jv f& Sd& mq Djump v ky fjy D; y & dk* & r fu dk p w i fa p & r Sm
jz p fy gw , f/ Anti-virus a q mhz f0 Jv fa w Gu a w mh encrypt r v ky fx m; w Jh ' Du k' ft y dki f; t p u dky J a jc & mc HMu w m
jz p fy gw , f/ Malicious y & dk* & r fr ma w Gu a w mh ' DA sL[ ma w Gu a e t a w GUt Mu HK, ljy D; A dki f; & y fp fa w G^ worm a w G
y Gm; r sm; y sHUE SHUc sde fr Sm encrypt r v ky fx m; w Jh decryption engine & Sd& mu k' fu dk jy e fx y fjy i fa & ; Mu jy D; o lw dkU& JU
polymorphic u k' fa w Gu dku mu G, fz dkU Mu dK; p m; Mu w mjz p fy gw , f/ Anti-virus a q mhz f0 Jv fa w Gu decryption
engine t o Gi f a jy mi f; v Ja e p Oft w Gi f; i ky fv QdK; a e w Jhu k' fa w Gu dk & Sma z Ga w GY& SdE dki fz dkUt w Gu f & Iy fa x G; v Sw Jh u k' fc GJjc r f;
p dw fjz mr Ia w Gjy Kv ky fE dki fr , fq dk& i f ' Dv dk malware a w Gu dk p Hkp r f; a x mu fv Sr f; E dki fz dkU a r Qmfv i fh& y gw , f/
INFO: : Metamorphic u k' fq dkw mu a w mho lu dk, fw dki fjy e fjy D; y & dk* & r fjy e fa & ; E dki fw Jhu k' fu dk a jy mw mjz p fy gw , f/
r Mu mc P q dko v dky J o lU& JUu dk, fy dki fu k' fu dk , m, Dy Hkp Hw p fc kt jz p f a jy mi f; v Ja y ; v dku fjy D; r S y Hkr Se fu k' fu dk jy e fjz p fa p
w my g/ ' De n f; u dka w mht c sdKUA dki f; & y fp fa w Gu z dki ft o p fa w Gu dk u l; p u fa p w Jht c gr Sm t o Hk; jy Ky gw , f/ & v ' fu a w mh
o lw dkU& JU children ( A dki f; & y fp fx dx m; a o my & dk* & r fr sm; ) a w G[ m b , fa w mhr S o lw dkUe JUw la w mhr Sm r [ kw fy gb l; /
u Ge fy sLw mA dki f; & y fp fa w Gu ' De n f; u dk t o Hk; jy K& w Jht a Mu mi f; & i f; u a w mh anti-virus a q mhz f0 Jv fa w Gu signature
a w Gu dkr Sw fr djc i f; r S a & Smi f& Sm; E dki fz dkUjz p fy gw , f/ w u , fh algorithm u a w mhr a jy mi f; v Jb l; v dkU q dkE dki fa y r , fhv J
t & m& mw dki f; u a w mh jz p fE dki fy gw , f/ Metamorphic u k' fu a w mh polymorphic u k' fx u f y dkjy D; t p Gr f; x u fy g
w , f/ b ma Mu mi fhv Jq dka w mh anti-virus a q mhz f0 Jv fa w mfa w mfr sm; r sm; u u k' fa w Gexecute v ky fc sde fr Sm o dx m;
jy D; o m; A dki f; & y fp fu k' fa w Gu dk & Sma z Gz dkU Mu dK; p m; Mu v dkUy g/ Metamorphic u k' fa w G[ m r w ln Dw Jh OS E Sp fc kMu m;
( Oy r m Windows E Si fhLinux) ( o dkU) ' Dx u fy dkjy D; ( o dkU) r w ln Dw Jhu Ge fy sLw mw n fa q mu fr I( y & dkq u fq m) a w G
& Sd& i fa w mi fr S exe z dki fa w Gu dk u l; p u fa p jy D; t v ky fv ky fa p E dki fy gw , f/ r Mu mc P q dko v dky J A dki f; & y fp fa w G[ m o l
u dk, fw dki f a jr mu fr sm; p Gma o m A dki f; & y fp fa w Gu dko , fa q mi fjy D; p ly gA dki f; & y fp ft o Gi fe JU t w lw u Gv ma & mu f a y gi f; p y f
Mu y gw , f/
INFO: : Alphanumeric u k' fu a w mh p mv Hk; a w G? * P e f; a w Ga y gi f; p y fx m; w Jht w GJ( ' ga Mu mi fh ' Dv dkt r n fw Gi f&
w my g) w p fc kjz p fjy D; o lw dkUu dk u Ge fy sLw mu o m process v ky fE kdi fw Jh e m; r v n fE dki fw Jhy Hkp Hw p fc kt o Gi fe JU a & ; x m; Mu
w my g/ e r le m alphanumeric u k' fw p fc ku a w mhASCII jz p fy gw , f/ ' Dx u fy dkjy D; a jy m& & i fa w mh alphanumeric
u k' fq dkw m machine u k' fjz p fjy D; o lw dkUu dk v Hk; 0 z w fv dkU& w Jh ASCII p mv Hk; t jz p f assemble v ky fjy D; a & ; x m; Mu
w my g/ Oy r m "a" "z", "A" "Z", "1" "9", "#", "!", "@" p o n f . . . / Alphanumeric u k' fa w Gu dk
a & ; w Jht c gr Sma w mh ' Du k' fu dkt v ky fv ky fa p r , fh o w fr Sw fx m; w Jh u Ge fy sLw mz GJUp n f; w n fa q mu fr Iy Hkp He JUy w fo u fw Jh
machine u k' f& JU encoding p e p fu dk a u mi f; a u mi f; e m; v n fx m; z dkUv dky gw , f/ ' Du k' fu dka w mh web form w dkUv kd
application a w Gu dk t & l; v ky fz dkU& n f& Gn fc su fe JU t o Hk; jy KMu w mjz p fy gw , f/ ' Du k' fa w Gu dk v u fc Hjc i f; t m; jz i fh
exploit jz p fa p r Smjz p fy gw , f/ ' Dexploit jz p fa p w mu y J buffer overflow jy e mu dk Mu HKa w GUa p r Smjz p fy gw , f/
w c gw & Hr Sma w mh alphanumeric u k' fu dk y & dk* & r fr mw p fa , mu fu b , f compiler ( o dkU) assembler r Sr & Sdb J
y & dk* & r fw p fy k' fu dka & ; z dkU v dkt y fv mw Jht c gr Sm t o Hk; jy KMu y gw , f/ Alphanumeric y & dk* & r fw p fy k' fu dk
a & ; z dkUv dkt y fw mu a w mhtext editor w p fc ky g/
INFO: : Shell u k' fq dkw mu a w mh a q mhz f0 Jv f bug u a e t c Gi fha u mi f; , ljy D; payload t jz p ft o Hk; jy Kw Jh
machine u k' f& JUw p fp dw fw p fa ' o jz p fy gw , f/ Machine r Smt v ky fv ky fa e w Jh a q mhz f0 Jv f& JUt m; e n f; c su fu dk
t c Gi fha u mi f; , ljy D; t c Gi fhr & Sdw Jho Hk; p GJo la w Gu dk OS & JU command-line u a e w q i fh u Ge fy sLw me JU c sdw fq u fE dki f
a t mi fc Gi fhjy Ky gw , f/ y Hkr Se ft m; jz i fha w mh null-terminated (\0) string t a e e JUo dr f; q n f; w mjz p fjy D; null
character a w Ga w mh r y g0 i fE dki fy gb l; / Exploit v ky fc Hx m; & w Jh process & JU privilege a w G& x m; w hJ u Ge fy sLw m
p e p fw p fc ku dk command-line access & x m; & i f shell u k' fw p fc ku dk exploit payload w p fc kt a e e JU t o Hk; jy KE dki f
y gw , f/ Anti-intrusion a w Gu p Hkp r f; w mu dk a & Smi f& Sm; z dkUe JU string w p fc kx u fy dkjy D; o dr f; q n f; E dki fz dkU y & dk* & r fr m
a w G[ m r Mu mc P q dko v dky J self-decrypting u k' f? polymorphic u k' f? alphanumeric u k' fa w Gu dk t o Hk; jy K
Mu y gw , f/ Shell u k' fa w Gu dk process w p fc k& JU r Sw fOmP fa e & mv Gw fr Sm o dr f; q n f; x m; E dki fjy D; stack e JU heap
u dkt a jc c Hw JU buffer overflow ( o dkU) format string attack w dkUv dk t m; e n f; c su fa w Gu dk t o Hk; jy Kjy D; y & dk* & r f
a w G& JU w ke fUjy e fr Iu dk x de f; c sKy fv dku fjy D; a e mu fr Sma w mhattacker a w Gu ' Du k' fa w Gu dk t v ky fv ky fa p w m jz p fy gw , f/
y & dk* & r f& JUw ke fUjy e fr Iu dk x de f; c sKy fw Jhe n f; v r f; a w Gu a w mh t r sm; Mu D; & Sdjy D; OS e JU y & dkq u fq m w n fa q mu fr Ia y :
r lw n fjy D; u GJjy m; a e r Sjz p fy gw , f/ ' De n f; v r f; a w Gx Ju t c sdKUu a w mhstack frame x Ju return address u dkz su f
a & ; jc i f; ? exception handler a w Gu dkz su fa & ; jc i f; e JU Windows u dkt a jc jy Kw Jhshatter attack w kdUy Jjz p fy gw , f/
., Polymorphic - ...- . ._ .


INFO: : Machine u k' f ( o dkU) machine b mo mp u m; q dkw mu a w mh u Ge fy sLw m& JU CPU u w dku f& dku f
e m; v n fE dki fw Jh instruction a w Ge JU a ' w ma w Gy g0 i fw Jh p e p fw p fc kjz p fy gw , f/ Machine b mo mp u m; w p fc k& JU
"words" q dkw mu a w mh instruction a w Gu dka c : a 0 : w mjz p fjy D; o lw dkUt o D; o D; [ m CPU & JU & dk; & Si f; v Sw Jh v ky f
a q mi fc su fw p fc ku dk v ky fa p y gw , f/ Instructon a w Gu dk bit a w Ge JUz GJUp n f; x m; w mjz p fjy D; command a w Gr w l& i f
a w mh r w ln Dw Jh bit y Hkp Ha w Gjz p fa e r Smy g/ CPU model w dki f; r Sma w mh o lU& JUu dk, fy dki f machine u k' f ( o dkU) instr-
uction set & Sdjy D; w p fx y fw n f; a w mh u sc si fr Su sE dki fy gv dr fhr , f/ w u , fv dkUo m CPU A u CPU B & JU b mo m
p u m; t m; v Hk; u dk e m; v n fw , fq dk& i fa w mh CPU A [ m CPU B e JU o [ Z mw jz p fw , fv dkU a jy mv dkU& y gw , f/
w u , fv dkU CPU B u CPU A & JUu k' ft c sdKUu dk e m; r v n fc Jhb l; q dk& i fa w mhCPU B [ m CPU A e JU o [ Z mw
r jz p fy gb l; / t c sdKU machine b mo mp u m; a w G[ m o lw dkU& JU instruction a w Gu dk bit t a & t w Gu f w ln Dp Gm
x m; w ma w GU& y gw , f/ y Hkp Ha w Gu dk b , fv dkz GJUp n f; x m; w , fq dkw mu a w mh machine u k' fo w fr Sw fc su f a y :
t r sm; Mu D; r lw n fy gw , f/ t r sm; p ku a w mh instruciton w p fc ku dk field a w Gt jz p fc GJv dku fw mjz p fy gw , f/ y Hkr Se f
t m; jz i fhq dk& i fa w mh field w p fc k& JUw e fz dk; ( opcode) [ m w du sw Jhv ky fa q mi fc su fw p fc ku dk ( Oy r m - add) o w f
r Sw fy gw , f/ t jc m; field a w Gu a w mh operand t r sdK; t p m; ? o lw dkU& JUw n fa e & m ( o dkU) o lw dkU& JUw e fz dk; u dk
w dku f& dku fa y ; y gw , f/ ( instrucion w p fc kx Jr Smy g0 i fw Jh operand a w Gu dk immediate v dkUa c : y gw , f/ ) x l; x l;
q e f; q e f; instruction set t c sdKUr Sma w mh opcode field w p fc kr & Sdb J operand a w Go my g& Sdy gw , f/ t jc m;
instruction set a w Gr Smv J operand w p fc kw a v c sdKUw JhE dki fy gw , f/ ( Oy r m - NOSC)
a u mi f; jy D? y Hk( 4 9 ) u dkjy e fMu n fhv dku fy g/ ' Du k' fa w G[ m data section & JUw p fp dw fw p fa ' o u dk encrypt
jy e fv ky fw mjz p fy gw , f/ ' Dencryption routine u a e F8 u dkE Sdy fv dku f& i fa w mhy Hk( 5 2 ) t w dki f; jr i f& y gr , f/

y Hk( 5 2 )
y Hk( 5 2 ) r Smjr i f& w mu a w mh a e mu fx y f CALL w p fc kjz p fy gw , f/ F7 u dkE Sdy fjy D; CALL x Ju dk 0 i fMu n fh
v dku fMu & a t mi f/ y Hk( 5 3 ) /

y Hk( 5 3 )
y Hk( 5 3 ) u dka w mh& Si f; jy p & mr v dka w mhb l; v dkUx i fy gw , f/
t u sOf; c sKy fjy e f& Si f; jy & r , fq dk& i fa w mh ' Dy & dk* & r fa v ; [ m u Re fa w mfw dkUu dk t m& Hkv TJw Jhu k' fu dk y x r q Hk; jy y g
w , f/ ' Dha e mu fr Sma w mh code section u dk decrypt v ky fy gw , f/ Nag u dkz e fw D; z dkU self-modifying u k' f
t c sdKUu dk t v ky fv ky fa p y gw , f/ Nag t w Gu fv dkt y fw Jh data section u dk decrypt v ky fy gw , f/ jy D; & i f nag u dk
run jy D; main y & dk* & r fu dkz e fw D; z dkU self-modifying u k' ft c sdKUu dk t v ky fv ky fa p y gw , f/ ' Dha e mu fr Sma w mhy & dk* & r f
u dk run jy D; y & dk* & r f& JUv ky fa q mi fc su f jy D; q Hk; v dkU r x Gu fc i fr Sm t jc m; enxor w p fc ke JU encryption jy e fv ky fjc i f; jz i fh
data section u dk z su fq D; v dku fy gw , f/
' ga w Gu dk ' Da e & mr Smy J e d* Hk; c sKy fv dku fjy D; nag u dk z su fz dkUjy i fy gr , f/ y & dk* & r fu dk Olly r Smjy e fz Gi fhv dku fy g/
( Ctrl+F2) / y Hk( 5 4 ) /

y Hk( 5 4 )
VA 401016 e JU VA 401017 Mu m; r Sm PUSH 0; u dk z e fw D; w mjz p fw Jht w Gu f ' Da e & mr Sm JMP
40106A; v dkUjy i fy gr , f/ ' ga y r , fhr Sw fx m; & r Smu ' Dt c sde fr Sma w mh ' Dbyte a w Gu dk encrypt v ky fx m; w ke f; & Sdy g
a o ; w , f/ y x r q Hk; VA 401016 e JU VA 401017 r Sm b ma w G& Sda e o v Jq dkw m t & i fMu n fhMu y gr , f/ t a y : u dk
scroll e n f; e n f; q GJv dku fy g/ y Hk( 5 5 ) /
., Polymorphic - ...- . ._ .



y Hk( 5 5 )
a jy mi f; & r Smu a w mh y Hk( 5 5 ) r Smjr i f& w Jht w dki f; 305A a e & mr Smy g/ ' gu dk & dk; & Si f; v Sw Jh enxor o Hk; jy D; a jz & Si f;
v dkU& y gw , f/ Code section decryption r Sm XOR v ky fw m[ m 5A e JUq dkw m r Sw fr dy go v m; / Crackers'
Tools u dkz Gi fhv dku fy g/ y Hk( 5 6 ) /

y Hk( 5 6 )
INFO: :
XOR A, B; // C
XOR A, C; // B
XOR B, C; // A
' ga Mu mi fhJMP 40106A (EB57) t w Gu f EB u dk XOR v ky fy gr , f/ y Hk( 5 7 ) /

y Hk( 5 7 )
B1 q dkw mu a w mhVA 401016 r Sm& dS& r , fhbyte jz p fy gw , f/ 57 u dk XOR v ky fy gr , f/ y Hk( 5 8 ) /

y Hk( 5 8 )
0D q dkw mu a w mhVA 401017 r Sm& dS& r , fhbyte jz p fy gw , f/
Decrypt v ky fr Smjz p fw Jht w Gu f y Hk( 5 5 ) u 305A a e & mr Sm EB57 v dkU u Re fa w mfw dkUu assemble
r v ky fw my g/ ' ga y r , fh 305A a e & mr Sm B10D v dkUjy i f& r Smjz p fy gw , f/ VA 401016 a e & mr Sm right-click
E Sdy fjy D; Binary edit u dka & G; y g/ y Hk( 5 9 ) /

y Hk( 5 9 )
., Polymorphic - ...- . ._ .


y Hk( 5 9 ) t w dki f; jy i fv dku f& i fa w mhy Hk( 6 0 ) t w dki f; jr i f& r Smjz p fy gw , f/

y Hk( 6 0 )
' Djy i fv dku fw Jhz dki fu dk Patch.exe t r n fe JUo dr f; v dku fjy D; Patch.exe z dki fu dk Olly r Smz Gi fhv dku fy g/ y Hk( 6 1 ) /

y Hk( 6 1 )
y Hk( 6 1 ) u VA 401299 u CALL 40130F u a w mhdecryption routine u dka c : o Hk; w my g/ Encrypt
v ky fx m; w Jhu k' fa w Gu dk y x r q Hk; Mu n fhv dku fMu & a t mi f/ y Hk( 6 2 ) /

y Hk( 6 2 )
y Hk( 6 2 ) r Sm u Re fa w mfw dkU patch v ky fx m; w Jhu k' fu dk a w GU& y gw , f/ F8 u dkE Sdy fjy D; ' Da e & mr Sm b mq u fjz p f
r v Jq dkw mMu n fhv dku fMu & a t mi f/ y Hk( 6 3 ) /

y Hk( 6 3 )
y Hk( 6 1 ) u VA 401299 u dkv ky fa q mi fjy D; c sde fr Sm jr i f& w mu a w mh y Hk( 6 3 ) r Smjr i f& w Jht w dki f; jz p fy gw , f/
Self-modifying u k' f[ m 57EB w e fz dk; u dk VA 401016/401017 r Smo Gm; x m; a w mhr Smjz p fy gw , f/ u Re fa w mf
w dkUt a e e JU decryption call u dk execute v ky fjy D; o Gm; y gjy D/ Decryption call (VA 401299) u dkv ky fa q mi fjy D;
c sde fr Sm ' Du k' fa w Gu dk a c : o Hk; w Jhcall 401011 (VA 40129E) x Ju dk F7 E Sdy fjy D; 0 i fMu n fhv dku fMu & a t mi f/

y Hk( 6 4 )
y Hk( 6 3 ) r Smjr i f& w Jht w dki f; VA 401013 u dk execute v ky fjy D; c sde fr Sma w mh VA 401011 a e & mr Sm JMP
40106A; v dkUa y : v mw ma w GU& y gw , f/ u se fw Jht y dki f; u dka w mh & Si f; jy p & mr v dka w mhb l; x i fy gw , f/ y & dk* & r fu
nag t w Gu fv dkt y fw Jhu k' fa w Gu dk decrypt v ky fjy D; w Jha e mu fr Sm VA 401011 a e & mu dk x y fa & mu fv mr Sm jz p fy g
w , f/
' Dw p fc gr Sma w mhVA 40106A & Sd& mq Djump jz p fo Gm; jy D; nag window u dka u smfo Gm; r Smjz p fy gw , f/
INFO: : u Re fa w mfht a e e JU 1 byte x Jo Hk; & r , fha jz & Si f; e n f; u dkv J a jy mc Jhy gw , f/ Messagebox u PUSH 0;
u dk PUSH 1; t jz p fa jy mi f; z dkUy g/ w u , fv dkU o i fht a e e JU ' gu dkMu dK; p m; Mu n fhc si fw , fq dk& i fa w mh VA 401039
u 5A a e & mr Sm 5B v dkU assemble v ky f& y gr , f/ b my Jjz p fjz p f ' De n f; u a w mh t a u mi f; q Hk; e JU t v G, fq Hk;
a jz & Si f; w Jhe n f; jz p fy gw , f/
., Registration number - .- ....._... ...._.


tcef;(24) - Registration number udk tGefvdkif;wGif ppfaq;jcif;tm; z,f&Sm;jcif;
-..--. registration number - .-.-_.-.. .._... ..- . .. _ ._..-
- .._._--. Registration number - -..- -.- - ......--
-.- --. - -. ..-.- - . .. - .. .. _ . ._-. ._ -. -.
-.-. . - . . register .._ . . .. ...-. ' Software Protection' ..,
-. . ..-. registration - ........--- -..-- crack _-_ . ._..
-. ........_..-. -..--. -.- . - ... . .- _.. _--....-.
._-. . . - - -.- .-..... .._-. Crack ......-
....-.-. Download Accelerator PLUS (DAP) _.. -. DAP -. -.--..--
_..._. speed download ... - ... . _.. _ . download .. ..-. .-. .. .
_. . .... . -. _.. -. _.. download accelerator ....-._..- FlashGet
-.-. link .- ._...- ..-- resume . download ...- ....-
.-. -., DAP - www.speedbit.com -. download ._. install - -
version -.-. ....._....... -.-... crack _..-.-. Version 8.0.4.1 _..
-. -. version _.. _.. ..-.-.. .-.-. - -
Crack . - .-. - .. .... .-.-. -.- -.......-.- ,

,
-.- SVK Protector protect ..-._.. -. ... .._. .-. - .-. .
pack ..-.- unpack _. -. . - . -.._-. . .-. unpack _.- Packer
(Protector) ...' .. . .. ... ._ ._.. ... - .-. . .. . SVKP pack
..-.- -. unpack . . -.- --_ . ._. ._.. -. SVKP - ......
-.-. Pavol Cerven .._ - ..- -. .- _ _ SVKP - .- - unpacker
.--..--.--._-.. SVKP - .- - unpacking . ... -. ._.. -.-
-._-. .. . . unpack -.-_.......--- unpack _.- --_.
.__ ._.. -. AHTeam -.......- Quick Unpack 2.1 -. packer .-..-.......-
unpack ... ... SVKP protect ..-..--- _.. _ .. .-. ,
SVKP -. . - protect . - - .- _ - _ .. .- . ._-. .- -.-. , RSA
algorithm - ..__. , API function ...-_...._.._. , anti-debug _ ....
..._...._. , .-.. tracer .-. dump . . .. -.- . .._ . - _.. -.
, SVKP _. protect ...... .. unpack _.
. ...- _ ..._ .. - .-. . ..- - . .,. _.........
_.. -.
, OEP - ._ .
, Stolen byte ...- ._.
, .- dump _ .
, IAT - _ _ .
, .-__.
., Registration number - .- ....._... ...._.



, OEP - ._.
OEP - .-.-.-. stolen code ._-. -.._-...-. -.-.-. stole
.- . code section ... instruction ..- OEP ... . OEP .. .---., break
. .. .-. ._ DAP.exe . - Olly . ... Olly _..-.-.- _. Alt + O
-._. Debugging options SFX tab -..- ,

,
,.. _.--. Trace real entry blockwise radio button - . .. _ Pass
exceptions to SFX extractor checkbox - check - .-- -.._-. ....
.-..-. ._.-... .---. -.._-...-. Olly Help ... ....- ._..
Trace real entry blockwise (inaccurate)
OllyDbg uses 4-K blocks to step through the packed code. This method may cause detection of false real
entry.
Pass exceptions to SFX extractor
This option tells OllyDbg to pass some kinds of software exceptions that occur while tracing for real SFX
entry (memory access violation, INT3 breakpoint, division by 0, privileged or illegal instruction) directly to self-
extractor.
.-.._ DAP.exe . - Olly ..._-_-_-.. ,

,
,.. _.--. VA 0053F432 .. Olly -. . ... . . - .-. - -. stolen
byte .- ..- - code section - .. . instruction ...-._ - -.-.- -.
. . . -. . . .. VA 0053F432 ..- - scroll _._...-._. _-_..
,

,
., Registration number - .- ....._... ...._.


--. .-. ,- - .-. - _. - NOP instruction ...- . . - .- . . .-. ._
,- VA 0053F432 ..- .. - - -. - . . . - ..- _..-. ,- Trace real
entry blockwise radio button ... Stop at entry of self-extractor -_..-
, Stolen bytes - ._ .
-.-. unpack .. . - . . _-.. ._.. -. .._-.- . ...- .-.
. - . .. . Ctrl + F2 -._. -.- _.- ,- . ... . ..

,
,- No button - ..- Entry point - ..- - Alt+O -._. ,-.
Exception tab -_-

,
,.. Memory access violation Ignore aslo following - _.---.
_..-. ,-. entry point .- _...-

,
,.. F7 - -.._. CALL function . VA 00731001 -... CALL function
.- ..- _ . Registers window - _-_- .,

.,
.,-_-_- ESP register .... .-.- .-.. -.._-...-. ESP
-..._..... .... right-click ._. Follow in Dump -..- ,-.
.- ..
., Registration number - .- ....._... ...._.
.


,
,- 38 07 91 70 .... right-click ._. hardware, on access - Dword -..-
_ . F9 (Run) - .-

,
,-. exception -_.- Shift+F9 -. Exception error ---. Shift+F9
-. ,-.-.. SVKP version ..-__. Shift+F9 - . - .- - -. _- . . ,
_- . - . ..

,
,-..-- Alt + M -._. memory map window - . ,

,
,- highlight _...-.... right-click ._. set memory breakpoint on access -
. .. _ . Shift+F9 -. ,- . _. ..

,
., Registration number - .- ....._... ...._.


,-.-. SVKP decompression code _..-. Alt+M -.._. PE header
... right-click . _. Remove memory breakpoint -... memory breakpoint
-...._..-. Shift+F9 -. ..- PUSHAD instruction ... -...
,

,
,-._.- -.-.... .- .. - - -. - . . . - ...- OEP (VA
0053F432) .-.... _.. Ctrl+G -._. OEP -..--_ ,

,
,- OK button -..- ,-. _...

,
VA 0053F432 ... . ... breakpoint -. .- . - - ,- ._. . .
.-. ._ . . hardware breakpoint .--..-.--- Debug menu - Hadrware
breakpoints -.._. breakpoint .--.-- _..-. trace -.. Ctrl+F11 (Trace into)
- . . - - .-. - ... breakpoint .-.--- OEP ..- ...--.
..-.-. ..-...-. -.-.- stolen bytes -.. trace --...-- __-_.
._ Olly View menu - Run trace -..- ,

,
,-.-. Olly - PUSHAD -. CALL 0042B5E4 trace ...-.- _-.
Highlight _...-..-.-. -.-.-..- stolen bytes +++
INFO: : Stolen bytes . -.-.-. . exe . -. . . - . exe .-..-..-
., Registration number - .- ....._... ...._.


.. ..- _.. _ . packer - . . ...-. .. ..- -. OEP . . - . - . -. dump
_.-..-...-. dump .._ .... exe ....-. ..-.-. .. ... ..-
... ..-. . .-. - ., ._-. . -. .- -. crash _.. _--. . -.-.-. -.
-.- crack . . .. -.- . . -. -. .- - pack ..- . ..-. crash
._.. - . -.._-. . .-. stolen bytes .--. OEP ...--... protector run
._-
, .- dump _.
-. . ..-. OEP - .- _ _.. - - - process (Task Manager...- DAP.exe)
- dump _-.. Olly . . right-click ._. make dump of process -..- .,-.
.- ..

.,
.,- Get MAP button -..- ,
,
,- .- - .-. - stolen byte .- .- . - . ..... ......- -
scroll ._._-_-... ,-. _... 00E60000 ..-.._. Add button -.
,-. _...
,
., Registration number - .- ....._... ...._.


,- Name . - - - . . . . . .- .._-. -_-_. Apply button
-..- ,-..-..

,
..- . .-.-. ,- 00E90000 ..- . ._ . Add button -.

,
-. . . ,- Name . - - - . . . . . .- .._-. -_-_. Apply
button -..- _..-. ,- Close button -..- ,-. _...

,
., Registration number - .- ....._... ...._.


,- .. _..- ...- - . _.. .. _ . Dump button -._.
dumped.exe .-._.- ... ..-. dump -._ .. ._
, IAT (Import Address Table) - _ _.
-. . ..-. IAT - _ . ..

,
,-. OEP ... . 0013F432 --__. AutoSearch button -... Found
something! .- MessagBox ..... Get Import button -._. import function
.-- _-_ ,. function .-..-.......- import ... ......-. .--.
....-... Show Invalid button -...

,
_ . .-. ,- . invalid _...- address .- . right-click ._. Trace Level1
(Disasm) - ... ,-. _...
,
., Registration number - .- ....._... ...._.


. ..-. dumped.exe . - _ . .-. .. ,- Fix Dump button - . . -
_ . dumped.exe -....- ,-. _...

,
,-._._..-. ImpREC - IAT _ _ ..... - dumped_.exe ._
..- . . .._ ...-.
, . - _ _ .
dumped_.exe .... ._-_.. .,

.,
- .-. - - ..-. .- . Windows - - .-. - . -. PE ..---. ._..
-. - .-. - OEP -__-_.. dumped_.exe - PE Editor 1.7 .. .-_. OEP -
A805B3 ._..- ,

,
... . .- .. -.-.-. OEP -_... LordPE ._ LordPE _- -.
.--. ......-. OEP .... A805B3 - .- ._-. . .-.-. ,-
- .-. - stolen bytes . virtual address -. OEP [E805B3-400000 = A805B3h] ...
_..-., __. .-...- ... .-.- .,- . _.- .

,
--. .-. dumped_.exe . . PE header _... ._-. CFF explorer .. PE
header -___. .-...- . -._... . .-. - SVKP protect ..-
DAP.exe . - .. _. . . unpack _ .. .._ _.. -.

., Registration number - .- ....._... ...._.


, Registration number - .- ....._ ... .. .._ .
u Re faw mfw dkU unpack v ky fx m; w Jh dump_.exe z dki fu dk PEiD e JU p p faq ; Mu n fhw Jht c gr Smaw mh y Hk( 3 1 )
t w dki f; jr i f&y gw , f/
y Hk( 3 1 )
u Re faw mf b maMu mi fh section t o p faw Gu dk x y fx n fh&o v Jq dkw m o i fht ae e JU &Si f; av mu fjy Dx i fy g
w , f/ OEP [ m t o p fx y fay gi f; x m; w Jh section x Jr Sm&Sdae w mr dkUv dkUy g/ dump_.exe u dk Visual C++ 6.0
e JUa&; o m; x m; w m ao c smjy Dr dkUy &dk* &r f&J Ut v ky fv ky fy Hku dkao c smMu n fh&at mi f/ dump_.exe u dky Hkr Se ft w dki f; z Gi fh
v dku fy g/ y Hk( 3 2) /

y Hk( 3 2)
y Hk( 3 2) u dkt i fw me u ft q u ft o G, f&Sdw Jhu Ge fy sLw mr SmMu n fhr , fq dk&i faw mhaMu mfji maw Gu dkaw GU&r Smjz p f
y gw , f/ Help menu u About u dkMu n fhy gr , f/ y Hk( 3 3 ) /
y Hk( 3 3 )
., Registration number - .- ....._... ...._.


y Hk( 3 3 ) r Smjr i f&w mu aw mhaq mhz f0 Jv f[ m register r v ky fx m; aMu mi f; e JU0 , fo Hk; z dkUjz p fy gw , f/

y Hk( 3 4 )
Help menu u dka&G; v dku f&i faw mh y Hk( 3 4 ) t w dki f; jr i f&r Smy g/ Enter Registration Info button u dk
ESdy fjy D; register v ky fMu n fhMu v dku f&at mi f/ y Hk( 3 5 ) /

y Hk( 3 5 )
y Hk( 3 5 ) r Sm OK u dka&G; ay ; &i faw mhy Hk( 3 6 ) t w dki f; jr i f&r Smjz p fy gw , f/

y Hk( 3 6 )
u Re faw mfhu Ge fy sLw m[ m t i fw me u fe JUc sdw fq u fx m; jc i f; r &Sdw Jht w Gu f ' Dv dkay : ae w my g/ ' Dav mu f
q dk&i f crack v ky fz dkU t c su ft v u faw Gaw mfaw mfav ; v Hkav mu fjy Dv dkUx i fy gw , f/ ' gaMu mi fh dump_.exe u dk
Olly r Smz Gi fhjy D; p p fMu n fh&at mi f/ y Hk( 3 7 ) /

y Hk( 3 7 )

., Registration number - .- ....._... ...._.


y Hk( 3 7 ) u aw mhOEP &Sd&mu dkjy y gw , f/ DB 2A? DB 84? DB 3F? DB AD p w maw Gu dkMu n fhv dku f&i f
aw mh' gaw G[ m u k' faw Gjz p faMu mi f; e m; v n fr Smy g/ ( VB r Smq dk&i faw mh' gaw G[ m p-code aw Gjz p fy gw , f/ ) F9
ESdy fjy D; y &dk* &r fu dkrun v dku fy g/

y Hk( 3 8 )
y Hk( 3 8 ) u exception u dkShift+F9 ESdy fjy D; au smfv dku fy g/ ae mu fx y f exception w p fc kx y faw GUy gr , f/

y Hk( 3 9 )
' Dexception u dkv JShift+F9 ESdy fjy D; au smfv dku fy g/ ' gq dk&i faw mhOlly r Sm dump_.exe y &dk* &r f run
ae y gv dr fhr , f/ ' Dt c g register v ky fMu n fhMu y gr , f/ y Hk( 4 0 ) /

y Hk( 4 0 )
y Hk( 4 0 ) r Sm OK u dka&G; v dku f&i faw mhy Hk( 4 1 ) t w dki f; jr i f&r Smy g/

y Hk( 4 1 )
y Hk( 4 1 ) u MessageBox u dkaw mh o i fjr i fz l; r Smy g/ ' D MessageBox u dkb , fae &mu ac : o Hk; w mv J
o d&at mi fv dkUOlly u dkPause execution (F12) v ky fv dku fy g/

y Hk( 4 2)
Pause ay ; v dku fw Jht c g y Hk( 4 2) t w dki f; jr i f&y gw , f/ ' Dt c g u dka&G; jy D; Call Stack (Ctrl+K) u dk
Mu n fhv dku fy g/

y Hk( 4 3 )
., Registration number - .- ....._... ...._.


y Hk( 4 3 ) r Sm jr i f&w Jht w dki f; ' DMessageBox u dk mfc42.#4224 u ac : o Hk; w mjz p fy gw , f/ ' gaMu mi fh' D
CALL &Sd&mu dkMu n fhy gr , f/ y Hk( 4 4 ) /

y Hk( 4 4 )
y Hk( 4 4 ) u BadBoy u dkac : r o Hk; c i fr Sm conditional jump (JE, JNZ) aw Gu dk aw GU&y gw , f/ ' Dt c g
Resource Hacker aq mhz f0 Jv fu dko Hk; jy D; BadBoy message t c sdKUu dkMu n fhy gr , f/ MessageBox w p fc kay : z dkU
q dkw m MessageBox r Smjy r , fh p mo m; aw Gu dk stack ay : t &i fu l; w i f&w , fv dkU ajy mc Jhz l; w m jy e ft r Sw f&y g/
' gaMu mi fhBadBoy message t c sdKUu dkMu n fhv dku fMu &at mi f/
PUSH 0F2BF = 62143,
"Your registration could not be completed due to unknown result from the activation server. \n\n Please try
again in a few minutes, or email sales@speedbit.com for more help.\n"
PUSH 0F2C0 = 62144,
"Your registration could not be completed due to submission of incorrect request to the Activation Server
\n\nPlease re-check the details you have entered or contact sales@speedbit.com \n"
PUSH 0F2BE = 62142,
"Your registration could not be completed due to lack of Internet connection with SpeedBit activation
server.\n\nPlease try again in a few minutes, or email sales@speedbit.com for more help.\n"
PUSH 0F2BD = 62141,
"Your registration could not be completed due to lack of Internet connection.\n\nPlease make sure you are
connected to the Internet.\n"
Message aw Gt m; v Hk; u aw mhau mi f; w mw p fc kr Sr &Sdy gb l; / ' gaMu mi fhv Jy kH( 4 5 ) u MessageBoxA u dk
t v ky fv ky fap w m jz p fy gw , f/

y Hk( 4 5 )
au mi f; jy D/ y &dk* &r f&JUOEP &Sd&mq Djy e fMu n fhMu &at mi f/ y Hk( 4 6 ) /

y Hk( 4 6 )
y Hk( 4 6 ) u JMP u dka&G; jy D; Enter key ESdy fv dku f&i f y Hk( 4 7 ) t w dki f; jr i f&y gw , f/

y Hk( 4 7 )
y Hk( 4 7 ) u JMP u dka&G; jy D; Enter key ESdy fv dku f&i f y Hk( 4 8 ) t w dki f; jr i f&y gw , f/

y Hk( 4 8 )
., Registration number - .- ....._... ...._.
.

c kc sde fx daw mhb mu k' fr Sr , fr , f&& a&; x m; w m r aw GU&y gb l; / ' Du k' faw G[ m cracker aw Gu dk t m&Hkv TJ
z dkUv ky fx m; w Jhdiversion u k' faw Gq dkw m ao c smy gw , f/ c ke u register v ky fw ke f; u u Re faw mfw dkU a&mu f&Sdae c Jh
w Jh address aw G[ m 4xx,xxx 0 e f; u si fr Smy g/ v u f&Sd u Re faw mfw dkU jr i fae &w Jh address aw G[ m 4,xxx,xxx
0 e f; u si fjz p fy gw , f/ ' gaMu mi fhSearch for u ae string p mo m; aw Gu dk&Smaw mhv Jy Hk( 4 9 ) t w dki f; jr i f&w my g/

y Hk( 4 9 )
' gq dk&i f string aw Gu dk&Smz dkU4xx,xxx aw Gq Do Gm; Mu n fhy gr , f/ Ctrl+G u dkESdy fjy D; 401000 v dkU&dku fx n fh
v dku fy g/ jy D; &i f Search for u ae All referenced text strings u dka&G; v dku f&i f y Hk( 5 0 ) t w dki f; jr i f&y gr , f/

y Hk( 5 0 )
' Dav mu fq dk u Re faw mfw dkUt w Gu f aw mfaw mft q i fajy y gjy D/ ' Dw p fc g Help menu u About r Smjr i fc Jh&
w JhDAP Unregistered q dkw Jhp mo m; u dk&SmMu n fhy gr , f/ y Hk( 5 1 ) / ( y Hk( 3 3 ) u dkjy e fMu n fhy g/ )

y Hk( 5 1 )
y Hk( 5 1 ) r Sm OK ESdy fjy D; &Smaw mhu Re faw mfw dkUv dkc si fw Jhp mo m; u dkr aw GUy gb l; /
Resource Hacker u dkt o Hk; jy Kjy D; ' Dp mo m; aw Gu dk&SmMu n fhy gr , f/

y Hk( 5 2)
b maMu mi fh "DAP Unregistered" p mo m; u dk &Smr aw GUw mv Jq dkw m o i fht ae e JU e m; v n fav mu fjy D
x i fy gw , f/ w u , faw mh ' Dp mo m; aw Gu dk code section/ data section a&; x m; w mr [ kw fb J resource
section r Sm o dr f; x m; w mr dkUv dkUy g/ ' Dstring aw Gu dkv dkt y fr So m stack ay : u l; w i fjy D; t o Hk; jy Kw mjz p fy gw , f/
10003 = 2713 = DAP Premium
10008 = 2718 = DAP Unregistered
' gaMu mi fh code section r Sm PUSH 2718 v dkU&dku fx n fhjy D; ajy mi f; &SmMu n fhv dku f&at mi f/
Disassembler window r Sm right-click ESdy fjy D; Search for u Command u dka&G; v dku fy g/ y Hk( 5 3 ) /
., Registration number - .- ....._... ...._.



y Hk( 5 3 )
y Hk( 5 3 ) u Find button u dka&G; jy D; &Smv dku fw Jht c gr Sm y Hk( 5 4 ) t w dki f; aw GU&y gw , f/

y Hk( 5 4 )
Help menu u About u dka&G; w Jht c gr Sm "DAP Unregistered" v dkUjy &w Jht aMu mi f; &i f; u aw mhJNZ
u jump r jz p fv dkUjz p fy gw , f/ Jump jz p fEdki f^ r jz p fEdki fu dk VA 004DAF53 u CMP DWORD PTR DS:
[5DCEA0], EBX r Smp p faq ; w mjz p fy gw , f/ ' gaMu mi fhdump window &JU 5DCEA0 ae &mr Sm breakpoint
o w fr Sw fjy D; b maw Gq u fjz p fr v Jq dkw m ap mi fhMu n fhMu &at mi f/

y Hk( 5 5 )
' gaMu mi fh5DCEA0 ae &mr Sm right-click ESdy fjy D; Breakpoint u Hardware, on access Byte
u dka&G; y g/ jy D; &i f F9 u dkESdy fjy D; y &dk* &r fu dkrun Mu n fhy g/

y Hk( 5 6 )
' gq dk y Hk( 5 6 ) r Smjr i f&w Jht w kdi f; MOV DWORD PTR DS:[ESI+F8], EDI u dk execute
v ky fjy D; c sde fr Sm u Re faw mfw dkUo w fr Sw fx m; w Jhbreakpoint ae &mr Sm &y fo Gm; w maw GU&y gw , f/ F9 u dkx y fEdSy fy g/

y Hk( 5 7 )
., Registration number - .- ....._... ...._.
.

y Hk( 5 7 ) r Smjr i f&w Jht w kdi f; MOV DWORD PTR SS:[EBP-277C], EAX u dk execute v ky fjy D; c sde fr Sm
hardware breakpoint &Sd&mr Sm x y f&y fjy e fy gw , f/ ' Dae &mr Sm o w dx m; ap v dkw mu aw mhw u , fv dkU5DCEA0
u byte w e fz dk; e JUo kn w dkUn Dc Jhc sde fr Sm polymorphic u k' faw Gu dkau smfv Tm; r Smjz p fy gw , f/ F9 u dkq u fESdy fy g/

y Hk( 5 8 )
y Hk( 5 8 ) r Smjr i f&w Jht w kdi f; MOV EAX, DWORD PTR DS:[5DCEA0] u dk execute v ky fjy D; c sde fr Sm
hardware breakpoint &Sd&mr Sm x y f&y fjy e fy gw , f/ F9 u dkq u fESdy fy g/ Hardware breakpoint &Sd&ma&mu fw Jh
t c gr Sm &y fy gv dr fhr , f/ DAP y &dk* &r f run w Jht x d F9 u dkESdy fv mc Jhy g/ DAP y &dk* &r fu dkjr i fw Jht c gr Smaw mh
Help menu u About u dka&G; v dku fy g/

y Hk( 5 9 )
' Dt c sde fr Smaw mh Help menu u dk a&G; v dku fc sde fr Smy J y Hk( 5 9 ) r Smjr i f&w Jh hardware breakpoint r Smy J
y &dk* &r f[ m &y fw e fUae w maw GU&y gw , f/ About submenu u dkaw mi f a&G; v dkUr &aw mhy gb l; / ' gaMu mi fh HW
BP u dkjz Kw fv dku fy gr , f/ y Hk( 6 0 ) /

y Hk( 6 0 )
jy D; &i f Help menu u About u dka&G; v dku fy g/

y Hk( 6 1 )
' Dt c gr Smaw mh u Re faw mfw dkU aq mhz f0 Jv f brekpoint o w fr Sw fx m; w Jhae &mu dk a&mu fv my gjy D/ Dump
window u 5DCEA0 r Smaw mhbyte w e fz dk; u o kn jz p fae y gw , f/ ' Dt c sde fr Sm EBX &JUw e fz dk; u v J o kn jz p f
ae y gw , f/ o kn w e fz dk; ESp fc ku dkEdIi f; , SOfw Jht c gr Smaw mhJNZ (Jump if not zero) [ m jump r jz p fEdki fw Jht w Gu f
PUSH 2718 (DAP Unregistered) q Da&mu fv mr Smy g/ y &dk* &r f[ m register v ky fx m; jc i f; &Sd^ r &Sdu dk dump
window u 5DCEA0 r Sm&Sdw Jhbyte w e fz dk; u dkz w fjy D; q Hk; jz w fae y Hky g/ ' gaMu mi fh5DCEA0 r Sm o kn t p m; 1
v dkUjy i fv dku fy gr , f/
' gaMu mi fh 5DCEA0 u byte (00) ae &mr Sm right-click ESdy fjy D; Binary Edit u dka&G; v dku fy g/
y Hk( 6 2) / y Hk( 6 2) t w dki f; jr i f&w Jht c gr Sm 01 v dkUjy i fjy D; OK u dka&G; v dku fy g/ ' Dae mu fr Smaw mhjy i fx m; w Jhbyte (01)
u dko dr f; q n f; z dkU 01 ae &mr Sm right-click ESdy fjy D; Copy to executable file u dka&G; jy D; patch.exe q dkw Jht r n fe JU
z dki fu dko dr f; v dku fy g/
., Registration number - .- ....._... ...._.
.


y Hk( 6 2)
o dr f; v dku fw Jhz dki f t v ky fr v ky fo d&at mi f ( patch.exe) z dki fu dk jy e fz Gi fhv dku fy g/ jy D; &i f Help menu u
About u dka&G; v dku f&i f y Hk( 6 3 ) t w dki f; jr i f&y gw , f/

y Hk( 6 3 )
w p fc kc kaw mhr Sm; ae y gjy D/ patch.exe z dki fu dkOlly r Smz Gi fhjy D; jy e fp p fMu n fhy gr , f/ y Hk( 6 4 ) /

y Hk( 6 4 )
y Hk( 6 4 ) r Smjr i f&w Jht w dki f; entry point &Sd&mae &mr Smaw mh dump window u 5DCEA0 &JU byte
w e fz dk; [ m 01 jz p fy gw , f/ F9 ESdy fjy D; y &dk* &r fu dk run Mu n fhy g/ jy D; &i faw mh Help menu u About u dka&G;
v dku fy g/ y Hk( 6 5 ) /

y Hk( 6 5 )
y Hk( 6 5 ) u dump window u dkMu n fhv dku f&i faw mh5DCEA0 u byte w e fz dk; [ m o kn jz p fae w m aw GU&
r Smy g/ ' gaMu mi fhv J y Hk( 6 3 ) r Smjr i f&w Jht w dki f; DAP Unregistered v dkUjy ae w mjz p fy gw , f/ b , fae &mr Sm
5DCEA0 &JU byte w e fz dk; [ m 1 t p m; 0 ajy mi f; o Gm; o v Jq dkw mMu n fh&at mi f/ ' gaMu mi fh5DCEA0 u byte
(01) ae &mr Sm hardware breakpoint o w fr Sw fEdki fz dkU Breakpoint u Hardware, on write byte
u dka&G; v dku fy g/ ' Dw p fc gr Smaw mh access t p m; write u dka&G; v dku fw m o w djy Ky g/ Breakpoint o w fr Sw fjy D;
o Gm; &i faw mhF9 u dkESdy fv dku fy g/ y Hk( 6 6 ) /

y Hk( 6 6 )
., Registration number - .- ....._... ...._.
.

y Hk( 6 6 ) r Smjr i f&w Jht w dki f; MOV DWORD PTR DS:[ESI+F8], EDI u dk execute v ky fjy D; c sde fr Sm
5DCEA0 &JU byte (01) w e fz dk; ajy mi f; o Gm; w mjz p fy gw , f/ ' gaMu mi fh ' Dae &mr Sm y Hk( 6 7 ) t w dki f; jy i fv dku fjy D;
y &dk* &r fu dkq u f run (F9) Mu n fhy g/

y Hk( 6 7 )
F9 u dkESdy fjy D; q u f run Mu n fh&mr Smaw mhy Hk( 6 8 ) t w dki f; jr i f&y gw , f/

y Hk( 6 8 )
y Hk( 6 8 ) r Sm OK button u dka&G; ay ; v dku f&i faw mhq u ft v ky fr v ky faw mhb Jy &dk* &r f[ m jy D; q Hk; o Gm; w maw GU
&y gw , f/ ' gq dk&i faw mh01 ajy mi f; w dki f; t v ky fr jz p fw maw mhao c smy gjy D/ u Re faw mfht x i fajy m&r , fq dk&i faw mh
y &dk* &r f[ m 1 jz p f^ r jz p fu dk main window p w i fr ay : v mc i fr Sm p p fw mjz p fEdki fy gw , f/ ' gaMu mi fh hardware
breakpoint ESp fc k o w fr Sw fjy D; 5DCEA0 u byte w e fz dk; u dk ap mi fhMu n fhMu &at mi f/ HW BP w p fc ku aw mh
on access jz p fjy D; ae mu fw p fc ku aw mhon write jz p fy gw , f/ y Hk( 6 9 ) /

y Hk( 6 9 )
Breakpoint aw Go w fr Sw fjy D; o Gm; &i faw mhF9 key u dkESdy fv mc Jhy g/ u Re faw mfw dkU o w fr Sw fx m; w JhBP
w dki f; r Sm Olly u &y fy gv dr fhr , f/ F9 ESdy fjy D; q u fo Gm; y g/ y Hk( 7 0 ) t w dk i f; jr i f&&i faw mhc P &y fv dku fy g/

y Hk( 7 0 )
., Registration number - .- ....._... ...._.
.

' Dae &mr Sm u Re faw mf b maMu mi fh&y fc dki f; &o v Jq dkw m o i fht ae e JU &Si f; v my gv dr fhr , f/ w u , faw mh
polymorphic u k' faw Gu dk aw GUv dku fv dkU &y fc dki f; v dku f&w my g/ 0045E6F5 u JNZ [ m jump r jz p fw Jht w Gu f
polymorphic u k' faw Gq Da&mu fv mr Smy g/ 0045E71B u PUSHAD u dk o w dx m; r dy go v m; / PUSHAD
q dkw mu aw mh"PUSH all Double" u dk q dkv dkw mjz p fjy D; CPU u dk stack ay : r Sm&Sdw JhEAX u ae t p c sDjy D; EDI
r Smt q Hk; o w fw Jh 32bit (DOWRD) register t m; v Hk; x Jr Smy gw Jht &m t m; v Hk; u dk o dr f; x m; ay ; z dkU n Te fMu m; y g
w , f/ PUSHAD u dko Hk; &i f ESP w e fz dk; u dkap mi fhMu n fh&y gw , f/ y Hk( 7 1 ) /

y Hk( 7 1 )
' Dt c sde fr Smaw mhF9 u dkr ESdy fb Jy Hk( 7 2) r Smjr i f&w Jht x dF8 u dko m ESdy fv mc Jhy g/

y Hk( 7 2)
y Hk( 7 2) u JMP ECX ae &mr Sm F8 u dkESdy f&i faw mh y Hk( 7 3 ) t w dki f; jr i f&y gr , f/ b maMu mi fhv Jq dkaw mh
ECX &JUw e fz dk; [ m 0012E774 jz p fae v dkUy g/

y Hk( 7 3 )
PUSHAD u dk POPAD e JUw GJo Hk; &y gw , f/ POPAD [ m stack u ae register x Jr Sm&Sdw Jht &m
t m; v Hk; u dku l; y gw , f/ ' gaMu mi fhPOPAD &Sdw Jhae &mr Sm breakpoint o w fr Sw fjy D; F9 (run) u dkESdy fv dku fy g/

y Hk( 7 4 )
' Dt c gr Sm y Hk( 7 3 ) [ m ( 7 4 ) t w dki f; u k' faw Gajy mi f; o Gm; r Smjz p fy gw , f/ PUSH + RETN u aw mh JMP
e JUn Dw mjz p fw Jht w Gu f F8 u dkESdy fr , fq dk&i f VA 0045E81D q Djump v ky fo Gm; r Smjz p fy gw , f/ VA 0045E81D
u aw mht a&; r Mu D; v Sw Jht w Gu f ae mu fx y f HW BP w p fc k&Sd&mq Da&mu fat mi f F9 u dkESdy fv kdu fy g/ y Hk( 7 5 ) /

y Hk( 7 5 )
., Registration number - .- ....._... ...._.
.

y Hk( 7 5 ) r Smaw GU&w Jh JE u aw mh polymorphic u k' faw Gu dk au smfv Tm; o Gm; w m aw GU&y gw , f/ ' Dae &mu dk
r Sw fo m; x m; y g/ w u , fv dkU u Re faw mfw dkU register v ky fw mr at mi fjr i f&i f ' Dae &mu dk patch v ky f&r Smr dkUv dkUy g/
F9 u dkx y fESdy fy g/ y Hk( 7 6 ) /
y Hk( 7 6 )
y Hk( 7 6 ) u dk Mu n fhr , fq dk&i f polymorphic u k' faw Gu kdx y faw GUy gw , f/ w u , fv dkUo m o i fht ae e JU
polymorphic u k' faw Gt aMu mi f; u dko m a&SUo i fc e f; p mw ke f; u r av hv mx m; c Jhb l; q dk&i f c kq dk&i f OD; aESmu fajc mu f
ae av mu fy gjy D/ ' Dw p fc gr Smv J JNZ [ m jump r jz p fw Jht w Gu f polymorphic u k' faw G[ m b maw Gv ky fo v J
q dkw m x y fav hv mMu n fhy gr , f/ y Hk( 7 7 ) /
y Hk( 7 7 )
y Hk( 7 7 ) u JMP ECX ae &mx da&mu fat mi f F8 u dkESdy f&i faw mhy Hk( 7 8 ) t w dki f; jr i f&y gr , f/
y Hk( 7 8 )
y Hk( 7 8 ) u 0012DEE5 ae &mx da&mu fat mi f F8 u dkESdy fv mc Jh&i faw mhy Hk( 7 9 ) t w dki f; jr i f&y gw , f/

y Hk( 7 9 )
., Registration number - .- ....._... ...._.
.

PUSH + RETN u aw mhJMP e JUn Dw mjz p fw Jht w Gu f F8 u dkESdy fr , fq dk&i f VA 004AED97 q Djump
v ky fo Gm; r Smjz p fy gw , f/ ' D VA 004AED97 u v Jx l; jc m; r Ir &Sdy gb l; / ' gaMu mi fh F9 u dkq u fEdSy fy g/ ' Dv dke JU
491C56? 49201F? 491ABB? 4918E8? 4ADF16? 4AEB94? 4AE4F8? 49444A? 469148? 4DA1C3?
4DF802 p w Jh hardware breakpoint aw Gu dk jz w fo e f; jy D; o Gm; w Jhae mu fr Smaw mh DAP &JU main window
ay : v mr Smjz p fy gw , f/ Main window r ay : c i fr Sm dump window u 5DCEA0 &JU byte w e fz dk; [ m 1 jz p f^
r jz p f p p fw mjz p fEdki fw , fv dkU c ke u u Re faw mfht jr i fu dkajy mc Jhy gw , f/ [ kw f?r [ kw f o dEdki fat mi fv dkU 4DA1C3 u dk
a&mu fc sde fr Sm 5DCEA0 &JUbyte w e fz dk; u dk1 v dkUjy i fMu n fhMu &at mi f/ y Hk( 8 0 ) /

y Hk( 8 0 )
y Hk( 8 0 ) t w dki f; jy i fjy D; c sde fr Smaw mh hardware breakpoint aw Gt m; v Hk; u dk jz Kw fv dku fjy D; y &dk* &r fu dk run
(F9) Mu n fhy g/ y Hk( 8 1 ) /

y Hk( 8 1 )
y Hk( 8 1 ) t &q dk&i faw mh t ajc t ae au mi f; y Hk&y gw , f/ Buy DAP q dkw Jht &ky fu av ; u t o u fr Jhae y g
w , f/ q dkv dkc si fw mu aw mh0 , fp &mr v dkaw mhy gb l; / Help menu u dkMu n fhy gr , f/ y Hk( 8 2) /

y Hk( 8 2)
y Hk( 8 2) u dk jr i f&w mu aw mh t m; &p &my gy J/ 4DA1C3 r Sm jy i fz dkUq Hk; jz w fv dku fw m r Se fo Gm; y gw , f/
' gaMu mi fh' Dae &mu dkpatch v ky fz dkU Mu dK; p m; Mu n hfy gr , f/ 4DA1C3 r Sm breakpoint (F2) o w fr Sw fjy D; y &dk* &r fu dk
jy e fp v dku fy g/ ( Ctrl+F2) / jy D; &i f F9 u dkESdy fv dku f&i faw mhy Hk( 8 3 ) t w dki f; jr i f&y gr , f/



., Registration number - .- ....._... ...._.
.


y Hk( 8 3 )
y Hk( 8 3 ) t w dki f; jr i f&w Jht c gr Smaw mhy Hk( 8 4 ) t w dki f; jy i f&y gr , f/

y Hk( 8 4 )
y Hk( 8 4 ) t w dki f; jy i fjy D; &i faw mhz dki fu dkESp fo u f&mt r n fe JUo dr f; v dku fy g/ y &dk* &r fau mi f; au mi f; t v ky fv ky f
y gv dr fhr , f/
p u m; r p y fajy m&r , fq kd&i faw mhBetaMaster u aw mh004ADF16 r Sm breakpoint &y fo Gm; jy D; ae mu fr Sm
dump window u 5DCEA0 &JU byte w e fz dk; u dk 01 v dkUjy i fc Jhy gw , f/ ' gq dk b mjz p fr v Jq dkw m Mu n fhv dku fMu &
at mi f/

y Hk( 8 5 )
y Hk( 8 5 ) r Smjr i f&w Jht w kdi f; ? e JU
w dkUay smu fo Gm; w m aw GU&y gw , f/ u se fw mu aw mht w lw ly Jjz p fy gw , f/ w u , fv dkU ' Dv dkjr i fc si f&i faw mhy Hk( 8 6 )
t w dki f; u k' fu dkjy i f&r Smjz p fy gw , f/

y Hk( 8 6 )
t ESp fc sKy fajy mjy &r , fq dk&i faw mhu Re faw mfw dkUt ae e JU DAP y &dk* &r fu dkv si fjr e fp Gm patch v ky fEdki fw m[ m
Resource Hacker &JU au s; Z l; aMu mi fhjz p fy gw , f/ PUSH 2718 ("DAP Unregistered") u dk &Smaz Gaw GU&Sdjc i f; u
DAP y &dk* &r fu dkpatch v ky fEdki fz dkUt q i fajy ap c Jhw mjz p fy gw , f/ DAP &JUy Hkr Se fv ky faq mi fc su fu aw mhPremium
version jz p fap z dkUt i fw me u fu dkt q u ft o G, fv ky fy gw , f/ o i f&dku fx n fhv dku fw Jhu k' fe JUt D; ar ; v f[ m r Se fu e fc Jh
r , fq dk&i f ' Du k' fe JU t D; ar ; v fw dkUu dk registry e JU dapreg8.key z dki fx Jr Smo dr f; q n f; r Smjz p fjy D; ae mu fw p fMu dr f y &dk
* &r fu dkjy e ft z Gi fhr Sm ' gaw Gu dk p p faq ; r Smjz p fy gw , f/ u Re faw mfw dkUu aw mh DAP y &dk* &r fu dk registry e JU
dapreg8.key z dki fw dkUu dk r p p faq ; ap aw mhb J v Sn fhp m; Edki fc Jhv dkU Premium version t jz p fo Hk; p GJEdki fw mjz p fy gw , f/
BetaMaster &JU dap-8.0.4.1-patch.exe z dki fu v J crack v ky f&mr Sm r sm; p Gmt ax mu ft u ljy Kc Jhy gaMu mi f; ajy m
Mu m; v dky gw , f/
ae mu fq Hk; t ae e JU o w day ; v dkw mu aw mhDAP 9.2 u dkArmadillo 5.40 e JU protect v ky fx m; w mjz p fjy D;
registration scheme [ mv J y dkjy D; t q i fhjr i fhv mw m aw GU&y gw , f/ DAP 9.2 u dk 20 0 9 ? Mo * kw fv ? 3 &u fr Sm
download v ky fx m; w mjz p fy gw , f/
., Registration number - .- ....._... ...._.
.

u Re faw mfht ae e JU Armadillo e JU protect v ky fx m; w mu dk unpack r v ky fc si faw mht w Gu f DAP 9.2
t w Gu f loader z dki fy Ja&; y gaw mhr , f/
Premium user jz p fz dkUb , fae &mr Sm jy i f&r v Jq dkw mu dkw e f; a&; r Sm jz p fy gw , f/

y Hk( 8 7 )
y Hk( 8 7 ) u u k' fu dky Hk( 8 8 ) t w dki f; jy i fy gr , f/

y Hk( 8 8 )
y Hk( 8 8 ) r Smjy i fw mu e r le mjy i fjy w my g/ w u , fjy i f&r Smu aw mhABEL loader r Smy g/

y Hk( 8 9 )
ABEL loader r Sm y Hk( 8 9 ) t w dki f; jy i fjy D; &i f loader z dki fu dkESp fo u f&mt r n fe JUo dr f; jy D; z Gi fhv dku fy g/ DAP
&JUHelp menu u About submenu u dka&G; v dku f&i faw mhy Hk( 9 0 ) t w dki f; jr i f&r Smjz p fy gw , f/

y Hk( 9 0 )
t c e f; ( 2 5 ) - Themida t m; a v hv mjc i f;
- 388 -

tcef;(25) - Themida tm;avhvmjcif;
a & SUo i fc e f; p ma w Gr Sm u Re fa w mfht a e e JU packer/protector a w G b , fv dkt v ky fv ky fo v Jq dkw mu dk
t Mu r f; z si f; a q G; a E G; c Jho v dk pack v ky fx m; w Jh z dki ft c sdKUu kdv J unpack v ky fjy c Jhy gw , f/ ' Dw p fc gr Sma w mh cracker
a w Gu dk ' ku t a y ; q Hk; ? cracker a w Gt w Gu f p dw ft a E Smi fht , Su fjz p f& q Hk; protector w p fc kjz p fw Jh Themida
t a Mu mi f; u dk a v hv mMu n fhy gr , f/ Themida & JU t v ky fv ky fy Hku dk o djc i f; t m; jz i fhThemida u dk b , fv dk unpack
v ky f& r , fq dkw mu dk o i fht a e e JU e m; v n fE dki fr Smjz p fw Jht w Gu f y x r q Hk; Themida t a Mu mi f; u dk t e n f; i , f
a q G; a E G; v dky gw , f/
( 1 ) Themida q dko n fr Sm . . .
Themida q dkw mu a w mh a q mhz f0 Jv fa w Gu dk crack v ky fjc i f; & e fu u mu G, fE dki fa t mi fv dkU Secure
Engine protection p e p fu dk o Hk; x m; w Jh protection p e p fw p fc kjz p fy gw , f/ Cracker a w Gt jr i ft & q dk& i fa w mh
Themida [ m o Hk; p GJa e u s a q mhz f0 Jv f protector a w Ge JU v Hk; 0 r w lb J u GJjy m; jc m; e m; a e y gw , f/ Developer
a w Gt w Gu fu a w mh Themida [ m v G, fu lp Gm t o Hk; jy KE dki fjy D; o lw dkUjz p fa p c si fw Jh t q i fhjr i fhw Jh protection
a w Gu dkv G, fu lp Gme JU a & G; c s, fE dki fy gw , f/ y Hk( 1 ) /

y Hk( 1 )
Advanced Anti-Debugger ' Doption u a w mh o i fh& JU application u dk debugger a w G& e fu u mu G, f
a y ; r Smjz p fy gw , f/ SecureEngine [ m debugger a w mfa w mfr sm; r sm; u dk ( user-mode e JU kernel-mode
debugger a w Gt y gt 0 i f) p Hkp r f; o d& SdE dki fy gw , f/
Anti Dumpers Protect v ky fx m; w Jha q mhz f0 Jv fa w Gt w Gu f t E & m, ft & Sdq Hk; tool a w Gx Ju w p fc ku a w mh
memory dumper a w Gjz p fy gw , f/ ' D tool a w Gu dk cracker a w Gu decrypt v ky fx m; w Jhu k' f ( o dkU) a ' w m
a w Gu dk r Sw fOmP fx Ju a e disk a y : r Smo dr f; q n f; z dkU t o Hk; jy KMu w mjz p fy gw , f/ ' Dha e mu f protect r v ky fc i fr Sm
& Sda e w Jht w dki f; r lv y & dk* & r f& JU w du sw Jh image u dkjy e fv n f& , lE dki fy gw , f/ ' D option u dka & G; c s, fjc i f; t m; jz i fh
Secure Engine u MemoryGuard e n f; y n mu dko Hk; jy D; r Sw fOmP fu a e disk a y : u dk dump v ky fjc i f; r S
u mu G, fa y ; y gw , f/
Entrypoint Obfuscation o lUu dka & G; c s, fx m; r , fq dk& i fa w mhSecureEngine u o i fhapplication & JU entry
point u dka & ma x G; o Gm; a p y gw , f/ Application x Jr Sm& Sdw Jhy x r q Hk; t v ky fv ky fw Jhinstruction a w G[ m Secure
Engine & JU u k' fa w Gjz p fy gv dr fhr , f/ ' Dv dk SecureEntryPoint e n f; y n mu dk t o Hk; jy Kx m; w Jht w Gu f cracker
a w Gu o i fh application & JU r Se fu e fw Jh entry point u dkr & & SdE dki fw Jht w Gu f crack v ky fz dkU& m c u fc Jo Gm; a p y gv dr fh
r , f/

t c e f; ( 2 5 ) - Themida t m; a v hv mjc i f;
- 389 -

Resources Encryption ' Doption u dka & G; c s, fx m; r , fq dk& i fa w mho i fhapplication u t o Hk; jy Kw Jhresource
a w Gu dk encrypt v ky fy gv dr fhr , f/ ' ga Mu mi fh cracker a w G[ m o i fh application & JU z GJUp n f; w n fa q mu fy Hku dk
a p mi fhr Mu n fhE dki fa w mhy gb l; / SecureEngine u resourece a w Gu dk v Hkjc HKp dw fc sa p z dkU v dkt y fr So m v dkt y fw Jh
resource a w Gu dkdecrypt v ky fr Smjz p fy gw , f/
VMWare/ Virtual PC ' D option u a w mh protect v ky fx m; w Jh o i fh application u dk VMWare e JU
Virtual PC w dkUv dkvirtual OS w p fc ka t mu fr Sm t v ky fv ky fE dki fa p z dkUjz p fy gw , f/
Advance API-Wrapping ' Doption u a w mh protect v ky fx m; w Jh o i fh application u t o Hk; jy Kw Jh API
t r sdK; r sdK; u dkc GJjc r f; p dp p fE dki fjc i f; r & SdE dki fa t mi f SecureAPIWrapper e n f; y n mu dk t o Hk; jy Kx m; y gw , f/
Anti-Patching ' D option u dk a & G; c s, fr , fq dk& i fa w mh protect v ky fx m; w Jh application u dk A dki f; & y fp f^
cracker^ t jc m; application a w Gu jy Kjy i fx m; jc i f; & Sd^ r & Sdp p fy gw , f/ w u , fv dkU t jc m; protector w p fc kc ku dk
x y fr Ht o Hk; jy Kz dkU & n f& G, fx m; & i fy Jjz p fjz p f? exe z dki f& JUu k' ft c sdKUu dk x y fr Hjy Kjy i fv dkw m& Sd& i fy Jjz p fjz p f Themida u
u k' fa w Gjy i fx m; jc i f; & Sd^ r & Sd t v dkt a v smu fp p fa q ; jc i f; u u mu G, fE dki fz dkU ' D option u dk None v kdUa & G; c s, fa y ;
x m; & y gr , f/ ' Dv dkr Sr [ kw f& i fa w mh Themida u error message u dkjy jy D; y & dk* & r fu dk c su fc si f; & y fq dki f; a p
y gr , f/
Metamorph Security ' De n f; y n mu a w mhapplication q Dprotect v ky fx m; w Jhu k' fa w Gu dk a y gi f; x n fhE dki fz dkU
SecureEngine u dkc Gi fhjy Ky gw , f/ ' D SmartMetamorph e n f; y n m[ m r l& i f; a w Gu dk a w Ga v hv mjc i f; & e fu
u mu G, fE dki fz dkU q i fw lu k' fa w Gt a e e JU a jy mi f; v Ja y ; jy D; a w Gu dkv Sn fhp m; y gw , f/
Advanced Debugger Monitors ' Doption u dka & G; c s, fv dku fr , fq dk& i fa w mh SecureEngine u t q i fhjr i fh
w Jh anti-debugging e n f; y n ma w Gu dk o i fh& JU application a w Gx J x n fho Gi f; r Smjz p fy gw , f/ ' gr So m cracker
a w G[ m o i fh& JUu k' fu dk a v hv mE dki fz dkU debugger a w Gu dk t o Hk; r jy KE dki fr Smy g/ SecureEngine & JU Debugger
Guard e n f; y n m[ m r Sw fOmP fr Sm t v ky fv ky fa e Mu w Jh debugger a w Gt m; v Hk; u dk p Hkp r f; o d& SdE dki fy gw , f/ t q Hk;
p Ge fa jy m& & i f kernel r Sm t v ky fv ky fa e Mu w Jhring 0 debugger a w Gu dka w mi f p Hkp r f; o d& SdE dki fy gw , f/
Compression SecureEngine u application w p fc ku dk protect v ky fc sde fr Sm t v Ge fMu D; r m; r sm; jy m; v Sw Jh
u k' fa w Gu dk application q Da y gi f; x n hfw mjz p fw Jht w Gu f o i fh& JU application u kd t & G, ft p m; Mu D; r m; a p r Sm
jz p fy gw , f/ Protect v ky fc sde fr Sm o i fh application & JU t & G, ft p m; Mu D; r m; jc i f; u u mu G, fE dki fz dkU ' Doption u dk
a & G; c s, fr , fq dk& i fa w mh application u k' f? resource a w Ge JU protection u k' fa w Gu dk compress v ky fa y ; r Sm
jz p fy gw , f/ SecureEngine [ m SmartCompression e n f; y n mu dk t o Hk; jy Kx m; w mjz p fw Jht w Gu f o lU& JU
decompression algorithm [ m o i hf application u dk r Sw fOmP fa y : u l; w i fw Jht c sde fr Sm application & JU
p Gr f; a q mi f& n fE Ie f; u dkx dc dku fa p r Smr [ kw fy gb l; /
Monitor Blockers o i fh application u z dki ft a jr mu ft r sm; ( o dkU) registry key a w Gu dk & , lo Hk; p GJc sde fr Sm
cracker a w G& e fu u mu G, fE dki fz dkU SecureEngine u MonitorBlocker e n f; y n mu dk t o Hk; jy Ky gw , f/
Cracker a w Gu registry key ( o dkU) z dki ft o Gi f; t x kw fa w Gu dk a p mi hfMu n fhw Jh ' Dtool a w Gu dk t o Hk; r jy KE dki fb l;
q dk& i fa w mh crack v ky fw Jht c gr Sm r Se fu e fw Jhq Hk; jz w fc su fu dk c sE dki fz dkU c J, Of; a p r Smjz p fy gw , f/ ( o i hft a e e JU trial
version a w Gt w Gu f trial o u fw r f; w p fc ku dk o w fr Sw fz dkUt w Gu f z dki fw p fc kr Sma & ; jc i f; ( o dkU) registry key
w p fc kt a e e JU o w fr Sw fjc i f; w dkUu dkjy Kv ky f& w mjz p fy gw , f/ )
Delphi/BCB form protection o i fht a e e JU o i fh& JU application u dk Delphi ( o dkU) Borland C++ builder
w dkUe JU a & ; o m; x m; w Jht c g o i fh application & JU form a w Gu dk u mu G, fz dkU t o Hk; jy Kw my g/ ' ga Mu mi fhr dkUv J o i fh
application t v ky fv ky fa e c sde fr Sm Delphi/BCB form a w Gu dk extract v ky fMu w Jh cracking tool a w Gu dk
SecureEngine u u s& IH; a p w my g/
( 2 ) SecureEngine q dko n fr Sm . . .
SecureEngine q dkw mu a w mh r su fa r Smu fa c w f cracking &