Server side cross-site scripting In github.com/gtsteffaniak/filebrowser
Description
FileBrowser Vulnerable to Stored XSS via SVG File in Public Share (Missing CSP Header)
Summary
FileBrowser Quantum serves inline SVG files without a Content-Security-Policy header, allowing embedded JavaScript in SVG files to execute when accessed via public share links.
Verified on v1.3.0-stable.
Affected product
Product: FileBrowser Quantum (gtsteffaniak/filebrowser)
Verified version: v1.3.0-stable
Docker image: gtstef/filebrowser:latest
Affected endpoint: GET /public/api/resources/download?hash=HASH&inline=true
CWE: CWE-79 — Cross-site Scripting (Stored)
Impact
Stored XSS — Malicious SVG persists and executes for every visitor to the share link
No authentication required to trigger — Public share links are accessible to anyone
Session hijacking — If authenticated users click the link, their session can be stolen
Phishing — Attacker can redirect or overlay fake login forms
Reproduction
Login as any user with upload permission
Upload SVG file:
<svg xmlns="http://www.w3.org/2000/svg"> <script>alert(document.domain)</script> </svg>
Create public share for the file
Access the share link with ?inline=true
JavaScript executes in browser
Root cause
The inline download endpoint returns SVG files with:
Content-Type: image/svg+xml Content-Disposition: inline; filename="xss.svg" X-Content-Type-Options: nosniff
But no CSP header to block script execution. The upstream project (filebrowser/filebrowser) mitigates this with:
Content-Security-Policy: script-src 'none'
Suggested fix
Add CSP header on inline file downloads:
w.Header().Set("Content-Security-Policy", "script-src 'none'")
This matches the upstream filebrowser/filebrowser implementation.
Mitigation
Update Impact
Minimal update. May introduce new vulnerabilities or breaking changes.
Ecosystem | Package | Affected version | Patched versions |
|---|---|---|---|
go | 0.0.0-20260501184955-6bfc3974192e |
Aliases
References