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 |
|---|---|---|---|---|---|---|---|
| #2351 | Plugin Load Filter | 40 | 76 | 112 | 7k+ | Text Domain Mismatch | |
| #2352 | Quiz Cat – WordPress Quiz Plugin | 40 | 151 | 69 | 5k+ | Output Not Escaped | |
| #2353 | Random Banner | 40 | 59 | 125 | 1k+ | Output Not Escaped | |
| #2354 | Random Post Plugin – Redirect URL to Post | 40 | 28 | 74 | 4k+ | Recommended | |
| #2355 | Redirector | 40 | 48 | 32 | 7k+ | Output Not Escaped | |
| #2356 | Responsive Full Width Background Slider | 40 | 131 | 22 | 2k+ | Unsafe Printing Function | |
| #2357 | Responsive Slider | 40 | 28 | 15 | 3k+ | Output Not Escaped | |
| #2358 | Role Based Redirect | 40 | 20 | 96 | 2k+ | Non Prefixed Variable Found | |
| #2359 | RPB Chessboard | 40 | 86 | 98 | 1k+ | missing direct file access protection | |
| #2360 | Secondary Title | 40 | 117 | 31 | 7k+ | Unsafe Printing Function | |
| #2361 | Select All Categories and Taxonomies, Change Checkbox to Radio Buttons | 40 | 116 | 30 | 3k+ | Output Not Escaped | |
| #2362 | Shortcodes Finder | 40 | 22 | 188 | 4k+ | Recommended | |
| #2363 | Simple Link List Widget | 40 | 129 | 8 | 2k+ | Output Not Escaped | |
| #2364 | Simple Page Sidebars | 40 | 55 | 65 | 20k+ | Output Not Escaped | |
| #2365 | Sinatra Core | 40 | 101 | 15 | 8k+ | Output Not Escaped | |
| #2366 | Specific Content For Mobile – Customize the mobile version without redirections | 40 | 26 | 155 | 4k+ | Missing Unslash | |
| #2367 | Super Testimonial – Testimonial & Customer Review Slider Plugin for WordPress | 40 | 28 | 167 | 2k+ | Missing Unslash | |
| #2368 | Theme and plugin translation for Polylang (TTfP) | 40 | 102 | 62 | 10k+ | Text Domain Mismatch | |
| #2369 | Multiple Shipping Addresses for WooCommerce (Address Book) | 40 | 21 | 208 | 2k+ | Non Prefixed Variable Found | |
| #2370 | ThemeZee Toolkit | 40 | 44 | 116 | 6k+ | Recommended | |
| #2371 | Timed Content | 40 | 76 | 63 | 5k+ | Unsafe Printing Function | |
| #2372 | Ultimate Dashboard – Custom WordPress Dashboard | 40 | 17 | 144 | 60k+ | Input Not Sanitized | |
| #2373 | Ultimate Noindex Nofollow Tool II | 40 | 38 | 51 | 3k+ | Input Not Validated | |
| #2374 | Universal Honey Pot | 40 | 23 | 94 | 1k+ | Missing | |
| #2375 | UsersWP – ReCaptcha | 40 | 80 | 17 | 3k+ | Text Domain Mismatch | |
| #2376 | Visual Editor Custom Buttons | 40 | 30 | 48 | 4k+ | Output Not Escaped | |
| #2377 | WP Sticky Button – Click to Chat | 40 | 73 | 64 | 10k+ | Non Prefixed Variable Found | |
| #2378 | Where Did You Hear About Us Checkout Field for WooCommerce | 40 | 57 | 66 | 1k+ | Output Not Escaped | |
| #2379 | Widget Visibility Without Jetpack | 40 | 74 | 47 | 5k+ | Text Domain Mismatch | |
| #2380 | Payment Gateway – nexi Alpha Bank for WooCommerce | 40 | 28 | 45 | 1k+ | Missing | |
| #2381 | Preview E-mails for WooCommerce | 40 | 35 | 37 | 30k+ | Unsafe Printing Function | |
| #2382 | Country Based Restrictions for WooCommerce | 40 | 21 | 65 | 5k+ | Missing Unslash | |
| #2383 | NP Quote Request for WooCommerce | 40 | 91 | 145 | 9k+ | Non Prefixed Variable Found | |
| #2384 | All In One SEO Pack for WooCommerce | 40 | 57 | 25 | 3k+ | Text Domain Mismatch | |
| #2385 | Simple Registration for WooCommerce | 40 | 27 | 55 | 4k+ | Missing | |
| #2386 | WooSidebars | 40 | 43 | 37 | 100k+ | Missing Translators Comment | |
| #2387 | Word Balloon | 40 | 20 | 125 | 10k+ | Missing Unslash | |
| #2388 | WP Date and Time Shortcode | 40 | 90 | 12 | 10k+ | Output Not Escaped | |
| #2389 | Easy PayPal & Stripe Buy Now Button | 40 | 388 | 96 | 10k+ | Unsafe Printing Function | |
| #2390 | WP Help | 40 | 49 | 54 | 10k+ | Unsafe Printing Function | |
| #2391 | WP All Import – Job Listing Import for WP Job Manager | 40 | 35 | 27 | 2k+ | Output Not Escaped | |
| #2392 | Media Library Categories | 40 | 29 | 49 | 20k+ | Output Not Escaped | |
| #2393 | WP Meteor Website Speed Optimization Addon | 40 | 34 | 19 | 20k+ | Output Not Escaped | |
| #2394 | WP Paint – WordPress Image Editor | 40 | 30 | 29 | 6k+ | Missing Arg Domain | |
| #2395 | QR code MeCard/vCard generator | 40 | 322 | 21 | 2k+ | Unsafe Printing Function | |
| #2396 | WP Reroute Email | 40 | 141 | 106 | 1k+ | Output Not Escaped | |
| #2397 | Sentry for WordPress | 40 | 80 | 40 | 10k+ | Text Domain Mismatch | |
| #2398 | Social Share Buttons & Analytics Plugin – GetSocial.io | 40 | 97 | 25 | 2k+ | Output Not Escaped | |
| #2399 | WP Tab Widget | 40 | 128 | 32 | 10k+ | Output Not Escaped | |
| #2400 | WP Theme Test | 40 | 21 | 39 | 7k+ | Input Not Sanitized |