| Type | software |
| Product Environment | web |
| Product Name | JSPWiki |
| Product Vendor | Apache Software Foundation |
| Product Version | 2.12.3-git-04 |
| Product Link | https://jspwiki.apache.org/ |
| Vulnerability Name | Cross-Site Scripting |
| Severity | High |
|
CVSS String
|
CVSS:3.1/AV:N/AC:L/PR:L/UI:R/S:C/C:H/I:H/A:N |
| CVSS Score | 8.7 |
| CVE ID | CVE-2025-24854 |
| Vendor Acknowledgement | Yes |
|
Affected digital Assets
|
1 |
|
Affected Users
|
1000 |
| Date of Reporting | Jan 21, 2025 |
| PoC Exploit | - |
| Credit | 0xhamy |
Apache JSPWiki v2.12.3-git-04 is vulnerable to stored cross-site scripting (XSS) in comments and page edits.
Attackers can use the Image plugin macro to embed a data: URL pointing to an SVG that executes JavaScript. The payload is stored and runs whenever a victim views the affected page or comment, enabling session theft, privilege misuse, and misleading UI/redirects.
The endpoints:
/JSPWiki/Edit.jsp?page=…/JSPWiki/Comment.jsp?page=…accept user-supplied macros/plugins. The Image plugin renders data:image/svg+xml;base64,… sources without sanitizing active SVG content (e.g., onload).
Because rendering occurs in the JSPWiki origin, any authenticated viewer (including admins) who loads the page executes attacker-controlled script. The impact escalates if an attacker can impersonate or socially engineer an admin to view the malicious content.
Open an editable page or the comment form.
…/JSPWiki/Edit.jsp?page=Install.jsp…/JSPWiki/Comment.jsp?page=PageIndexInsert an Image plugin with a base64-SVG payload.
Example macro (line breaks for clarity):
[{Image
src=''
caption='Testing Image'
style='font-size:120%; color:green;'}]
View the page/comment.
The embedded SVG executes (e.g., alert('xss')).
Decoded SVG used above:
<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200"
onload="alert('xss')">
<rect width="200" height="200" fill="lightblue"/>
</svg>
data: SVGs; strip event handlers (on*), scripts, and external refs when rendering macros.Image plugin sources to vetted schemes/MIME types (e.g., https raster only) and validate against an allow-list.img-src/object-src/frame-src; consider serving user content from a separate origin.