TryHackMe is an online platform that teaches Cybersecurity through hands-on virtual labs. Whether you are an expert or beginner, learn through a virtual room structure to understand theoretical and practical security elements.
data:image/s3,"s3://crabby-images/03df1/03df180b6ce4df1dd0483bd0daf4b0b8ea8aefaa" alt=""
Thompson is an easy room on TryHackMe for beginners to explore.
You have to first signup to join the room. There are few simple steps that you can follow in the Signup page. Next follow the steps in the Welcome room to configure the VPN connectivity.
I have connected to TryHackMe network using OpenVPN on Kali Linux. Once you connect, the access page will confirm the status by confirming your IP address and status. Join the room to access it's contents.
data:image/s3,"s3://crabby-images/6fb3c/6fb3c8d604b0da59943c5d7e5e4c7a3077528453" alt=""
Click on Deploy to start the Vulnerable target machine.
data:image/s3,"s3://crabby-images/61b99/61b995930ab653abb85d4d1225097ad4ad57cd63" alt=""
The IP address of the target is displayed.
Start Enumeration using nmap. The -sV option will do a service fingerprinting too.
data:image/s3,"s3://crabby-images/7bdf7/7bdf7ea6975e5902c1edaaf6f1c60677a50be587" alt=""
We can see that the nmap scan has revealed that port 22 and port 8080 are open. Open SSH is running on port 22 and Apache Tomcat is running on port 8080.
Explore the Apache Tomcat service using a web browser.
data:image/s3,"s3://crabby-images/22cbb/22cbbb3593cd8022c5b7b31e1b8d2e2cd8b03833" alt=""
The home page of the Apache Tomcat could be seen. Run nikto scan to check for vulnerabilities.
data:image/s3,"s3://crabby-images/ef730/ef730aa14b4341efd10337cf445b674620bed66c" alt=""
There are many vulnerabilities found, Default account for Tomcat Manager is also found in the nikto scan. Also run gobuster to scan for directories under this URL.
data:image/s3,"s3://crabby-images/73e8b/73e8bc3a5893c24d02e491d761a49a7eeff3fb48" alt=""
The gobuster too revealed the manager page. Visit the /manager page.
We can see the default credentials for manager-gui on this page.
data:image/s3,"s3://crabby-images/30e27/30e27165a1a15329365c5ae9036457441cedc73c" alt=""
Try to login into the manager-gui using this credentials.
data:image/s3,"s3://crabby-images/a9b50/a9b5033e54c3d40affab67501c62cd4fe6fe610c" alt=""
You can also run user enumeration scan for Metasploit.
Open msfconsole and search for tomcat. A number of options will appear.
data:image/s3,"s3://crabby-images/c29bf/c29bfbfcd475c17388468ff9f5724a19839b00fc" alt=""
data:image/s3,"s3://crabby-images/bbd91/bbd91d3d49cb36e6476dfdf29c3560fedc1bf3ce" alt=""
Select the 9th option in the list. That is index 8. so the command would be use 8. Set the RHOST IP and RPORT number. That is Target host IP and Target port number.
data:image/s3,"s3://crabby-images/8fa30/8fa303b247af33f5dc8f18b9359ea7a538e6a453" alt=""
Set the target URI of host-manager. Then use the command run and check the users found by the scanner.
data:image/s3,"s3://crabby-images/8399d/8399da021db5207ee32797e9ccbb8a82bbd0440b" alt=""
Since you already know the user tomcat and it's default password, you can run an exploit from Metasploit for manager upload.
data:image/s3,"s3://crabby-images/2292a/2292ae0335f14b0fe258dd448edeb7be50cbd924" alt=""
Select the tomcat_mgr_upload exploit by using the command use 17. The command show options will give you all the parameters that need to set in order for the exploit to work. set all these options as shown. Your RHOST and LHOST IP and port may vary. RHOST is the target host IP address and LHOST is the listening host(tun0 interface IP address on my Kali VM in my case).
Once all the options are set, use the command exploit
data:image/s3,"s3://crabby-images/fdee0/fdee02115361f19812b3c669e336cd3e4cde1560" alt=""
You have successfully obtained a meterpreter session. Run the command shell to get a CLI of the target host and use Python tty command as shown to get a more stable shell.
data:image/s3,"s3://crabby-images/8ffd9/8ffd9431314f7cc23b899e91b4b4fd6c7be92cd5" alt=""
Navigate to the user's home directory to find the user flag.
data:image/s3,"s3://crabby-images/51bb6/51bb6b8ad09aa808b69bb43eed10dd1e5225fa4f" alt=""
Validate the user flag on TryHackMe.
Notice that there is a script in the user's home directory and probably that is utilized by root as well. Try updating the script with your own command to escalate the privilege of current user.
data:image/s3,"s3://crabby-images/c366b/c366b6c3ed966b6b6d871e62354b56c83206df87" alt=""
I am just updating a command in script to just copy the contents of root.txt to the user's home directory. Whereas you can try updating the script to give you a root shell.
data:image/s3,"s3://crabby-images/ab3d0/ab3d0ab5df23ad7c00ae8bc27bf0c5abf23cb47e" alt=""
After a while the root.txt appeared on user's home directory.
data:image/s3,"s3://crabby-images/60599/605991f43b74da02184e9839e3d7d046f7b84446" alt=""
Validate the flag on TryHackMe.
data:image/s3,"s3://crabby-images/b30ab/b30ab18dc5df79f9a5a59d7bcf28353f1bacabc4" alt=""
I hope this write-up was informative for you. Please leave a feedback. Thank you
-Srivathsa Dhanvantri
Comments