WordPress.Security.ValidatedSanitizedInput.MissingUnslash
Request data is not unslashed
Input from a WordPress request superglobal is used before removing WordPress-added slashes.
Why It Shows Up
WordPress adds slashes to request data for historical compatibility. The scan found `$_GET`, `$_POST`, `$_REQUEST`, or similar input used without `wp_unslash()`.
Why It Matters
Sanitizing slashed data can produce incorrect values, failed comparisons, broken validation, or stored data that does not match what the user submitted.
How to Fix
- Read the specific request key, then call `wp_unslash()` on it.
- Sanitize the unslashed value with a function that matches the expected data type.
- Validate the sanitized value before using it in permissions, queries, redirects, or stored settings.
Affected Plugins
| Rank | Plugin | Score | Errors | Warnings | Installs | Added | Updated | Top Issue |
|---|---|---|---|---|---|---|---|---|
| #3551 | Show Pages URL List | 40 | 29 | 234 | 1k+ | Non-prefixed global variable | ||
| #3552 | Simple Statistics for Feeds | 40 | 64 | 131 | 800 | Nonce verification recommended | ||
| #3553 | Simple Link List Widget | 40 | 129 | 8 | 2k+ | Output is not escaped | ||
| #3554 | Simple Page Sidebars | 40 | 55 | 65 | 20k+ | Output is not escaped | ||
| #3555 | Sinatra Core | 40 | 101 | 15 | 8k+ | Output is not escaped | ||
| #3556 | Specific Content For Mobile – Customize the mobile version without redirections | 40 | 26 | 155 | 4k+ | Nonce verification recommended | ||
| #3557 | SportsPress for Cricket | 40 | 122 | 34 | 500 | Text Domain Mismatch | ||
| #3558 | ST Demo Importer | 40 | 27 | 75 | 700 | Missing nonce verification | ||
| #3559 | Stax Addons for Elementor | 40 | 143 | 81 | 500 | Output is not escaped | ||
| #3560 | Developer Tools Blocker | 40 | 35 | 47 | 400 | strip tags strip tags | ||
| #3561 | Tagging | 40 | 33 | 37 | 500 | Output is not escaped | ||
| #3562 | Tealium | 40 | 73 | 19 | 600 | Unsafe printing function | ||
| #3563 | Theme Toolkit | 40 | 53 | 14 | 400 | Output is not escaped | ||
| #3564 | Theme and plugin translation for Polylang (TTfP) | 40 | 102 | 62 | 10k+ | Text Domain Mismatch | ||
| #3565 | Multiple Shipping Addresses for WooCommerce (Address Book) | 40 | 21 | 208 | 2k+ | Non-prefixed global variable | ||
| #3566 | ThemeZee Toolkit | 40 | 44 | 116 | 6k+ | Nonce verification recommended | ||
| #3567 | Thin Out Revisions | 40 | 93 | 35 | 800 | Non Singular String Literal Domain | ||
| #3568 | Timed Content | 40 | 76 | 63 | 5k+ | Unsafe printing function | ||
| #3569 | Timeline History | 40 | 31 | 17 | 500 | Output is not escaped | ||
| #3570 | Track Geolocation Of Users Using Contact Form 7 | 40 | 17 | 173 | 900 | Nonce verification recommended | ||
| #3571 | turboSMTP | 40 | 114 | 112 | 400 | Unsafe printing function | ||
| #3572 | Ultimate Dashboard – Custom WordPress Dashboard | 40 | 17 | 144 | 60k+ | Input is not sanitized | ||
| #3573 | Ultimate Noindex Nofollow Tool II | 40 | 38 | 51 | 3k+ | Input is not validated | ||
| #3574 | Ultimate Member – ForumWP forum integration | 40 | 31 | 73 | 500 | Nonce verification recommended | ||
| #3575 | Universal Honey Pot | 40 | 23 | 94 | 1k+ | Missing nonce verification | ||
| #3576 | Unlimited Logo Carousel | 40 | 286 | 15 | 500 | Text Domain Mismatch | ||
| #3577 | Upcoming Events Lists | 40 | 75 | 17 | 900 | Text Domain Mismatch | ||
| #3578 | Url Rewrite Analyzer | 40 | 73 | 23 | 400 | Unsafe printing function | ||
| #3579 | UsersWP – ReCaptcha | 40 | 80 | 17 | 3k+ | Text Domain Mismatch | ||
| #3580 | UTM Leads Tracker – XLPlugins | 40 | 21 | 38 | 400 | Output is not escaped | ||
| #3581 | Visibility Control for LearnDash | 40 | 55 | 23 | 1k+ | Missing Arg Domain | ||
| #3582 | Visibility Control for LearnPress | 40 | 52 | 19 | 700 | Missing Arg Domain | ||
| #3583 | Visma Pay for Woocommerce | 40 | 27 | 37 | 2k+ | Output is not escaped | ||
| #3584 | Visual Builder for Contact Form 7 | 40 | 20 | 43 | 500 | Output is not escaped | ||
| #3585 | Visual Editor Custom Buttons | 40 | 30 | 48 | 4k+ | Output is not escaped | ||
| #3586 | WP Sticky Button – Click to Chat | 40 | 73 | 64 | 10k+ | Non-prefixed global variable | ||
| #3587 | WooBooster Partial COD for WooCommerce | 40 | 90 | 51 | 500 | Text Domain Mismatch | ||
| #3588 | Where Did You Hear About Us Checkout Field for WooCommerce | 40 | 57 | 66 | 1k+ | Output is not escaped | ||
| #3589 | WC Search Orders By Product | 40 | 47 | 66 | 800 | Nonce verification recommended | ||
| #3590 | Webo-facto | 40 | 10 | 90 | 800 | Input is not sanitized | ||
| #3591 | Weight Based Pricing for WooCommerce | 40 | 167 | 86 | 600 | Text Domain Mismatch | ||
| #3592 | Widget Builder | 40 | 40 | 52 | 500 | Non-prefixed global variable | ||
| #3593 | Widget Menuizer | 40 | 44 | 26 | 600 | Missing Arg Domain | ||
| #3594 | Widget Visibility Without Jetpack | 40 | 74 | 47 | 5k+ | Text Domain Mismatch | ||
| #3595 | Widgets Control | 40 | 92 | 47 | 800 | Output is not escaped | ||
| #3596 | Payment Gateway – nexi Alpha Bank for WooCommerce | 40 | 28 | 45 | 1k+ | Missing nonce verification | ||
| #3597 | Preview E-mails for WooCommerce | 40 | 35 | 37 | 30k+ | Unsafe printing function | ||
| #3598 | NP Quote Request for WooCommerce | 40 | 91 | 145 | 9k+ | Non-prefixed global variable | ||
| #3599 | Total Sales Counts for WooCommerce | 40 | 121 | 62 | 700 | SQL query is not prepared | ||
| #3600 | yubikey-plugin | 40 | 64 | 33 | 400 | Text Domain Mismatch |