Command Injection (IV): Webshell -> Msfvenom / Meterpreter
- Layout for this exercise:
data:image/s3,"s3://crabby-images/87b13/87b137445771ec475f2039ff746f23e968fe11dc" alt=""
- This exercise is based on the previous one:
http://www.whitelist1.com/2018/04/command-injection-attack.html
- The goal of this exercise is to achieve a meterpreter session by injecting a PHP webshell through the attacker's URL browser.
- First of all, let's have a look at options of the reverse_tcp, available with Metasploit:
data:image/s3,"s3://crabby-images/f39b8/f39b8fa4e407cced401966b0928cee487a12e765" alt=""
- The only option required is LHOST, corresponding to the attacker's IP.
- Based on this payload, msfvenom generates the webshell pm.php:
data:image/s3,"s3://crabby-images/57146/571466adfc566b94506541b09862203eb010c37b" alt=""
data:image/s3,"s3://crabby-images/f4bb1/f4bb1dcc979f15f5a591d401c5baa3e9c4136ded" alt=""
- Opening the file, there are a couple of characters /* that must be removed to make the PHP script executable:
data:image/s3,"s3://crabby-images/9293c/9293c6285616f9b3f6e97341423489204ec34a16" alt=""
data:image/s3,"s3://crabby-images/43d41/43d41253d78cb08cfd0c45c7d6fabe314fb54c1a" alt=""
data:image/s3,"s3://crabby-images/d37ed/d37ed8cedbe87dc287409846cbdc06c2c4543a77" alt=""
- At the attacker's side, let's open a SimpleHTTPServer listening on port 8000:
data:image/s3,"s3://crabby-images/606b9/606b9aacc21ece965d2620a7dc3a0f11580766ce" alt=""
- Now, it is time to launch the attack using the wget command with -O indicating the folder where to allocate the output, in this case the folder /tmp.
- Why the folder /tmp? because it is a usual writable folder in most systems, what helps to bypass the problem of finding a writable area of memory where to store our malicious webshell pm.php:
data:image/s3,"s3://crabby-images/2e862/2e86276c9b0495260fcf77e3e096f4a479cdd015" alt=""
- At the attacker's side, the successful transaction is registered:
data:image/s3,"s3://crabby-images/3a8ba/3a8ba34e63f10a764aba5797346d2bfe55fd6f8f" alt=""
- Also, the attacker Kali can check that this phase of the attack goes well, locating the transferred webshell pm.php at the folder /tmp:
data:image/s3,"s3://crabby-images/44115/44115d38f49395b09c3169d8cbbe38e81de50edc" alt=""
- Before running the webshell, let's open a listening session at the attacker's side (IP 192.168.1.10 on port 4444) with a Metasploit handler:
data:image/s3,"s3://crabby-images/426b9/426b9fe7772ac7a8fe943ca4cc1a4ca93095041a" alt=""
data:image/s3,"s3://crabby-images/ef8c5/ef8c5e46bd24b5fa54a439a97bdc731f55197dd2" alt=""
- Finally, executing the webshell pm.php with the command php -f:
data:image/s3,"s3://crabby-images/b0522/b0522945e94781877d206bfb71c83c2017a0a028" alt=""
- The attack is successful because a meterpreter session is immediately achieved as a consequence of running the webshell:
data:image/s3,"s3://crabby-images/4840e/4840ea5fc3f09b0573e0e5c59a05595b0142b35d" alt=""