Home

Description

The Elementor Website Builder plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the _elementor_data meta field in versions up to, and including, 4.0.4. This is due to insufficient input sanitization when processing form-encoded REST API requests. The plugin registers the _elementor_data meta field with show_in_rest but omits a sanitize_callback, relying instead on a rest_pre_insert_post filter (sanitize_post_data function) that only sanitizes JSON-encoded request bodies. When a contributor sends a form-encoded PATCH request to the WordPress REST API, the json_decode() call on the raw body returns null, causing all sanitization to be skipped. The unsanitized data is then stored via update_post_meta() and later output without escaping through multiple widget sinks including the HTML widget's print_unescaped_setting() function. 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.

PUBLISHED Reserved 2026-04-12 | Published 2026-05-01 | Updated 2026-05-01 | Assigner Wordfence




MEDIUM: 6.4CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:L/I:L/A:N

Problem types

CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Product status

Default status
unaffected

Any version
affected

Timeline

2026-04-12:Vendor Notified
2026-04-30:Disclosed

Credits

Jonah Burgess finder

References

www.wordfence.com/...-c526-4760-8c21-10d5ae7bb384?source=cve

plugins.trac.wordpress.org/.../includes/base/widget-base.php

plugins.trac.wordpress.org/.../includes/base/widget-base.php

plugins.trac.wordpress.org/...ntor/trunk/includes/plugin.php

plugins.trac.wordpress.org/...tags/4.0.1/includes/plugin.php

plugins.trac.wordpress.org/...lasses/elementor-post-meta.php

plugins.trac.wordpress.org/...lasses/elementor-post-meta.php

plugins.trac.wordpress.org/changeset/3519457/

cve.org (CVE-2026-6127)

nvd.nist.gov (CVE-2026-6127)

Download JSON