WordPress.Security.ValidatedSanitizedInput.InputNotValidated
Input is not validated
Request data is used without checking that it is allowed for the operation.
Why It Shows Up
The scan found input from a request superglobal being used without validation such as capability checks, allowlists, type checks, or range checks.
Why It Matters
Sanitization cleans a value, but validation proves the value is acceptable. Missing validation can allow unexpected actions, invalid states, or unsafe query choices.
How to Fix
- Check that IDs are positive integers, enum-like values are in an allowlist, and URLs or file paths are constrained.
- Pair state-changing requests with nonce and capability checks.
- Reject or safely default values that do not pass validation.
Affected Plugins
| Rank | Plugin | Score | Errors | Warnings | Installs | Added | Updated | Top Issue |
|---|---|---|---|---|---|---|---|---|
| #2651 | Simple Posts Ticker – Easy, Lightweight & Flexible | 39 | 151 | 28 | 2k+ | Output is not escaped | ||
| #2652 | Simple Staff List | 39 | 90 | 236 | 3k+ | Non-prefixed global variable | ||
| #2653 | SimpleModal Login | 39 | 50 | 12 | 800 | Unsafe printing function | ||
| #2654 | Slash Admin | 39 | 116 | 38 | 500 | Output is not escaped | ||
| #2655 | Slideshow SE | 39 | 35 | 240 | 2k+ | Non-prefixed global variable | ||
| #2656 | Smaily for WP | 39 | 52 | 36 | 700 | Output is not escaped | ||
| #2657 | Smart Archives Reloaded | 39 | 78 | 36 | 1k+ | Non Singular String Literal Domain | ||
| #2658 | Spreadr Woocommerce Plugin – Amazon Importer for Dropshipping and Affiliate | 39 | 42 | 226 | 500 | Request data is not unslashed | ||
| #2659 | Stock Ticker | 39 | 92 | 49 | 2k+ | Output is not escaped | ||
| #2660 | Stockdio Historical Chart | 39 | 65 | 16 | 900 | Output is not escaped | ||
| #2661 | Sydney Toolbox | 39 | 84 | 62 | 50k+ | Unsafe printing function | ||
| #2662 | Tabify Edit Screen | 39 | 83 | 27 | 500 | Output is not escaped | ||
| #2663 | Tawk.To Manager | 39 | 204 | 21 | 700 | Output is not escaped | ||
| #2664 | Easy Category Icons | 39 | 50 | 43 | 700 | Text Domain Mismatch | ||
| #2665 | ThemeKit For WordPress | 39 | 149 | 49 | 700 | Output is not escaped | ||
| #2666 | TinyMCE Custom Styles | 39 | 297 | 76 | 7k+ | Non Singular String Literal Domain | ||
| #2667 | TinyMCE Spellcheck | 39 | 27 | 32 | 2k+ | Unsafe printing function | ||
| #2668 | TomS reCAPTCHA | 39 | 128 | 256 | 500 | Missing nonce verification | ||
| #2669 | Ultimate Client Dash | 39 | 697 | 12 | 2k+ | Text Domain Mismatch | ||
| #2670 | Ultimate Lightbox | 39 | 110 | 59 | 1k+ | Unsafe printing function | ||
| #2671 | Universal Google Adsense and Ads manager | 39 | 70 | 31 | 2k+ | Unsafe printing function | ||
| #2672 | upPrev | 39 | 35 | 36 | 1k+ | Dynamic hook name | ||
| #2673 | Uptolike Social Share Buttons | 39 | 38 | 33 | 4k+ | Output is not escaped | ||
| #2674 | Use Any Font | Custom Font Uploader | 39 | 36 | 55 | 200k+ | Request data is not unslashed | ||
| #2675 | UserHeat Plugin | 39 | 121 | 20 | 6k+ | Non Singular String Literal Domain | ||
| #2676 | Accessibility by UserWay | 39 | 22 | 35 | 80k+ | Direct Query | ||
| #2677 | Smart Variation Swatches and Attribute Filters for WooCommerce | 39 | 39 | 50 | 3k+ | Output is not escaped | ||
| #2678 | Video Blogster Lite | 39 | 29 | 80 | 700 | Missing nonce verification | ||
| #2679 | Virusdie | One-click website security | 39 | 149 | 66 | 2k+ | Output is not escaped | ||
| #2680 | Smart COD for WooCommerce | 39 | 50 | 28 | 30k+ | Output is not escaped | ||
| #2681 | WebHotelier for WordPress | 39 | 451 | 40 | 500 | Text Domain Mismatch | ||
| #2682 | Wicked Folders – Folder Organizer for Pages, Posts, and Custom Post Types | 39 | 89 | 117 | 20k+ | Unsafe printing function | ||
| #2683 | Combo Offers WooCommerce | 39 | 38 | 89 | 2k+ | Missing nonce verification | ||
| #2684 | Lucky Wheel for WooCommerce – Spin a Sale | 39 | 12 | 153 | 1k+ | Request data is not unslashed | ||
| #2685 | CURCY – Multi Currency for WooCommerce – Smoothly on WooCommerce 9.x | 39 | 7 | 222 | 20k+ | Non-prefixed hook name | ||
| #2686 | Eurobank WooCommerce Payment Gateway | 39 | 62 | 63 | 2k+ | Non Singular String Literal Domain | ||
| #2687 | PayU GPO Payment for WooCommerce | 39 | 44 | 91 | 10k+ | Output is not escaped | ||
| #2688 | Modal Fly Cart & AJAX Add to Cart for WooCommerce | 39 | 83 | 74 | 2k+ | Text Domain Mismatch | ||
| #2689 | Store Toolkit – WooCommerce Extensions, Quick Enhancements & Handy Tools | 39 | 323 | 66 | 8k+ | Output is not escaped | ||
| #2690 | WP Accessibility | 39 | 199 | 104 | 60k+ | Unsafe printing function | ||
| #2691 | WP Add Custom CSS | 39 | 45 | 23 | 60k+ | Output is not escaped | ||
| #2692 | WP Attachments | 39 | 49 | 44 | 3k+ | Output is not escaped | ||
| #2693 | WP-Cycle | 39 | 53 | 17 | 3k+ | Output is not escaped | ||
| #2694 | WP Gmail SMTP | 39 | 99 | 50 | 1k+ | Text Domain Mismatch | ||
| #2695 | WP Limit Login Attempts | 39 | 26 | 67 | 10k+ | Direct Query | ||
| #2696 | WP Most Popular | 39 | 50 | 35 | 2k+ | Output is not escaped | ||
| #2697 | WP Multibyte Patch | 39 | 24 | 55 | 1m+ | Input is not sanitized | ||
| #2698 | WP SendGrid SMTP | 39 | 99 | 50 | 1k+ | Text Domain Mismatch | ||
| #2699 | WP Server Health Stats | 39 | 66 | 31 | 10k+ | Output is not escaped | ||
| #2700 | WP Sitemaps Config | 39 | 88 | 37 | 700 | Output is not escaped |