WordPress.Security.NonceVerification.Recommended
Nonce verification recommended
The code reads request data in a place where Plugin Check recommends a nonce check.
Why It Shows Up
The scan saw request handling that may not always mutate state, but still looks like a user-triggered action that should usually be protected by a nonce.
Why It Matters
Adding a nonce reduces accidental or forged requests and documents that the action is expected to originate from the plugin UI.
How to Fix
- For admin forms and action links, add and verify a nonce.
- For AJAX handlers, use `check_ajax_referer()`.
- For public read-only endpoints, document why a nonce is not required and keep input validation strict.
References
Affected Plugins
| Rank | Plugin | Score | Errors | Warnings | Installs | Added | Updated | Top Issue |
|---|---|---|---|---|---|---|---|---|
| #3551 | Disable Gutenberg | 43 | 23 | 47 | 500k+ | Nonce verification recommended | ||
| #3552 | Disable WP Notification | 43 | 74 | 26 | 10k+ | Output is not escaped | ||
| #3553 | Easy PayPal Shopping Cart | 43 | 19 | 40 | 1k+ | Input is not sanitized | ||
| #3554 | F4 Total Stock Value for WooCommerce | 43 | 27 | 12 | 1k+ | Output is not escaped | ||
| #3555 | Floating Awesome Button (Sticky Button, Popup, Toast) & 200+ Website Custom Interactive Element | 43 | 66 | 109 | 800 | Missing direct file access protection | ||
| #3556 | GD bbPress Tools | 43 | 15 | 61 | 1k+ | Input is not sanitized | ||
| #3557 | Per User Prompt for Google Authenticator | 43 | 8 | 52 | 400 | Nonce verification recommended | ||
| #3558 | Hash Form – Drag & Drop Form Builder | 43 | 9 | 273 | 4k+ | Non-prefixed global variable | ||
| #3559 | Linker – URL shortener & track outbound link clicks | 43 | 17 | 17 | 2k+ | Output is not escaped | ||
| #3560 | Live Copy Paste for Elementor – Cross Domain Copy Paste & Page Duplicator | 43 | 12 | 32 | 7k+ | Request data is not unslashed | ||
| #3561 | Make Tables Responsive | 43 | 31 | 102 | 6k+ | Input is not validated | ||
| #3562 | MarqueeX – Smooth Marquee Slider, News Ticker & Post Marquee for Gutenberg & Elementor | 43 | 37 | 20 | 600 | Output is not escaped | ||
| #3563 | MembershipWorks Login Connector | 43 | 28 | 81 | 800 | Request data is not unslashed | ||
| #3564 | Opal Woo Custom Product Variation | 43 | 1 | 116 | 400 | Non-prefixed global variable | ||
| #3565 | Pods Gravity Forms Add-On | 43 | 79 | 1k+ | Missing nonce verification | |||
| #3566 | Post Carousel Slider for Elementor | 43 | 133 | 23 | 3k+ | Text Domain Mismatch | ||
| #3567 | Redirect List | 43 | 34 | 22 | 1k+ | Output is not escaped | ||
| #3568 | Rut Chileno con Validación para WooCommerce | 43 | 35 | 16 | 1k+ | Text Domain Mismatch | ||
| #3569 | Simple Revisions Delete | 43 | 16 | 26 | 10k+ | Output is not escaped | ||
| #3570 | Simple Shipping Labels for WooCommerce | 43 | 78 | 12 | 1k+ | Output is not escaped | ||
| #3571 | Sinbyte Indexer | 43 | 61 | 19 | 2k+ | Text Domain Mismatch | ||
| #3572 | Snazzy Maps | 43 | 9 | 62 | 30k+ | Request data is not unslashed | ||
| #3573 | SQL Chart Builder | 43 | 12 | 39 | 600 | Non-prefixed global variable | ||
| #3574 | SSO for Entra ID | 43 | 65 | 18 | 600 | Output is not escaped | ||
| #3575 | Team Builder Member Showcase | 43 | 14 | 127 | 1k+ | Non-prefixed global variable | ||
| #3576 | Term Management Tools | 43 | 9 | 26 | 10k+ | Non-prefixed hook name | ||
| #3577 | Terms Order WP – Categories And Taxonomies Order Plugin | 43 | 12 | 47 | 900 | Non-prefixed global variable | ||
| #3578 | Theme Switcha – Easily Switch Themes for Development and Testing | 43 | 42 | 53 | 7k+ | Output is not escaped | ||
| #3579 | Theme Test Drive | 43 | 39 | 16 | 7k+ | Output is not escaped | ||
| #3580 | Ultimate Member Widgets for Elementor – Login Form, Register Form & User Directory | 43 | 15 | 102 | 400 | Non-prefixed namespace | ||
| #3581 | User Role Editor | 43 | 117 | 145 | 700k+ | Output is not escaped | ||
| #3582 | utm.codes | 43 | 34 | 33 | 400 | Missing nonce verification | ||
| #3583 | Checkout Field Manager (Checkout Manager) for WooCommerce | 43 | 162 | 154 | 90k+ | Non-prefixed global variable | ||
| #3584 | WP Extra File Types | 43 | 11 | 26 | 40k+ | Request data is not unslashed | ||
| #3585 | WP Hotel Booking Stripe Payment | 43 | 34 | 29 | 400 | Text Domain Mismatch | ||
| #3586 | WP Hotel Booking WPML Support | 43 | 10 | 52 | 400 | Direct Query | ||
| #3587 | WP SmartCrop | 43 | 43 | 12 | 4k+ | Output is not escaped | ||
| #3588 | Active Campaign & Contact Form 7 | 43 | 40 | 27 | 3k+ | Output is not escaped | ||
| #3589 | Advanced Dynamic Pricing and Discount Rules for WooCommerce | 44 | 2 | 813 | 20k+ | Non-prefixed namespace | ||
| #3590 | Buttonizer – Live Chat, AI Chatbot, Call, Chat, Contact Button | 44 | 24 | 71 | 50k+ | Non-prefixed constant | ||
| #3591 | Coming soon and Maintenance mode | 44 | 14 | 43 | 9k+ | Request data is not unslashed | ||
| #3592 | Comment Image | 44 | 19 | 23 | 1k+ | Output is not escaped | ||
| #3593 | Creative Addons for Elementor | 44 | 63 | 100 | 800 | Missing Arg Domain | ||
| #3594 | Github Embed | 44 | 18 | 35 | 1k+ | Non-prefixed global variable | ||
| #3595 | I Order Terms | 44 | 40 | 24 | 1k+ | Output is not escaped | ||
| #3596 | KKiapay WooCommerce Plugin | 44 | 20 | 25 | 400 | Output is not escaped | ||
| #3597 | LearnPress – BuddyPress Integration | 44 | 27 | 25 | 1k+ | Output is not escaped | ||
| #3598 | Roles & Capabilities | 44 | 24 | 79 | 1k+ | Nonce verification recommended | ||
| #3599 | Save and Close | 44 | 4 | 47 | 400 | Missing nonce verification | ||
| #3600 | LIQUID SPEECH BALLOON | 44 | 34 | 30 | 10k+ | Output is not escaped |