Description
The TableOn – WordPress Posts Table Filterable plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the 'tableon_button' shortcode in all versions up to and including 1.0.4.4. This is due to insufficient input sanitization and output escaping on user-supplied shortcode attributes such as 'class', 'help_link', 'popup_title', and 'help_title'. The do_shortcode_button() function extracts these attributes without sanitization and passes them to TABLEON_HELPER::draw_html_item(), which concatenates attribute values into HTML using single quotes without escaping (line 29: $item .= " {$key}='{$value}'"). This makes it possible for authenticated attackers, with Contributor-level access and above, to inject arbitrary web scripts in pages that will execute whenever a user accesses an injected page.
Problem types
CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
Product status
Any version
Timeline
| 2026-03-04: | Vendor Notified |
| 2026-04-07: | Disclosed |
Credits
Itthidej Aramsri
References
www.wordfence.com/...-da99-465e-bfb6-44d2ba84f3ee?source=cve
plugins.trac.wordpress.org/...ilterable/trunk/lib/helper.php
plugins.trac.wordpress.org/...ble-filterable/trunk/index.php
plugins.trac.wordpress.org/...ble-filterable/trunk/index.php
plugins.trac.wordpress.org/...lterable&sfp_email=&sfph_mail=
plugins.trac.wordpress.org/...lterable&sfp_email=&sfph_mail=