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 |
|---|---|---|---|---|---|---|---|---|
| #3501 | LLM Bot Tracker – AI Crawler Detection & Analytics | 40 | 18 | 90 | 700 | Database parameter is not escaped | ||
| #3502 | Loan Comparison | 40 | 27 | 192 | 400 | Request data is not unslashed | ||
| #3503 | Logbook | 40 | 33 | 59 | 2k+ | Nonce verification recommended | ||
| #3504 | WPO365 | Mail Integration for Office 365 / Outlook | 40 | 59 | 27 | 2k+ | Output is not escaped | ||
| #3505 | MailerSend – Official SMTP Integration | 40 | 39 | 25 | 2k+ | Unsafe printing function | ||
| #3506 | Manual Image Crop | 40 | 178 | 61 | 8k+ | Output is not escaped | ||
| #3507 | Mark New Posts | 40 | 61 | 39 | 500 | Non Singular String Literal Domain | ||
| #3508 | MAS Company Reviews For WP Job Manager | 40 | 44 | 71 | 1k+ | Output is not escaped | ||
| #3509 | Mass Email To Users | 40 | 84 | 81 | 800 | Output is not escaped | ||
| #3510 | MembershipWorks – Membership, Events & Directory | 40 | 41 | 29 | 2k+ | Output is not escaped | ||
| #3511 | Mobile Contact Line | 40 | 39 | 355 | 1k+ | Non-prefixed global variable | ||
| #3512 | WP Mobile Redirect | 40 | 44 | 20 | 400 | Text Domain Mismatch | ||
| #3513 | Modal Window – create popup modal window | 40 | 4 | 170 | 10k+ | Non-prefixed global variable | ||
| #3514 | Monri Payments Gateway for WooCommerce | 40 | 144 | 172 | 900 | Text Domain Mismatch | ||
| #3515 | 코드엠샵 소셜톡 | 40 | 47 | 36 | 400 | Output is not escaped | ||
| #3516 | Multiple Featured Images | 40 | 50 | 22 | 5k+ | Output is not escaped | ||
| #3517 | Customize My Account for WooCommerce – Custom Tabs, Login, Registration, 2FA & Design | 40 | 77 | 167 | 800 | Non-prefixed global variable | ||
| #3518 | My Social Feeds – Social Feeds Embedder Plugin for WP | 40 | 8 | 77 | 400 | Request data is not unslashed | ||
| #3519 | Flying Images: Optimize and Lazy Load Images for Faster Page Speed | 40 | 32 | 58 | 3k+ | Missing direct file access protection | ||
| #3520 | No-Bot Registration | 40 | 112 | 42 | 2k+ | Unsafe printing function | ||
| #3521 | No CAPTCHA reCAPTCHA | 40 | 112 | 26 | 4k+ | Text Domain Mismatch | ||
| #3522 | One Click SSL | 40 | 136 | 62 | 10k+ | Unsafe printing function | ||
| #3523 | OPML Importer | 40 | 35 | 13 | 3k+ | Output is not escaped | ||
| #3524 | Owl Carousel WP | 40 | 62 | 19 | 1k+ | Output is not escaped | ||
| #3525 | Page As Subdomain Lite | 40 | 61 | 25 | 500 | Output is not escaped | ||
| #3526 | Page Comments Off Please | 40 | 17 | 29 | 1k+ | Nonce verification recommended | ||
| #3527 | Give – Paystack Gateway | 40 | 96 | 10 | 1k+ | Text Domain Mismatch | ||
| #3528 | Paystack MemberPress | 40 | 71 | 76 | 400 | Output is not escaped | ||
| #3529 | Permalink Editor | 40 | 50 | 28 | 1k+ | Output is not escaped | ||
| #3530 | List Petfinder Pets | 40 | 121 | 46 | 400 | Output is not escaped | ||
| #3531 | Pixel Tag Manager for WooCommerce – Google Analytics 4, Google Ads, and More Pixels | 40 | 68 | 249 | 3k+ | Missing nonce verification | ||
| #3532 | Plugin Load Filter | 40 | 76 | 112 | 7k+ | Text Domain Mismatch | ||
| #3533 | Popup addon for Ninja Forms | 40 | 121 | 25 | 1k+ | Output is not escaped | ||
| #3534 | Post Ratings | 40 | 160 | 32 | 600 | Output is not escaped | ||
| #3535 | Requirements Checklist | 40 | 200 | 22 | 900 | Output is not escaped | ||
| #3536 | Private Google Calendars | 40 | 227 | 37 | 1k+ | Output is not escaped | ||
| #3537 | Privilege Widget | 40 | 139 | 52 | 600 | Text Domain Mismatch | ||
| #3538 | PT Theme Addon | 40 | 67 | 21 | 1k+ | Output is not escaped | ||
| #3539 | Quick Child Theme Generator | 40 | 22 | 74 | 900 | Request data is not unslashed | ||
| #3540 | Quiz Cat – WordPress Quiz Plugin | 40 | 151 | 69 | 4k+ | Output is not escaped | ||
| #3541 | Random Banner | 40 | 59 | 125 | 1k+ | Output is not escaped | ||
| #3542 | Random Post Plugin – Redirect URL to Post | 40 | 28 | 74 | 4k+ | Nonce verification recommended | ||
| #3543 | Redirector | 40 | 48 | 32 | 7k+ | Output is not escaped | ||
| #3544 | Manual Related Posts | 40 | 51 | 32 | 1k+ | Output is not escaped | ||
| #3545 | Rename default post Labels | 40 | 54 | 36 | 600 | Text Domain Mismatch | ||
| #3546 | Responsive Plus – Elementor Templates & Starter Sites | 40 | 46 | 305 | 10k+ | Non-prefixed global variable | ||
| #3547 | Responsive Full Width Background Slider | 40 | 131 | 22 | 2k+ | Unsafe printing function | ||
| #3548 | Responsive Sidebar | 40 | 43 | 12 | 700 | Output is not escaped | ||
| #3549 | Responsive Slider | 40 | 28 | 15 | 3k+ | Output is not escaped | ||
| #3550 | Risk Free Cash On Delivery (COD) – WooCommerce | 40 | 106 | 31 | 400 | Text Domain Mismatch |