In this writeup I will show you how I solved The Needle challenge from HackTheBox. The challenge is a very easy hardware challenge. Let’s start!
Initial Analysis #
After downloading and unzipping the file we can see that there is only one file, firmware.bin
. We can use the file
command to see what kind of file it is.
file firmware.bin
firmware.bin: Linux kernel ARM boot executable zImage (big-endian)
Binwalk #
To analize the file we can use the binwalk
command. If we use the -e
the program will extract the files from the firmware.
binwalk -e firmware.bin
As we can see now we have a new folder called _firmware.bin.extracted
. Let’s go inside and see what’s inside.
The folder is full of files and folders and it’s a bit confusing. We can use the grep
command to search for the username and password. The command we will use is:
grep -rn "./" -e login
The -r
flag is for recursive search and the -n
flag is for printing the line number. The ./
is for searching in the current directory. The -e
flag is for searching for a specific string. The string we are searching for is login
. The output of the command is:
data:image/s3,"s3://crabby-images/00981/0098100be0b3fdf0e194841a7ef69c521bb28c19" alt=""
If we read carefully we can see that maybe we have found the username Device_Admin
. Now we need to find the password, we can use the command:
find ./ -name sign
In this case we are using the find
command. The -name
flag is for searching for a specific file name. The file name we are searching for is sign
. The output of the command is:
data:image/s3,"s3://crabby-images/f2e31/f2e31e45688b8dd60ba9689ae31dd8f0b349c2a8" alt=""
Bingo! We have found the password this the password:
data:image/s3,"s3://crabby-images/b19e7/b19e736bc5ebbef55ab935b3c7235573936ada82" alt=""
Now we can try to login using these credentials. To do that we can use the ip address of the machine that is provided by HTB (<IP_address>:
nc <IP_address> <port>
data:image/s3,"s3://crabby-images/6836b/6836b3905c40fe098e7e1734dcabd17c6a06f296" alt=""
Conclusion #
Now we need to use the credentials to login to the machine, and explore what’s inside. We will easly find the flag in a file called flag.txt
.
data:image/s3,"s3://crabby-images/1c290/1c290e1415a28f640bab7206ae9d91e0c993b515" alt=""