Security Issues
Issue Codes
39 normalized finding codes in this category.
Output is not escaped
WordPress.Security.EscapeOutput.OutputNotEscaped
Dynamic data is printed to the page without an escaping function for the output context.
Request data is not unslashed
WordPress.Security.ValidatedSanitizedInput.MissingUnslash
Input from a WordPress request superglobal is used before removing WordPress-added slashes.
Input is not sanitized
WordPress.Security.ValidatedSanitizedInput.InputNotSanitized
Request data is used without being cleaned for the expected type or format.
Nonce verification recommended
WordPress.Security.NonceVerification.Recommended
The code reads request data in a place where Plugin Check recommends a nonce check.
Input is not validated
WordPress.Security.ValidatedSanitizedInput.InputNotValidated
Request data is used without checking that it is allowed for the operation.
Missing nonce verification
WordPress.Security.NonceVerification.Missing
A request handler uses request data without verifying that the request was intentionally created by WordPress.
Unsafe printing function
WordPress.Security.EscapeOutput.UnsafePrintingFunction
A printing function is outputting dynamic content without proving that the content is escaped.
Database parameter is not escaped
PluginCheck.Security.DirectDB.UnescapedDBParameter
A value is passed into database-related code without escaping, preparation, or strict allowlisting.
wp redirect wp redirect
WordPress.Security.SafeRedirect.wp_redirect_wp_redirect
Plugin Check reported a security-sensitive coding pattern that needs review.
SQL query is not prepared
WordPress.DB.PreparedSQL.NotPrepared
A database query includes dynamic data without using `$wpdb->prepare()` or an equivalent safe pattern.
Exception output is not escaped
WordPress.Security.EscapeOutput.ExceptionNotEscaped
An exception message or related exception value is printed without escaping.
Interpolated SQL is not prepared
WordPress.DB.PreparedSQL.InterpolatedNotPrepared
Variables are interpolated into a SQL string before the query is prepared.
Setting is missing a sanitization callback
PluginCheck.CodeAnalysis.SettingSanitization.register_settingMissing
A registered setting does not define a sanitization callback.
Unfinished Prepare
WordPress.DB.PreparedSQLPlaceholders.UnfinishedPrepare
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Quoted Simple Placeholder
WordPress.DB.PreparedSQLPlaceholders.QuotedSimplePlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Replacements Wrong Number
WordPress.DB.PreparedSQLPlaceholders.ReplacementsWrongNumber
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Input is not validated or sanitized
WordPress.Security.ValidatedSanitizedInput.InputNotValidatedNotSanitized
Request data is used without both cleanup and an allowability check.
Plugin menu slug uses __FILE__
WordPress.Security.PluginMenuSlug.Using__FILE__
Plugin Check reported a security-sensitive coding pattern that needs review.
Like Wildcards In Query
WordPress.DB.PreparedSQLPlaceholders.LikeWildcardsInQuery
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Heredoc Output Not Escaped
WordPress.Security.EscapeOutput.HeredocOutputNotEscaped
A value reaches browser output without clear escaping for the final HTML context.
Unquoted Complex Placeholder
WordPress.DB.PreparedSQLPlaceholders.UnquotedComplexPlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Unsupported Identifier Placeholder
WordPress.DB.PreparedSQLPlaceholders.UnsupportedIdentifierPlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Unnecessary Prepare
WordPress.DB.PreparedSQLPlaceholders.UnnecessaryPrepare
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Like Wildcards In Query With Placeholder
WordPress.DB.PreparedSQLPlaceholders.LikeWildcardsInQueryWithPlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Unsupported Placeholder
WordPress.DB.PreparedSQLPlaceholders.UnsupportedPlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
mysql mysqli real escape string
WordPress.DB.RestrictedFunctions.mysql_mysqli_real_escape_string
The plugin uses a raw MySQL extension or class instead of WordPress database APIs.
Like Without Wildcards
WordPress.DB.PreparedSQLPlaceholders.LikeWithoutWildcards
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Quoted Dynamic Placeholder Generation
WordPress.DB.PreparedSQLPlaceholders.QuotedDynamicPlaceholderGeneration
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Deprecated function: like_escape
WordPress.WP.DeprecatedFunctions.like_escapeFound
The plugin uses a WordPress API, parameter, class, or value that has been deprecated.
mysql mysql real escape string
WordPress.DB.RestrictedFunctions.mysql_mysql_real_escape_string
The plugin uses a raw MySQL extension or class instead of WordPress database APIs.
Deprecated function: attribute_escape
WordPress.WP.DeprecatedFunctions.attribute_escapeFound
The plugin uses a WordPress API, parameter, class, or value that has been deprecated.
Unescaped Literal
WordPress.DB.PreparedSQLPlaceholders.UnescapedLiteral
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Missing Replacements
WordPress.DB.PreparedSQLPlaceholders.MissingReplacements
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
curl curl escape
WordPress.WP.AlternativeFunctions.curl_curl_escape
The plugin uses raw cURL functions instead of the WordPress HTTP API.
curl curl unescape
WordPress.WP.AlternativeFunctions.curl_curl_unescape
The plugin uses raw cURL functions instead of the WordPress HTTP API.
Deprecated function: js_escape
WordPress.WP.DeprecatedFunctions.js_escapeFound
The plugin uses a WordPress API, parameter, class, or value that has been deprecated.
register setting Invalid
PluginCheck.CodeAnalysis.SettingSanitization.register_settingInvalid
Plugin Check reported a security-sensitive coding pattern that needs review.
Quoted Identifier Placeholder
WordPress.DB.PreparedSQLPlaceholders.QuotedIdentifierPlaceholder
A SQL query is built in a way that Plugin Check cannot verify as safely prepared.
Deprecated function: sanitize_user_object
WordPress.WP.DeprecatedFunctions.sanitize_user_objectFound
The plugin uses a WordPress API, parameter, class, or value that has been deprecated.
Affected Plugins
| Rank | Plugin | Score | Errors | Warnings | Installs | Updated | Top Issue |
|---|---|---|---|---|---|---|---|
| #4751 | Lightweight Accordion | 91 | 4 | 3 | 10k+ | Non-prefixed function | |
| #4752 | Limit Revisions | 91 | 7 | 1 | 1k+ | Missing Arg Domain | |
| #4753 | Link Juice Keeper | 91 | 4 | 36 | 10k+ | Non-prefixed hook name | |
| #4754 | MAS Static Content | 91 | 3 | 7 | 10k+ | Non-prefixed hook name | |
| #4755 | matchHeight | 91 | 6 | 2 | 2k+ | Non-prefixed global variable | |
| #4756 | MC4WP: WPML Integration | 91 | 7 | 9 | 2k+ | Missing direct file access protection | |
| #4757 | Meks Quick Plugin Disabler | 91 | 3 | 8 | 1k+ | Nonce verification recommended | |
| #4758 | Ollie Menu Designer | 91 | 43 | 3k+ | Non-prefixed global variable | ||
| #4759 | Pantheon Advanced Page Cache | 91 | 10 | 6 | 10k+ | Request data is not unslashed | |
| #4760 | Parent Category Toggler | 91 | 6 | 0 | 10k+ | Missing direct file access protection | |
| #4761 | PDF Embedder | 91 | 1 | 7 | 300k+ | Non-prefixed class | |
| #4762 | Preload Featured Images | 91 | 2 | 2 | 1k+ | Output is not escaped | |
| #4763 | reBusted! | 91 | 7 | 3 | 6k+ | Missing direct file access protection | |
| #4764 | Responsive Tabs | 91 | 59 | 9 | 4k+ | Non Singular String Literal Domain | |
| #4765 | REST API Toolbox | 91 | 25 | 0 | 2k+ | Missing Arg Domain | |
| #4766 | Restricted Site Access | 91 | 14 | 11 | 10k+ | Missing Arg Domain | |
| #4767 | SearchWP Modal Search Form | 91 | 9 | 9 | 5k+ | trademarked term | |
| #4768 | Simple Membership Form Shortcode | 91 | 7 | 1 | 2k+ | Missing direct file access protection | |
| #4769 | Simple WP Maintenance Mode | 91 | 6 | 4 | 2k+ | trademarked term | |
| #4770 | Simply Show IDs | 91 | 5 | 1 | 3k+ | Missing direct file access protection | |
| #4771 | Slim SEO – A Fast & Automated SEO Plugin For WordPress | 91 | 3 | 9 | 60k+ | Database parameter is not escaped | |
| #4772 | Smooth Page Scroll Up/Down Buttons | 91 | 1 | 5 | 2k+ | Non-prefixed function | |
| #4773 | Widgets for Social Photo Feed | 91 | 1 | 147 | 10k+ | Non-prefixed global variable | |
| #4774 | Storefront Footer Bar | 91 | 6 | 2 | 3k+ | Missing Arg Domain | |
| #4775 | Tickera – Sell Tickets & Manage Events | 91 | 5 | 8 | 2k+ | Nonce verification recommended | |
| #4776 | Timeline Express HTML Excerpts Add-on | 91 | 9 | 6 | 1k+ | Text Domain Mismatch | |
| #4777 | Tumblr Importer | 91 | 7 | 9 | 10k+ | wp function not compatible with requires wp | |
| #4778 | WebAuthn Provider for Two Factor | 91 | 6 | 14 | 1k+ | Missing Arg Domain | |
| #4779 | Unveil Lazy Load | 91 | 2 | 6 | 2k+ | error log error log | |
| #4780 | VenoBox Lightbox | 91 | 11 | 4 | 1k+ | Text Domain Mismatch | |
| #4781 | Min Max Quantities – Set Minimum/Maximum Quantity & Price Limits with Step Control for WooCommerce | 91 | 2 | 30 | 10k+ | Non-prefixed hook name | |
| #4782 | WCFM – Multivendor Marketplace REST API for WooCommerce | 91 | 5 | 34 | 1k+ | Non-prefixed hook name | |
| #4783 | Bootstrap Blocks | 91 | 8 | 30 | 10k+ | Non-prefixed global variable | |
| #4784 | WP Mobile Detect | 91 | 4 | 6 | 5k+ | trademarked term | |
| #4785 | WP Session Manager | 91 | 5 | 16 | 2k+ | Direct Query | |
| #4786 | WPC AJAX Add to Cart for WooCommerce | 91 | 5 | 28 | 10k+ | Non-prefixed hook name | |
| #4787 | WPConsent – Cookie Banner & Cookie Consent for Privacy Compliance (GDPR / CCPA / EU Compliance Cookie Notice) | 91 | 2 | 12 | 100k+ | Post Not In exclude | |
| #4788 | DearFlip – PDF Flipbook, 3D Flipbook, PDF embed, PDF viewer | 92 | 10 | 11 | 200k+ | Missing direct file access protection | |
| #4789 | Add Code To Head | 92 | 2 | 8 | 3k+ | Non-prefixed global variable | |
| #4790 | Admin Taxonomy Filter | 92 | 3 | 3 | 5k+ | Non-prefixed class | |
| #4791 | Ads.txt Manager | 92 | 4 | 4 | 100k+ | Missing direct file access protection | |
| #4792 | Table Field Add-on for ACF and SCF | 92 | 9 | 3 | 50k+ | Text Domain Mismatch | |
| #4793 | Bangla Web Fonts | 92 | 4 | 0 | 2k+ | Non Enqueued Stylesheet | |
| #4794 | Canada Post Shipping For WooCommerce | 92 | 4 | 0 | 2k+ | Output is not escaped | |
| #4795 | Change Text Case | 92 | 4 | 1 | 2k+ | Missing Arg Domain | |
| #4796 | Contact Form 7 Shortcode Enabler | 92 | 4 | 3 | 10k+ | trademarked term | |
| #4797 | Cookie Consent – GDPR & CCPA Cookie Banner & Consent Manager | 92 | 16 | 10k+ | Direct Query | ||
| #4798 | Cryptocurrency Widgets – Price Ticker & Coins List | 92 | 4 | 36 | 7k+ | Non-prefixed global variable | |
| #4799 | Daisy Titles — Style & Hide Page and Post Titles | 92 | 1 | 5 | 3k+ | Discouraged text-domain loading | |
| #4800 | ERE Colors – Essential Real Estate Add-On | 92 | 4 | 1 | 1k+ | Missing direct file access protection |