CVE-2026-31809
MEDIUM NUCLEISiYuan <3.5.10 - XSS
Title source: llmDescription
SiYuan is a personal knowledge management system. Prior to 3.5.10, SiYuan's SVG sanitizer (SanitizeSVG) checks href attributes for the javascript: prefix using strings.HasPrefix(). However, inserting ASCII tab (	), newline ( ), or carriage return ( ) characters inside the javascript: string bypasses this prefix check. Browsers strip these characters per the WHATWG URL specification before parsing the URL scheme, so the JavaScript still executes. This allows an attacker to inject executable JavaScript into the unauthenticated /api/icon/getDynamicIcon endpoint, creating a reflected XSS. This is a second bypass of the fix for CVE-2026-29183 (fixed in v3.5.9). This vulnerability is fixed in 3.5.10.
Nuclei Templates (1)
SiYuan <= v3.5.9 - Cross Site Scripting
MEDIUMVERIFIEDby 0x_Akoko
Shodan:
http.favicon.hash:-1450125239
Scores
CVSS v3
6.1
EPSS
0.0060
EPSS Percentile
69.5%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
Details
CWE
CWE-79
Status
published
Products (1)
b3log/siyuan
< 3.5.10
Published
Mar 10, 2026
Tracked Since
Mar 11, 2026