Exploiting Port 80 – Drupal
Drupal is a free and open-source web content management framework written in PHP and distributed under the GNU General Public License.
When browsing port 80 with Firefox, Apache will present you with a directory listing containing a number of entries:
data:image/s3,"s3://crabby-images/00f54/00f54b76d1a4dc0a35b9551fbc86f49eb8b9bc0d" alt="Port 80 directory listing Port 80 directory listing"
If you go back to the OpenVAS report, you will see a lot of potential on port 80:
data:image/s3,"s3://crabby-images/67102/67102c5da7e726dd2dc5330f5814ffba5f7ef7ac" alt="OpenVAS list of port 80 services vulnerabilities OpenVAS list of port 80 services vulnerabilities"
The first thing to do should be to identify Drupal’s version. Analyzing the source code for the Drupal page you can immediately get some information about the website’s structure, namely the fact that many things are coming from the drupal/modules folder.
data:image/s3,"s3://crabby-images/74d4a/74d4a19c892b353ee38951aa06f28215b40115b9" alt="Drupal webpage source code Drupal webpage source code"
Digging and researching online will lead you to the discovery of the blog.info file located inside the drupal/modules/blog folder.
data:image/s3,"s3://crabby-images/e9466/e946633211499ecff8d4f6fb8f22c5305334c78a" alt="Drupal version Drupal version"
Now you know Drupal is version 7.5
Exploiting Drupal using Metasploit
Searching inside MSF, you will find there are several modules available to use against Drupal:
data:image/s3,"s3://crabby-images/f96d4/f96d409fafabcdd40a7f86ff97b86c9bf337c07e" alt="List of Metasploit modules for Drupal List of Metasploit modules for Drupal"
Comparing this list with the vulnerabilities identified by OpenVAS will tell you exploits 2 and 3 are probably going to succeed.
Let’s try to exploit the SQL Injection vulnerability:
data:image/s3,"s3://crabby-images/bdb61/bdb614635ca6feb5053572acbd6fe3ff26603985" alt="Exploiting Drupal using Metasploit Exploiting Drupal using Metasploit"
This is a low privilege session…
NOTES:
- The targeturi was set to /drupal/ instead of root (/) because that is the Drupal directory on the Apache web server.
- This exploit is supposed to work only against Drupal 7.0 and 7.31 (the vulnerability was fixed in 7.32). The server apparently has version 7.5 and is still vulnerable.
Now let’s try to exploit the remote code execution vulnerability:
data:image/s3,"s3://crabby-images/a4364/a4364c87ac9081109d913c6cc18cdc9814ccf7e3" alt="Exploiting Drupal using Metasploit Exploiting Drupal using Metasploit"
And this is another low privilege shell…
Exploiting Port 80 – Payroll Application
Another interesting item is the file payroll_app.php. Clicking on it will load a Payroll Login interface.
data:image/s3,"s3://crabby-images/97797/97797208c739fd056a21923501c8517ad2d9ef76" alt="Payroll Login Payroll Login"
The Nmap scan identified a MySQL server running on Metasploitable3. Therefore, it might be a good idea to try a basic SQL injection attack. Let’s use the classic ' OR 1=1#.
data:image/s3,"s3://crabby-images/fb1fb/fb1fba4f84575f67335b4db1182757be71054016" alt="Trying basic SQL injection Trying basic SQL injection"
Clicking the Ok button with the classic injection string in the User input box will immediately reveal a total of 15 users in the Payroll App.
data:image/s3,"s3://crabby-images/f4138/f41387f0a3671d2a4646d0009495a45475ddd1a3" alt="Successful SQL injection Successful SQL injection"
This could be the beginning of a real SQL Injection attack but instead I went after the code for the Payroll app. I remembered the file was listed in a previous exploit, namely ProFTPD. So, I repeated the exploit and investigated the contents of the file payroll_app.php.
data:image/s3,"s3://crabby-images/00cad/00cad146a40c192e02f89614664fac73d42a838e" alt="Credentials inside the payroll_app.php file Credentials inside the payroll_app.php file"
These appear to be the credentials for the Payroll application but they are not…
data:image/s3,"s3://crabby-images/5731f/5731fb91e645a51b35d1baf7b643464f10a45510" alt="Payroll failed logon Payroll failed logon"
However, let’s not forget about these credentials as they might still be useful.
Exploiting Port 80 – phpMyAdmin
Opening the phpMyAdmin link will take you to the service login page:
data:image/s3,"s3://crabby-images/3af26/3af2689b5523903bfebe09e5c22dbdbfe18e73fa" alt="phpMyAdmin login page phpMyAdmin login page"
Brute forcing phpMyAdmin using Hydra
Brute forcing this service requires a bit of research but nothing special. You can use the wordlists provided with Kali, or you can add the previous credentials to the customized wordlists.
data:image/s3,"s3://crabby-images/93a96/93a96276a63d76bd0788cae1d57cd050b01a7da2" alt="Brute forcing phpMyAdmin using Hydra Brute forcing phpMyAdmin using Hydra"
The credentials are valid for the phpMyAdmin service!
Brute forcing phpMyAdmin using Metasploit
There is a scanner module to use against phpMyAdmin but it’s broken and therefore completely useless:
data:image/s3,"s3://crabby-images/528dc/528dc86ced1c3f6156d1ddb6225e5a1db7981c4b" alt="Brute forcing phpMyAdmin using Metasploit Brute forcing phpMyAdmin using Metasploit"
Exploiting phpMyAdmin using Metasploit
The phpMyAdmin web application running on Metasploitable 3 has a remote code execution vulnerability which can be exploited using the phpmyadmin_preg_replace module:
data:image/s3,"s3://crabby-images/3aee6/3aee66a6c245f9bfe26da6a45e283a9ae3014625" alt="Exploiting phpMyAdmin using Metasploit Exploiting phpMyAdmin using Metasploit"
Unfortunately, something went wrong with this exploit. It might be a simple thing but I decided not to waste time investigating it. Instead, I tried to use the previously collected credentials…
data:image/s3,"s3://crabby-images/0b359/0b35915d41b34334d4d9249ace8192d2d0123313" alt="Exploiting phpMyAdmin using Metasploit Exploiting phpMyAdmin using Metasploit"
It worked! The created session is a low privilege one, but this means the credentials are valid for phpMyAdmin. Therefore, instead of using them inside MSF, why not use them directly in the phpMyAdmin login page?
data:image/s3,"s3://crabby-images/b2f52/b2f5290c7db41263e191ac072835a7fa48076a28" alt="Inside the phpMyAdmin dashboard Inside the phpMyAdmin dashboard"
From here, everything is your disposal. Take a look at the users table inside the payroll database:
data:image/s3,"s3://crabby-images/bd97e/bd97e2b1e05377a14e0983e19b7b1eec403ce9ec" alt="The payroll database The payroll database"
You still need to get root access to the target, so why don’t you add all this information to your user/pass custom wordlists and try to brute force SSH again?
data:image/s3,"s3://crabby-images/ad20a/ad20a2f311e62f3dd2d7d433f94e3cfe75d9768d" alt="Brute forcing SSH with the new credentials Brute forcing SSH with the new credentials"
It works! All these accounts have SSH access and on top of that, Leia, Luke, and Han all have sudo privileges so some of these sessions have root access to the target machine.