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 |
|---|---|---|---|---|---|---|---|---|
| #3101 | WP-Ban | 38 | 99 | 108 | 8k+ | Unsafe printing function | ||
| #3102 | WP Client Reports | 38 | 95 | 80 | 6k+ | Unsafe printing function | ||
| #3103 | WP-CommentNavi | 38 | 68 | 46 | 700 | Output is not escaped | ||
| #3104 | WP Content Copy Protection with Color Design | 38 | 96 | 61 | 5k+ | Non Singular String Literal Domain | ||
| #3105 | WP Discord Post Plus – Supports Unlimited Channels | 38 | 116 | 34 | 700 | Text Domain Mismatch | ||
| #3106 | WP-DraftsForFriends | 38 | 141 | 71 | 1k+ | Output is not escaped | ||
| #3107 | WP Mail SMTP SendGrid Edition | 38 | 102 | 19 | 500 | Text Domain Mismatch | ||
| #3108 | WP Mailgun SMTP | 38 | 99 | 51 | 900 | Text Domain Mismatch | ||
| #3109 | WP Maintenance Mode & Site Under Construction | 38 | 72 | 57 | 3k+ | Output is not escaped | ||
| #3110 | WP Media Categories | 38 | 40 | 103 | 800 | Nonce verification recommended | ||
| #3111 | Native PHP Sessions | 38 | 30 | 92 | 10k+ | Direct Query | ||
| #3112 | Real-Time Post Statistics for WordPress | 38 | 63 | 68 | 2k+ | SQL query is not prepared | ||
| #3113 | WP Redirects – Contact Form 7 | 38 | 50 | 71 | 400 | Unsafe printing function | ||
| #3114 | WP Safe Mode | 38 | 95 | 55 | 2k+ | Output is not escaped | ||
| #3115 | WP-ServerInfo | 38 | 162 | 55 | 10k+ | Output is not escaped | ||
| #3116 | External Store for Shopify | 38 | 97 | 33 | 2k+ | Output is not escaped | ||
| #3117 | WP Terms Popup – Terms and Conditions and Privacy Policy WordPress Popups | 38 | 299 | 58 | 3k+ | Non Singular String Literal Domain | ||
| #3118 | WP Video Lightbox | 38 | 107 | 67 | 30k+ | Unsafe printing function | ||
| #3119 | WPC Product Options for WooCommerce | 38 | 57 | 182 | 4k+ | Non-prefixed global variable | ||
| #3120 | Responsive Vertical Icon Menu | 38 | 188 | 85 | 700 | Output is not escaped | ||
| #3121 | mb.YTPlayer for background videos | 38 | 80 | 29 | 1k+ | Unsafe printing function | ||
| #3122 | WPTurbo -WordPress性能优化插件 | 38 | 20 | 34 | 600 | Output is not escaped | ||
| #3123 | Weather Underground | 38 | 64 | 27 | 3k+ | Output is not escaped | ||
| #3124 | YouTube widget | 38 | 39 | 25 | 400 | Output is not escaped | ||
| #3125 | ZeroBounce Email Verification & Validation | 38 | 299 | 162 | 1k+ | Text Domain Mismatch | ||
| #3126 | Zoho Campaigns | 38 | 3 | 129 | 3k+ | Non-prefixed global variable | ||
| #3127 | Smart Custom 404 Error Page | 39 | 90 | 44 | 100k+ | Output is not escaped | ||
| #3128 | Accounting for WooCommerce | 39 | 87 | 115 | 500 | Unsafe printing function | ||
| #3129 | ACF: Google Font Selector | 39 | 57 | 45 | 3k+ | Output is not escaped | ||
| #3130 | Ad Invalid Click Protector (AICP) | 39 | 78 | 57 | 10k+ | Text Domain Mismatch | ||
| #3131 | Add-on Gravity Forms – MailPoet 3 | 39 | 31 | 33 | 600 | Output is not escaped | ||
| #3132 | Add Tiktok Pixel for Tiktok ads (+Woocommerce) | 39 | 94 | 25 | 2k+ | Output is not escaped | ||
| #3133 | Additional Order Filters for WooCommerce | 39 | 79 | 255 | 2k+ | Nonce verification recommended | ||
| #3134 | Admin Custom Font | 39 | 34 | 25 | 1k+ | Unsafe printing function | ||
| #3135 | Advanced Product Fields (Product Addons) for WooCommerce | 39 | 145 | 145 | 50k+ | Output is not escaped | ||
| #3136 | Advanced Spoiler | 39 | 106 | 19 | 600 | Non Singular String Literal Domain | ||
| #3137 | Advanced Woo Labels – Product Labels & Badges for WooCommerce | 39 | 173 | 125 | 10k+ | Output is not escaped | ||
| #3138 | Affiliate Links – Link Cloaking and Management | 39 | 23 | 113 | 3k+ | Non-prefixed global variable | ||
| #3139 | AffiliatePages – Pros & Cons, Notice, and CTA Blocks for Affiliates | 39 | 91 | 53 | 2k+ | Output is not escaped | ||
| #3140 | AffiliateWP – Affiliate Area Tabs | 39 | 86 | 26 | 3k+ | Output is not escaped | ||
| #3141 | Load More Anything | 39 | 38 | 73 | 5k+ | Output is not escaped | ||
| #3142 | Accessibility by AllAccessible | 39 | 200 | 82 | 2k+ | Unsafe printing function | ||
| #3143 | Animate It! | 39 | 137 | 16 | 20k+ | Text Domain Mismatch | ||
| #3144 | Anything Order by Terms | 39 | 48 | 93 | 1k+ | Direct Query | ||
| #3145 | Ads.txt & App-ads.txt Manager for WordPress | 39 | 97 | 23 | 2k+ | Output is not escaped | ||
| #3146 | Archive Control | 39 | 151 | 67 | 1k+ | Unsafe printing function | ||
| #3147 | AWEOS WP Lock | 39 | 24 | 53 | 400 | Output is not escaped | ||
| #3148 | Timeline – Vertical and Horizontal Timeline Layouts | 39 | 500 | 43 | 2k+ | Output is not escaped | ||
| #3149 | Header Footer for Beaver Builder | 39 | 39 | 31 | 10k+ | Output is not escaped | ||
| #3150 | bbPress Voting | 39 | 27 | 53 | 500 | Output is not escaped |