Modern Binary
Exploitation Writeups-0x04
This is the 4th writeup of Tools and Basic Reverse Engineering by RPISEC, a subpart of Modern Binary Exploitation Course.
Link of lectures:- http://security.cs.rpi.edu/courses/binexp-spring2015/
All the lecture materials and other necessary files are available on the above link to check it out.
⬅️ Previous writeup__________________________________ Next WriteUp
crackme0x02
$ ./crackme0x02
data:image/s3,"s3://crabby-images/d9782/d9782b374b3e35e0176a66e66d8e8590ab619838" alt=""
Information gathering using the rabin2 tool.
rabin2 -I crackme0x02
data:image/s3,"s3://crabby-images/28057/280575dc66d6eee4a4b55408727b9ecda6efa6a6" alt=""
data:image/s3,"s3://crabby-images/18a5a/18a5a19bd37384c0a77a0551619e38841562bfc7" alt=""
Cracking using radare2
radare2 crackme0x02
[0x08048330]> aaa
[0x08048330]> pdf @ main
- aa:- analyze all.
- aaa:- analyze all with more info.
- pdf:- print disassemble function.
data:image/s3,"s3://crabby-images/b94f6/b94f67802b64f6386884ddfc3a66f16a427db265" alt=""
[0x08048330]> dr
dr:- prints the data register with values.
data:image/s3,"s3://crabby-images/886ea/886ea648090e19da3f5b2d30fb82b472ab1a102d" alt=""
It shows the eax with ‘0’ which is not right it must contain some value. radare2 analysis the binary in the static mode so we have to use radare2 debug mode so that we can set the breakpoint in between the program and find out more.
Cracking using radare2 debug mode
$radare2 -d crackme0x02
data:image/s3,"s3://crabby-images/c9bee/c9bee11441f8307d928fa01065690ec71f20141f" alt=""
- aa:- analyze all.
- aaa:- analyze all with more info.
- pdf:- print disassemble function.
data:image/s3,"s3://crabby-images/66be0/66be0ed61f5ee8b58091fac3cea8a0bbf2ebbdfd" alt=""
data:image/s3,"s3://crabby-images/18b81/18b8118f5815126279115d2a4d67b4ced39833be" alt=""
At address ‘0x0804844e’ there is cmp instruction so lets set the breakpoint there.
data:image/s3,"s3://crabby-images/c8e54/c8e54eed0ebe9823670fa028cf6519b6b1a6f182" alt=""
- db flag:- place a breakpoint at a flag, where the flag can be either an address or a function name.
- dc :- run the program.
cmp eax, dword [local_ch], Now let’s try to find out the value of $eax register and local_0xc.
Finding the value of eax.
[0x0804844e]> ? eax
data:image/s3,"s3://crabby-images/9f8b9/9f8b902f2ba6a8c99bec2c0c984626f478297e96" alt=""
There is one more way to get the value of eax register.
[0x0804844e]> dr eax
[0x0804844e]> ? 0x00000539
- dr flag:- prints the data register value.
data:image/s3,"s3://crabby-images/f1436/f143689fdd83c2287a1ab92ac0597ca2a050204d" alt=""
Finding the value of local_ch.
[0x0804844e]> afvd local_ch
[0x0804844e]> pxr $w @ebp-0xc
[0x0804844e]> ? 0x00052b24
- afvd:- afvd name output r2 command for displaying the value of args/locals in the debugger.
data:image/s3,"s3://crabby-images/3a68b/3a68b7ff14296f0301666413b6563c9238739a71" alt=""
Another way of finding the value of local_ch.
[0x0804844e]> afvd
[0x0804844e]> ? 0x00052b24
- afvd:- afvd name output r2 command for displaying the value of args/locals in the debugger.
data:image/s3,"s3://crabby-images/b7c5d/b7c5dac9f7abf57b5e192f1fdf0f98ea6a903fd1" alt=""
data:image/s3,"s3://crabby-images/888ef/888ef9fcb3711dc36e5964a7dcb5b07fcfa16894" alt=""
Cracking using gdb
$gdb crackme0x02
gdb-peda$ disassemble main
data:image/s3,"s3://crabby-images/b1de2/b1de282cab0d8ac932344489ba2c49b4ad9a9c22" alt=""
gdb-peda$ break *0x0804844e
data:image/s3,"s3://crabby-images/490c3/490c3aea391ef7b7581e5ffa1f00e49508c76f41" alt=""
data:image/s3,"s3://crabby-images/a83a6/a83a6024ee420569547e90bb3c6b2c30891e2a11" alt=""
cmp eax,DWORD PTR [ebp-0xc]
- eax:- eax register contains 0x539, 0x shows that it’s in hex.
- DWORD:- It refers to the double word, doubleword is 32 bit or 4 bytes(8 bit =1 byte).
- PTR:- Abbreviation of Pointer.
- ebp-0xc:- 0xc(12 in decimal) is subtracted from ebp(Base pointer).
So in this instruction eax is compared to the word(number) which is stored in the address ebp-0xc.
Let’s find out what is stored in eax and ebp-0xc.
From the above image, eax show the value 0x539
p/d 0x539
- p:- print command (abbreviated p).
- d:- Print as an integer in signed decimal.
data:image/s3,"s3://crabby-images/cd144/cd144ce8dbbaaeec8da6d0680342f7e21e210fff" alt=""
1337 is stored in the $eax, which we give as an input.
gdb-peda$ x/x $ebp-0xc
0xffffd1ec: 0x00052b24
gdb-peda$ p/d 0x00052b24
$9 = 338724
x command is used to eXamine.
- /x:- prints address $ebp and the contents at that address in hex.
p command is used to Print.
- /d:-print contents as a decimal.
data:image/s3,"s3://crabby-images/2127f/2127febc3e8e69ede11e3b83937d73896bb59f69" alt=""
$./crackme0x02
data:image/s3,"s3://crabby-images/888ef/888ef9fcb3711dc36e5964a7dcb5b07fcfa16894" alt=""
Converting ‘0x00052b24’ using python
python -c "print 0x00052b24"
data:image/s3,"s3://crabby-images/cb91a/cb91a901c154d36c2bf10c41feb259074dcc2e68" alt=""
Converting ‘0x00052b24’ using rax2
rax2 0x00052b24
data:image/s3,"s3://crabby-images/b1cd3/b1cd3ca10b813ba5b330e01e14c2eaeeae385c1e" alt=""
data:image/s3,"s3://crabby-images/9b53d/9b53df10a1268fbedf7155f431441d8c2327d8c6" alt=""