Modern Binary
Exploitation Writeups-0x02
This is the 2nd 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 ➡️
crackme0x00b
Information gathering using the file command
$file crackme0x00b
data:image/s3,"s3://crabby-images/e1076/e10760b741af1ceabc48c19b49f0a7deebe130ed" alt=""
Information gathering using the rabin2 tool.
$rabin2 -I crackme0x00b
data:image/s3,"s3://crabby-images/f8c13/f8c13060f011b0ff0ecdaa200f859cfd8dfe7a7e" alt=""
data:image/s3,"s3://crabby-images/4e2ce/4e2ce9b8c86a96681f353d0849d4f9956614fc64" alt=""
The given crack me is 32 bits and little endian, make a note of this it will help to find out the way to crack.
Cracking the file using strings
$strings -e L crackme0x00b
data:image/s3,"s3://crabby-images/56615/56615a7efe02044dd2cfd919d16a238286ead375" alt=""
data:image/s3,"s3://crabby-images/0f687/0f6870231b8968b6b5b02b06a34a254ada6e7032" alt=""
data:image/s3,"s3://crabby-images/b9d0c/b9d0cc251c25925c7cc653202a1549f6a633e472" alt=""
Cracking the file using xxd
$xxd crackme0x0b
data:image/s3,"s3://crabby-images/322e2/322e21f71f69e01afa301babdecdb1c2d19143d5" alt=""
data:image/s3,"s3://crabby-images/e6d5b/e6d5bdf31dc9ffbd1ff604c6196a79bed2857301" alt=""
data:image/s3,"s3://crabby-images/b9d0c/b9d0cc251c25925c7cc653202a1549f6a633e472" alt=""
Cracking the file using rabin2
$rabin2 -z crackme0x00b
data:image/s3,"s3://crabby-images/45749/457493c3bded1a5f5e8621f0283c68103cf98f93" alt=""
data:image/s3,"s3://crabby-images/b0c21/b0c21fb689ecbec39c75e4b21d17d62be2ce7c7d" alt=""
data:image/s3,"s3://crabby-images/b9d0c/b9d0cc251c25925c7cc653202a1549f6a633e472" alt=""
Cracking the file using radare2
$radare2 crackme0x00a
[0x080483e0]> aaa
[0x080483e0]> pdf @ main
- aa:-analyze all.
- aaa:- analyze all with more info.
- pdf:- print disassemble function.
data:image/s3,"s3://crabby-images/21040/21040b4d3ab6c41678fe8f4cb50e2500d7244784" alt=""
wcscmp() use *s1 and *s2 variable s1 is pointing to w0wgreat and s2 is the input strings.
data:image/s3,"s3://crabby-images/00a6f/00a6f93a3160130227c5722a0a318f59fd3e8d25" alt=""
data:image/s3,"s3://crabby-images/b9d0c/b9d0cc251c25925c7cc653202a1549f6a633e472" alt=""
Cracking the file using gdb-peda
gdb-peda is like an addon for gdb, you can install it from GitHub.
$gdb crackme0x00a
>gdb-peda$ disassemble main
disassemble main will show the main function of the binary.
gdb-peda$ break *0x080484ce
data:image/s3,"s3://crabby-images/1d12a/1d12a7fcd4a73ec3d8c9bdb72fc21d5259d01659" alt=""
gdb-peda$ run
data:image/s3,"s3://crabby-images/2f4cc/2f4ccbf8ec9e0e1cfd46332a82cc5c8b26028228" alt=""
gdb-peda$ ni
ni or nexti — execute calls as one instruction.
data:image/s3,"s3://crabby-images/9e7e2/9e7e2f92cd52e897275d02c8ea6feb25204dc916" alt=""
gdb-peda$ telescope $edx
The telescope view shows stack values, and also attempts to dereference pointers which may be pointed to by the stack.
data:image/s3,"s3://crabby-images/d46ef/d46ef04e718f641bca3ef8e7329757a32b3e883a" alt=""
There is one more way to do that above thing
gdb-peda$ x/25s $edx
x/ :- show bytes
25:- how many we want to show
s:- as a strings
$edx:- this refers to the register
data:image/s3,"s3://crabby-images/1f349/1f3492b593042f1fe5bc282857d161ffeb4aca2f" alt=""
data:image/s3,"s3://crabby-images/b9d0c/b9d0cc251c25925c7cc653202a1549f6a633e472" alt=""