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 | Updated | Top Issue |
|---|---|---|---|---|---|---|---|
| #2051 | WP Sticky Button – Click to Chat | 40 | 73 | 64 | 10k+ | Non Prefixed Variable Found | |
| #2052 | Widget Visibility Without Jetpack | 40 | 74 | 47 | 5k+ | Text Domain Mismatch | |
| #2053 | Preview E-mails for WooCommerce | 40 | 35 | 37 | 30k+ | Unsafe Printing Function | |
| #2054 | Country Based Restrictions for WooCommerce | 40 | 21 | 65 | 5k+ | Missing Unslash | |
| #2055 | NP Quote Request for WooCommerce | 40 | 91 | 145 | 9k+ | Non Prefixed Variable Found | |
| #2056 | All In One SEO Pack for WooCommerce | 40 | 57 | 25 | 3k+ | Text Domain Mismatch | |
| #2057 | Simple Registration for WooCommerce | 40 | 27 | 55 | 4k+ | Missing | |
| #2058 | WooSidebars | 40 | 43 | 37 | 100k+ | Missing Translators Comment | |
| #2059 | Word Balloon | 40 | 20 | 125 | 10k+ | Missing Unslash | |
| #2060 | WP Date and Time Shortcode | 40 | 90 | 12 | 10k+ | Output Not Escaped | |
| #2061 | Easy PayPal & Stripe Buy Now Button | 40 | 388 | 96 | 10k+ | Unsafe Printing Function | |
| #2062 | WP Help | 40 | 49 | 54 | 10k+ | Unsafe Printing Function | |
| #2063 | WP All Import – Job Listing Import for WP Job Manager | 40 | 35 | 27 | 2k+ | Output Not Escaped | |
| #2064 | Media Library Categories | 40 | 29 | 49 | 20k+ | Output Not Escaped | |
| #2065 | WP Meteor Website Speed Optimization Addon | 40 | 34 | 19 | 20k+ | Output Not Escaped | |
| #2066 | WP Paint – WordPress Image Editor | 40 | 30 | 29 | 6k+ | Missing Arg Domain | |
| #2067 | QR code MeCard/vCard generator | 40 | 322 | 21 | 2k+ | Unsafe Printing Function | |
| #2068 | Sentry for WordPress | 40 | 80 | 40 | 10k+ | Text Domain Mismatch | |
| #2069 | Social Share Buttons & Analytics Plugin – GetSocial.io | 40 | 97 | 25 | 2k+ | Output Not Escaped | |
| #2070 | WP Tab Widget | 40 | 128 | 32 | 10k+ | Output Not Escaped | |
| #2071 | WP Theme Test | 40 | 21 | 39 | 7k+ | Input Not Sanitized | |
| #2072 | WPC Estimated Delivery Date for WooCommerce | 40 | 13 | 106 | 10k+ | Non Prefixed Variable Found | |
| #2073 | WPC Grouped Product for WooCommerce | 40 | 19 | 95 | 3k+ | Missing Unslash | |
| #2074 | WPFront Notification Bar | 40 | 222 | 44 | 50k+ | Output Not Escaped | |
| #2075 | My YouTube Channel | 40 | 54 | 38 | 5k+ | Output Not Escaped | |
| #2076 | Zippy | 40 | 43 | 31 | 9k+ | Output Not Escaped | |
| #2077 | AMP for WP – Accelerated Mobile Pages | 41 | 656 | 2,401 | 80k+ | Non Prefixed Variable Found | |
| #2078 | Add-on Contact Form 7 – MailPoet 3 | 41 | 88 | 12 | 3k+ | Output Not Escaped | |
| #2079 | Advanced Excerpt | 41 | 69 | 43 | 80k+ | Unsafe Printing Function | |
| #2080 | AH Display Widgets | 41 | 52 | 16 | 9k+ | Text Domain Mismatch | |
| #2081 | Schema – All In One Schema Rich Snippets | 41 | 598 | 180 | 30k+ | Text Domain Mismatch | |
| #2082 | Amazon Link Engine | 41 | 38 | 17 | 2k+ | Output Not Escaped | |
| #2083 | Amazon Web Services | 41 | 53 | 21 | 5k+ | Missing Translators Comment | |
| #2084 | Announcer – Sticky Message Banner & Notification Bar | 41 | 110 | 27 | 10k+ | Output Not Escaped | |
| #2085 | Auto Image Attributes From Filename With Bulk Updater (Add Alt Text, Image Title For Image SEO) | 41 | 175 | 26 | 100k+ | Unsafe Printing Function | |
| #2086 | Avatar Manager | 41 | 29 | 41 | 5k+ | Unsafe Printing Function | |
| #2087 | Beautiful Cookie Consent Banner | 41 | 33 | 76 | 40k+ | Non Prefixed Variable Found | |
| #2088 | BuddyPress Xprofile Custom Field Types | 41 | 39 | 189 | 4k+ | Missing | |
| #2089 | Carbon Copy | 41 | 64 | 89 | 3k+ | Text Domain Mismatch | |
| #2090 | Easy Social Like Box – Popup – Sidebar Widget | 41 | 218 | 91 | 7k+ | Text Domain Mismatch | |
| #2091 | Conditional Fields for Contact Form 7 | 41 | 113 | 52 | 100k+ | Output Not Escaped | |
| #2092 | CF7 Invisible reCAPTCHA | 41 | 19 | 52 | 7k+ | Missing Unslash | |
| #2093 | Colorful Categories | 41 | 20 | 20 | 2k+ | Output Not Escaped | |
| #2094 | Comments Like Dislike | 41 | 172 | 20 | 5k+ | Non Singular String Literal Domain | |
| #2095 | Contact Form 7 Captcha | 41 | 7 | 75 | 100k+ | Missing Unslash | |
| #2096 | Controlled Admin Access | 41 | 22 | 40 | 10k+ | Recommended | |
| #2097 | Dashboard Notepad | 41 | 29 | 34 | 10k+ | Missing | |
| #2098 | Database for CF7 | 41 | 37 | 32 | 2k+ | Text Domain Mismatch | |
| #2099 | Debug Bar | 41 | 64 | 25 | 20k+ | Output Not Escaped | |
| #2100 | Disable Everything | 41 | 90 | 16 | 30k+ | Output Not Escaped |