HTB - Find the easy pass
Overview
Challenge | Find the easy pass |
Rank | Easy |
Time | 45min |
Category | Reverse Engineering |
Quick solve
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# download the required zip file
ls
'Find The Easy Pass.zip'
# unzip the file with the given password
unzip Find\ The\ Easy\ Pass.zip
Archive: Find The Easy Pass.zip
[Find The Easy Pass.zip] EasyPass.exe password:
inflating: EasyPass.exe
ls
EasyPass.exe 'Find The Easy Pass.zip'
# check file type
file EasyPass.exe
EasyPass.exe: PE32 executable (GUI) Intel 80386, for MS Windows, 8 sections
# create a hex dump and write it to a file
xxd EasyPass.exe > bin_code
# read file with sublime
subl bin_code
Search for “password” in Sublime.
data:image/s3,"s3://crabby-images/47288/472884ea5b28268f747e9607fc38fef509597cab" alt="Searching for the string 'password' in Sublime"
Since ‘fortan!’ gave ‘Wrong Password!’, I tried ‘fortran!’ which is a general-purpose programming language and it worked!
Proper solution
Taken from haxez.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# check file permissions
ls -l
total 2280
-rw-r--r-- 1 kali kali 402432 Jul 3 2017 EasyPass.exe
-rwxrwxrwx 1 kali kali 210291 Nov 28 14:02 'Find The Easy Pass.zip'
# give execute permissions to .exe
sudo chmod +x EasyPass.exe
# check again to confirm that .exe has execute permissions
ls -l
total 2280
-rwxr-xr-x 1 kali kali 402432 Jul 3 2017 EasyPass.exe
-rwxrwxrwx 1 kali kali 210291 Nov 28 14:02 'Find The Easy Pass.zip'
# run the program
./EasyPass.exe
data:image/s3,"s3://crabby-images/8cbc8/8cbc87110c5b7888e888b06cc851e0854f15a3a6" alt="Program launched"
1
2
# launch ghidra
ghidra
Ghidra is a reverse engineering tool, aka a disassembly tool, that was developed by the NSA and released in 2019 (Ghidra quickstart & tutorial: Solving a simple crackme).
Search for the string ‘password’:
data:image/s3,"s3://crabby-images/f4932/f4932f0e1ae382f949ea36362c20cfba51e23466" alt="String search"
data:image/s3,"s3://crabby-images/73bc5/73bc5cb3acc48b9027c6f99c037ce92008731864" alt="'Password' string search"
Click on ‘Wrong Password’ (memory reference: 00454200
) and check References from main app:
data:image/s3,"s3://crabby-images/96d59/96d59cdadf25d0e30836ef6ba95f47d07d7e123b" alt="Checking references"
data:image/s3,"s3://crabby-images/7d9d5/7d9d5d528fda6a0f9313f4d141228bb354d81a1a" alt="Memory location's references"
Repeat above step (memory ref: 00454144
) and click on the Function Graph icon (top bar):
data:image/s3,"s3://crabby-images/bdb31/bdb315a11493213a387ca20ee7103e8f0ad35528" alt="Function Graph"
The above represents an if
statement and the green arrow indicates that the function executed the second box (00454144
). The last function call was FUN_00404628
. Click on the function and check back on the main window (mem ref: 00454131
):
data:image/s3,"s3://crabby-images/e38ce/e38cea1ff63b07f7bfeedd71b0a23dd8b6b6c508" alt="Function's memory reference"
Double-click the function to reveal its logic. It takes 2 parameters, param_1
and param_2
, and then compares them. So we can ‘safely’ assume that one of them would be the correct one:
data:image/s3,"s3://crabby-images/c2719/c2719130f650bc127f7a0fad749c51f1f957298b" alt="Function's logic"
We need to find out what is stored inside these parameters. Open .exe
with ollydgb
, find function’s mem ref and toggle a breakpoint:
data:image/s3,"s3://crabby-images/690d8/690d865bbc92617672a9e5b4109061df6c3f9ec4" alt="Toggle breakpoint"
Now click the Play button on top and check the registers on the right-hand side:
data:image/s3,"s3://crabby-images/99dfb/99dfbe1739ba424b4b20d20312f3ce6fc49f4e95" alt="Toggle breakpoint"
data:image/s3,"s3://crabby-images/48f15/48f15b58010e98791afdac5010ccd6a6d81872ae" alt="Challenge pwned"