Title: WP Bannerize Pro
Author: gfazioli
Published: <strong>28 An t-Samhain 2016</strong>
Last modified: 11 An Giblean 2026

---

Search plugins

![](https://ps.w.org/wp-bannerize-pro/assets/banner-772x250.png?rev=3503931)

![](https://ps.w.org/wp-bannerize-pro/assets/icon-256x256.png?rev=3503931)

# WP Bannerize Pro

 By [gfazioli](https://profiles.wordpress.org/gfazioli/)

[Download](https://downloads.wordpress.org/plugin/wp-bannerize-pro.1.13.0.zip)

[Live Preview](https://gd.wordpress.org/plugins/wp-bannerize-pro/?preview=1)

 * [Details](https://gd.wordpress.org/plugins/wp-bannerize-pro/#description)
 * [Reviews](https://gd.wordpress.org/plugins/wp-bannerize-pro/#reviews)
 *  [Installation](https://gd.wordpress.org/plugins/wp-bannerize-pro/#installation)
 * [Development](https://gd.wordpress.org/plugins/wp-bannerize-pro/#developers)

 [Support](https://wordpress.org/support/plugin/wp-bannerize-pro/)

## Description

Bannerize is a WordPress plugin for creating and managing advertising banners with
built-in analytics. Create image, HTML, or text banners, organize them into campaigns,
and track impressions, clicks, and click-through rates to measure the effectiveness
of your advertising.

For full documentation, visit the [Bannerize website](https://bannerize.vercel.app).

### Banner Types

 * **Image Banners** — Upload from your WordPress media library or link to external
   image URLs
 * **HTML Banners** — Use the rich text editor to create custom HTML, embed third-
   party ad code, iframes, or video players
 * **Text Banners** — Simple text-based banners with full formatting support

### Display Methods

 * **Gutenberg Block** — Native block editor integration with campaign and banner
   selection
 * **Shortcode** — `[wp_bannerize_pro]` with filtering by campaign, order, layout,
   device, and geolocation
 * **Widget** — Dedicated sidebar widget with all configuration options
 * **PHP Function** — `wp_bannerize_pro()` and `get_wp_bannerize_pro()` for theme
   templates

### Analytics

 * **Impressions Tracking** — Records every banner view with timestamp, referrer,
   IP, and user agent
 * **Clicks Tracking** — Records every banner click with the same contextual data
 * **CTR Calculation** — Automatic click-through rate computation
 * **Trend Charts** — Visualize performance over time (hourly, daily, weekly, monthly)
 * **Top Performers** — Rankings of best-performing banners and campaigns
 * **Export** — Download analytics data in CSV or SQL format
 * **Auto Cleanup** — Configurable data retention policies

### Advanced Features

 * **Campaigns** — Organize banners into campaigns for grouped display and filtering
 * **Scheduling** — Set start and end dates for time-limited promotions
 * **Performance Limits** — Set maximum impressions and clicks per banner
 * **Drag & Drop Sorting** — Reorder banners with ease
 * **Device Targeting** — Show banners only on mobile or desktop
 * **Geolocation** — Target banners by visitor country (via IPStack)
 * **User Roles** — Three built-in roles: Banners Manager, Campaigns Manager, Campaigns
   Viewer
 * **Custom Templates** — Override banner and campaign archive templates

### Dashboard Widget

A compact dashboard widget showing key banner performance metrics at a glance.

## Screenshots

 * [[
 * Add new banner by local media library
 * [[
 * Add new banner text
 * [[
 * Real time preview
 * [[
 * Date range rules
 * [[
 * Enable impressions and click for single banner
 * [[
 * Banner campaigns
 * [[
 * Analytics overview
 * [[
 * Single report with filters
 * [[
 * Settings
 * [[
 * Widget

## Blocks

This plugin provides 1 block.

 *   Bannerize Display a list of banners in accordance with the settings below.

## Installation

 1. Upload the entire content of plugin archive to your `/wp-content/plugins/` directory.
 2. Activate the plugin through the ‘Plugins’ menu in WordPress (deactivate and reactivate
    if you’re upgrading).
 3. Done. Enjoy.

For detailed instructions, see the [installation guide](https://bannerize.vercel.app/docs/getting-started/installation).

## FAQ

### 1. What is Bannerize?

Bannerize is a WordPress banner management plugin with built-in analytics. It helps
you create, organize, and track the performance of advertising banners on your site.

### 2. Where can I find the documentation?

Full documentation, guides, and release notes are available at [bannerize.vercel.app](https://bannerize.vercel.app).

### 3. What banner formats are supported?

Bannerize supports three types: local images (from your media library), remote images(
external URLs), and HTML/text banners (custom HTML, ad code, iframes).

### 4. How do I display banners?

You can display banners using a Gutenberg block, shortcode (`[wp_bannerize_pro]`),
sidebar widget, or PHP function (`wp_bannerize_pro()`).

### 5. Can I track banner performance?

Yes. Bannerize tracks impressions, clicks, and click-through rate (CTR) for every
banner. View analytics in the Bannerize dashboard and export data in CSV or SQL 
format.

### 6. Can I customize the HTML output?

Yes. Use the `wp_bannerize_classes` filter to add custom CSS classes, or configure
custom templates in Settings. See [Customize Output](https://bannerize.vercel.app/docs/display-banners/customize-output).

### 7. Does Bannerize support geolocation?

Yes. With an IPStack API key, you can target banners by visitor country using the`[
wp_bannerize_pro_geo]` shortcode or the widget geo field.

### 8. Can I request a new feature?

Yes! Please submit feature requests at [the support forum](https://wordpress.org/support/plugin/wp-bannerize-pro/).

### 9. Can I report a bug?

Yes! Please report bugs at [the support forum](https://wordpress.org/support/plugin/wp-bannerize-pro/).

## Reviews

![](https://secure.gravatar.com/avatar/4fa1e64c99d05cd03a3bdc1ed601e3d3a19d8c21b707f33545fd3f8c98c517cf?
s=60&d=retro&r=g)

### 󠀁[Really easy to use and works flawlessly](https://wordpress.org/support/topic/really-easy-to-use-and-works-flawlessly-2/)󠁿

 [tondosusanto](https://profiles.wordpress.org/tondosusanto/) 20 An Dàmhair 2022

Really easy to use and works flawlessly. After trying various plugins I finally 
found a really good one, simple and very easy to use. Thank you for creating this
plugin and hope that this plugin will continue to be developed and become one of
the default plugins for wordpress

![](https://secure.gravatar.com/avatar/ab54cb3392947e878772b5a8853d61c918dcca220342a04046c39bc6e4d4ae9f?
s=60&d=retro&r=g)

### 󠀁[Thanks for this easy plugin, works like a charme!](https://wordpress.org/support/topic/error-and-warnings-after-1-6-6-update/)󠁿

 [hellmute](https://profiles.wordpress.org/hellmute/) 27 An t-Iuchar 2022 13 replies

After testing under PHP 8.0 & WP 6.0.1 – i’ve got some errors and warnings in the
backend, when i visit the ‘Analytics Overview’ and ‘Analytics Report’. It still 
works by the way. If i switch back to php 7.4.1 the errors & warnings are gone. 
Thanks again for this great plugin!

![](https://secure.gravatar.com/avatar/dc0c4663f654efad28badbf08dcf36beec82f94dbc5609bac62503326e6da271?
s=60&d=retro&r=g)

### 󠀁[Simple and OK](https://wordpress.org/support/topic/simple-and-ok-3/)󠁿

 [trillebar](https://profiles.wordpress.org/trillebar/) 14 An Dùbhlachd 2019

Missing impressions when using iframe-ads. Would be nice to be able to see the impressions(
number of times the iframe is loaded).

![](https://secure.gravatar.com/avatar/a470e32231e03d9f5d65746f8afba730ea1b75ee89b92d1df279ab00eae5bf9e?
s=60&d=retro&r=g)

### 󠀁[Great Plugin, great support!](https://wordpress.org/support/topic/great-plugin-great-support-1114/)󠁿

 [Soela](https://profiles.wordpress.org/soela/) 13 An Dùbhlachd 2019

This is a plugin that reliably does what it promises in a straightforward way. Plus
the author provides a real five star support: before I even could try out his workaround
for a question I had, it was turned into a new feature in a plugin update, all this
within less than 24 hours. Wow! I don’t have the slightest need to try out any other
banner plugin. Thanks a bunch!

![](https://secure.gravatar.com/avatar/e6ea3e266fc2e4b1124b8131d86ce76bfc4d77634cf5bfab080082795b05c322?
s=60&d=retro&r=g)

### 󠀁[Highly optimized plugin](https://wordpress.org/support/topic/highly-optimized-plugin/)󠁿

 [peperompe](https://profiles.wordpress.org/peperompe/) 15 An Gearran 2019

The new mobile function is the best. It is also light and perfect for a fast wordpress.

![](https://secure.gravatar.com/avatar/b82e2ed11457b47ee625b66bdae08bae2f81f0daa252ff8ef0dd29a7223bc4fa?
s=60&d=retro&r=g)

### 󠀁[Great Plugin for Advertisement Banners](https://wordpress.org/support/topic/great-plugin-for-advertisement-banners/)󠁿

 [virgilio27](https://profiles.wordpress.org/virgilio27/) 8 An Gearran 2019

Best plugin for add banners. I’ve used it on my website and it has options that 
others don’t have. Also it’s optimized and compatible with the latest versions of
Wordpress

 [ Read all 10 reviews ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/)

## Contributors & Developers

“WP Bannerize Pro” is open source software. The following people have contributed
to this plugin.

Contributors

 *   [ gfazioli ](https://profiles.wordpress.org/gfazioli/)

“WP Bannerize Pro” has been translated into 2 locales. Thank you to [the translators](https://translate.wordpress.org/projects/wp-plugins/wp-bannerize-pro/contributors)
for their contributions.

[Translate “WP Bannerize Pro” into your language.](https://translate.wordpress.org/projects/wp-plugins/wp-bannerize-pro)

### Interested in development?

[Browse the code](https://plugins.trac.wordpress.org/browser/wp-bannerize-pro/),
check out the [SVN repository](https://plugins.svn.wordpress.org/wp-bannerize-pro/),
or subscribe to the [development log](https://plugins.trac.wordpress.org/log/wp-bannerize-pro/)
by [RSS](https://plugins.trac.wordpress.org/log/wp-bannerize-pro/?limit=100&mode=stop_on_copy&format=rss).

## Changelog

### 1.13.0

Feature, Security & Compatibility Update

#### New Features

 * Added WebP image format support for local and remote banners
 * WebP banners can now be uploaded from the media library or linked via external
   URLs
 * Updated remote image validation to accept image/webp content type

#### Security

 * Hardened analytics queries: campaign and banner ID filters now use $wpdb->prepare()
   placeholders instead of string interpolation
 * Fixed invalid SQL placeholder (%1s) in analytics cleanup LIMIT clause, replaced
   with %d
 * Hardened meta key JOINs in banner query builder with $wpdb->prepare() for all
   meta_key values
 * Fixed SQL export using unescaped table name in INSERT statements
 * Added capability check (manage_banners) to admin error notice display
 * Used esc_html__() for translatable admin notice output

#### Bug Fixes

 * Fixed PHP 8.0+ function str_starts_with() usage that broke compatibility with
   PHP 7.4
 * Fixed duplicate entries in image MIME types array
 * Fixed uninitialized $width and $height variables when image size detection fails
 * Fixed potential fatal error when mime type is not detected during banner save
 * Fixed string-to-integer comparison in banner list column for max impressions/
   clicks
 * Fixed Gutenberg block missing “type” field for orderby attribute in block.json
   causing REST API warnings
 * Fixed fatal error “read property ID on null” in getBannerClasses() when banner
   post is null
 * Fixed esc_attr() used instead of esc_html() for impressions/clicks column output
 * Fixed incorrect sanitization order (absint on esc_attr result) in pagination 
   input

#### Improvements

 * Redesigned horizontal layout with modern flexbox and responsive 2-column grid
   on wide screens, single column on mobile
 * Vertical layout now uses flexbox with consistent gap spacing
 * Banner images are fully responsive with max-width: 100% and auto height
 * Refactored banner query meta key JOINs from repetitive code to loop-based construction
 * Removed dead code: commented-out create_function() reference
 * Refreshed readme.txt with structured description, expanded FAQ, and documentation
   links
 * Rewrote README.md with badges, features, tech stack, and project structure

### 1.12.0

Security, Bug Fixes & Improvements

#### Security

 * Fixed SQL injection vulnerabilities in analytics queries (impressions, clicks,
   CTR trends)
 * Fixed SQL injection in the legacy importer controller
 * Fixed XSS in banner rendering: added proper escaping for image src, alt, title,
   link href, and target attributes
 * Fixed XSS in text banner rendering: added escaping for width/height style attributes
 * Fixed stored XSS risk: sanitized IP address and User-Agent before saving to the
   database
 * Fixed SSRF in image size detection: replaced raw cURL and getimagesize() with
   wp_remote_get()
 * Fixed SSRF in remote image validation: replaced raw cURL with wp_remote_head()
 * Hardened options update endpoint with schema validation, key whitelist, and sanitize_file_name()
   for template paths
 * Hardened wp_loaded banner endpoint: added post type check, ID validation, null
   safety, and wp_kses_post() output filtering
 * Removed full plugin options exposure from public frontend
 * Used wp_json_encode() for all inline script output to prevent script injection

#### Bug Fixes

 * Fixed Gutenberg block not filtering by campaign
 * Fixed banner layout always forced to vertical regardless of the layout parameter
 * Fixed banner preview meta box not appearing in the editor
 * Fixed analytics data not deleted when a banner is permanently removed
 * Fixed cron cleanup events not cleared when tracking is disabled or plugin is 
   deactivated
 * Fixed N+1 query issue: banner click/impression counts with value 0 no longer 
   trigger unnecessary COUNT queries
 * Fixed resetOptions calling a non-existent AJAX action
 * Fixed DataTable crash when a banner has no campaigns assigned
 * Fixed CSV export using incorrect escape sequence instead of RFC 4180 standard

#### Improvements

 * Replaced remove_all_filters(‘parse_query’) with explicit suppress_filters
 * Replaced deprecated get_terms() positional arguments with array syntax
 * Replaced date() with gmdate() for WordPress coding standards
 * Aligned all SQL queries to use %i placeholder for table identifiers
 * Removed all debug error_log() calls and console.log() from production code
 * Migrated CPT meta box registration to registerMetaBoxes()

### 1.11.0

Security & Enhancement Updates

#### Security

 * Added SSRF protection for external banner image URLs
 * Added wp_bannerize_is_remote_image() validation method
 * Only allows JPEG, PNG, and GIF formats from external sources
 * Added admin error notice when invalid image URLs are submitted

#### Improvements

 * Standardized code formatting and indentation
 * Added user-friendly error messages for invalid banner image URLs

## Meta

 *  Version **1.13.0**
 *  Last updated **1 seachdain ago**
 *  Active installations **900+**
 *  WordPress version ** 6.2 or higher **
 *  Tested up to **6.9.4**
 *  PHP version ** 7.4 or higher **
 *  Languages
 * [English (US)](https://wordpress.org/plugins/wp-bannerize-pro/), [Italian](https://it.wordpress.org/plugins/wp-bannerize-pro/),
   and [Portuguese (Brazil)](https://br.wordpress.org/plugins/wp-bannerize-pro/).
 *  [Translate into your language](https://translate.wordpress.org/projects/wp-plugins/wp-bannerize-pro)
 * Tags
 * [ads](https://gd.wordpress.org/plugins/tags/ads/)[advertising](https://gd.wordpress.org/plugins/tags/advertising/)
   [analytics](https://gd.wordpress.org/plugins/tags/analytics/)[banner](https://gd.wordpress.org/plugins/tags/banner/)
   [campaign](https://gd.wordpress.org/plugins/tags/campaign/)
 *  [Advanced View](https://gd.wordpress.org/plugins/wp-bannerize-pro/advanced/)

## Ratings

 4.9 out of 5 stars.

 *  [  9 5-star reviews     ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/?filter=5)
 *  [  1 4-star review     ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/?filter=4)
 *  [  0 3-star reviews     ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/?filter=3)
 *  [  0 2-star reviews     ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/?filter=2)
 *  [  0 1-star reviews     ](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/?filter=1)

[Your review](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/#new-post)

[See all reviews](https://wordpress.org/support/plugin/wp-bannerize-pro/reviews/)

## Contributors

 *   [ gfazioli ](https://profiles.wordpress.org/gfazioli/)

## Support

Issues resolved in last two months:

     2 out of 2

 [View support forum](https://wordpress.org/support/plugin/wp-bannerize-pro/)

## Donate

Would you like to support the advancement of this plugin?

 [ Donate to this plugin ](https://www.paypal.com/donate/?hosted_button_id=L77YYA8AVH2UW)