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 |
|---|---|---|---|---|---|---|---|---|
| #2851 | WPC Composite Products for WooCommerce | 39 | 25 | 107 | 9k+ | Missing nonce verification | ||
| #2852 | Categories to Tags Converter | 39 | 86 | 38 | 50k+ | Output is not escaped | ||
| #2853 | WPS Child Theme Generator | 39 | 111 | 85 | 6k+ | Unsafe printing function | ||
| #2854 | WPS Limit Login | 39 | 152 | 76 | 100k+ | Output is not escaped | ||
| #2855 | Yandex Metrica | 39 | 92 | 46 | 20k+ | Output is not escaped | ||
| #2856 | YITH Custom Login | 39 | 86 | 33 | 6k+ | Output is not escaped | ||
| #2857 | You can quote me on that | 39 | 57 | 37 | 500 | Output is not escaped | ||
| #2858 | htaccess protect | 39 | 28 | 33 | 800 | Input is not validated | ||
| #2859 | 404 Notifier | 40 | 39 | 41 | 700 | Output is not escaped | ||
| #2860 | AccessibleWP – ALT Detector | 40 | 55 | 14 | 500 | Text Domain Mismatch | ||
| #2861 | ACF to Custom Database Tables | 40 | 36 | 64 | 600 | Nonce verification recommended | ||
| #2862 | Add Pinterest conversion tags for Pinterest Ads + Site verification | 40 | 88 | 26 | 1k+ | Output is not escaped | ||
| #2863 | Add & Replace Affiliate Links for Amazon | 40 | 39 | 52 | 600 | Output is not escaped | ||
| #2864 | Subscribe Button by AddToAny | 40 | 93 | 47 | 1k+ | Output is not escaped | ||
| #2865 | Address Autocomplete Anything | 40 | 94 | 32 | 900 | Unsafe printing function | ||
| #2866 | Advanced Custom Fields: Font Awesome Field | 40 | 327 | 70 | 90k+ | Text Domain Mismatch | ||
| #2867 | Advanced WooCommerce Product Gallery Slider | 40 | 42 | 48 | 3k+ | Non-prefixed global variable | ||
| #2868 | AgreeMe Checkboxes For WooCommerce | 40 | 88 | 44 | 600 | Text Domain Mismatch | ||
| #2869 | AJAX Thumbnail Rebuild | 40 | 38 | 14 | 30k+ | Unsafe printing function | ||
| #2870 | Allow Multiple Accounts | 40 | 115 | 19 | 9k+ | Non Singular String Literal Domain | ||
| #2871 | amCharts: Charts and Maps | 40 | 263 | 113 | 2k+ | Text Domain Mismatch | ||
| #2872 | Analytics Cat – Google Analytics Made Easy | 40 | 83 | 27 | 6k+ | Text Domain Mismatch | ||
| #2873 | Animated Live Wall Gallery | 40 | 27 | 72 | 2k+ | Request data is not unslashed | ||
| #2874 | Ads.txt & App-ads.txt Manager for WordPress | 40 | 92 | 28 | 2k+ | Output is not escaped | ||
| #2875 | Athemes Toolbox | 40 | 254 | 58 | 3k+ | Text Domain Mismatch | ||
| #2876 | Attachment Importer | 40 | 24 | 76 | 3k+ | Input is not sanitized | ||
| #2877 | Autocomplete LearnDash Lessons and Topics | 40 | 46 | 16 | 1k+ | Missing Arg Domain | ||
| #2878 | Mastodon Autopost | 40 | 41 | 50 | 800 | Output is not escaped | ||
| #2879 | Back To The Top Button | 40 | 31 | 271 | 4k+ | Non-prefixed global variable | ||
| #2880 | Bangladeshi Payment Gateways – Make Payment Using QR Code | 40 | 40 | 36 | 5k+ | Output is not escaped | ||
| #2881 | Basic Interactive World Map | 40 | 94 | 54 | 1k+ | Text Domain Mismatch | ||
| #2882 | bbPress WP Tweaks | 40 | 147 | 18 | 1k+ | Output is not escaped | ||
| #2883 | Better Internal Link Search | 40 | 23 | 48 | 1k+ | strip tags strip tags | ||
| #2884 | Black Studio TinyMCE Widget | 40 | 39 | 28 | 200k+ | Output is not escaped | ||
| #2885 | Broken Link Notifier | 40 | 11 | 193 | 1k+ | Non-prefixed global variable | ||
| #2886 | Bulk Add Terms | 40 | 74 | 27 | 800 | Text Domain Mismatch | ||
| #2887 | Bulk Delete Comments | 40 | 16 | 61 | 5k+ | Direct Query | ||
| #2888 | Bulk Move | 40 | 85 | 44 | 9k+ | Unsafe printing function | ||
| #2889 | Buy one Get one Free – BOGO discount rule maker for WooCommerce | 40 | 119 | 57 | 500 | Text Domain Mismatch | ||
| #2890 | Coming soon Page | 40 | 24 | 18 | 500 | Text Domain Mismatch | ||
| #2891 | Catalog for Woocommerce | 40 | 92 | 75 | 1k+ | Output is not escaped | ||
| #2892 | Category Featured Images Extended | 40 | 177 | 40 | 400 | Text Domain Mismatch | ||
| #2893 | CleverReach Integration for Contact Form 7 | 40 | 103 | 43 | 700 | Text Domain Mismatch | ||
| #2894 | Contact Form 7 to Mailjet | 40 | 70 | 39 | 600 | Output is not escaped | ||
| #2895 | Client Portal – Private user pages and login | 40 | 52 | 29 | 3k+ | Output is not escaped | ||
| #2896 | codoc | 40 | 19 | 39 | 2k+ | Request data is not unslashed | ||
| #2897 | Complete Image Sitemap | 40 | 55 | 18 | 1k+ | Output is not escaped | ||
| #2898 | Conditional WooCommerce Checkout Field | 40 | 84 | 22 | 400 | Unsafe printing function | ||
| #2899 | Contact Form 7 GetResponse Extension | 40 | 88 | 18 | 1k+ | Text Domain Mismatch | ||
| #2900 | Contact Form 7 Multi-Step Forms | 40 | 65 | 40 | 50k+ | Output is not escaped |