This document will provide information to help you set up the ad server so ads of various media formats will be rendered properly. A couple of questions to consider:
Here’s a set of basic creative recommendations to use as a starting point:
Depending on the advertising scenarios you support and how they were implemented, these are the types of creatives that may be attached to your ad server line items.
![]() |
---|
- AMP - Prebid Mobile Bidding-Only - Prebid.js when you use AMP or PBSDK and want to keep line item setup simple. |
The original idea behind the Prebid Universal Creative (which we fondly call ‘the PUC’) was that it would be one set of javascript that would render banners, non-instream, and native creatives.
However, having a lot of functionality (even if not quite “universal”) comes with some drawbacks:
So now there are a number of different options for rendering Prebid ads that win the auction. The PUC is still available as a collection of rendering routines. You can find full details in the Prebid Universal Creative Overview.
Terminology tip: the PUC is the script that’s loaded from the CDN. The block of HTML and javascript in your ad server is sometimes called the “PUC agent” - it’s what tells your browser/webview to load the actual PUC.
If you choose to use the Prebid Universal Creative, you’ll need to decide where to load it from:
https://cdn.jsdelivr.net/npm/prebid-universal-creative@${VERSION}/dist/*
- substitute ${VERSION}
with a version number. Using Prebid.js 10.11.0 or later, you may also use the hb_ver
targeting key; see create your creatives.
![]() |
---|
- Prebid.js with no need to worry about AMP or Prebid Mobile - You’re using a tool that can modify the creative if needed |
If you have line items that target only browsers running Prebid.js, you can use dynamic creatives to avoid the PUC performance penalty but keep the same ease of setup and maintenance.
![]() |
---|
- Instream video - Prebid Mobile non-instream video - Prebid Mobile rewarded video (GAM Bidding-only integration) |
VAST video does not use the PUC. Instead, video bids provide VAST that Prebid caches to obtain a cache ID that can be retrieved with a URL. The cache ID is passed as a key value to the ad server. (See Video Overview for details.)
When you’re running campaigns with video creatives, the primary decision you need to make is where to cache your video bids. You’ll enter this location in the VastUrl you add to the line item. The cache location is typically independent of the bidders. The most common cache location is https://prebid.adnxs.com, but this may vary with your setup. See Setting Up Video In GAM for detailed instructions on configuring a video creative in GAM.
![]() |
---|
Prebid Mobile rendering scenarios: - Display Banner -Video Banner - Display Interstitial - Video Interstitial |
When the mobile app is coded to use the Prebid-Rendered scenario (iOS,Android), there’s no PUC. Instead, a special ad server creative is used. See the GAM Prebid Mobile Rendering Ad Ops page for details.
![]() |
---|
- Prebid Mobile rewarded video (Prebid rendered scenario) |
When the mobile app is coded to use the Prebid-Rendered scenario (iOS,Android), there’s a special VAST URL required. See the GAM Prebid Mobile Rendering Ad Ops page for details.
![]() |
---|
- Prebid.js Native |
Native ads require close collaboration between web designers, engineering, and ad ops. The primary decision to be made that affects ad ops is where to store the rendering template. The options are:
If you already have templates stored in your ad server for some native ads, it might make sense to also store the templates for Prebid there and keep everything together and consistent. This also gives ad ops control over when templates change.
The second two options require engineering to make any changes when template updates are required. Because native ad formatting is tied to the look of the site, these options could fit in with normal site maintenance.
Each option requires a different PUC ad tag to be used in the associated creatives, so be sure to get the correct script (and CSS file) from the engineers.
Engineering details outlining each template storage option can be found in the Prebid.js Native Implementation Guide.
![]() |
---|
- Prebid Mobile webview native |
Like Prebid.js, Mobile native ads require close collaboration between web designers, engineering, and ad ops. However, mobile only supports hosting the template in the ad server.
Prebid Mobile uses a special script called ‘native-trk.js’ to render native creatives implemented on a webview. See the GAM Native Creatives page for details.
![]() |
---|
- Prebid Mobile app-rendered native |
The final native option is when the app itself does the rendering. See Prebid In-App Native for GAM for more information.
Mobile apps that are integrated with mediation platforms AdMob or MAX should follow those special instructions.
You can name your creatives whatever makes sense to your organization. We recommend names in the following format: Prebid - Type - Size - N. For example, a banner creative using the PUC would be Prebid - banner - 1x1 - 1
.
For display ads, you need to decide how you’re going to represent the size options in the ad server. There are three creative size modes:
If you select this mode, in the ad server you’ll set the size of all your Prebid creatives to 1x1. The creatives will then be resized based on the value supplied by the demand partner in the hb_size key. This is the simplest option to implement and requires the fewest number of creatives to be created.
If you’re working with Google Ad Manager (GAM) we recommend you create one general 1x1 creative, then duplicate it to attach 3 - 5 identical creatives to each line item. The reason for this is that GAM doesn’t make a distinction between creatives with images attached and creatives with a script that could be used to retrieve one of many different images. It treats every creative as an individual image, and allows each one to be served to only one ad unit per page.
For Prebid line items, this means that if your page has multiple ad slots that fit the same line item targeting, GAM would allow only one of them to display the creative, not realizing that one creative could point to different images. Attaching multiple identical creatives to each line item ensures that creatives from a line item matching the targeting on multiple ad slots can serve on the same page.
For example, say you’re using “low” granularity, which means that one line item covers bids from $1.00 to $1.49. If you have three creatives associated with that line item, the page could not display anymore than three Prebid bids in that price range. If you have infinite scroll pages, you’ll have to consider the tradeoff for how many copies of creatives you want to have.
With this mode, you set specific sizes on the creatives. This mode allows for more precise reporting if you’re interested in knowing the exact sizes of creatives being served from Prebid. As with the 1x1 option, we recommend you create 3 - 5 duplicate creatives of each size. The downside is that this requires a lot of creatives per line item. If you specify 20 sizes, you would need as many as 100 duplicate creatives.
We recommend against using this mode, but are aware some publishers use it for reporting purposes. With this mode, you would target your line item based on the value of the hb_size key. This would require you to create one line item for every size, for every bidder, for every price. The number of line items required could get extremely large. Here’s an example (see Price Granularity for more details):
This scenario would require you to create 10,000 line items (10 x 200 x 5). If you were to use either 1x1 mode or creative-level sizing you would need only 2,000 line items.
Another decision you need to make with regards to banner and native creatives is whether to run them in SafeFrames. A SafeFrame is defined by the IAB as “a managed API-enabled iframe that opens a line of communication between the publisher page and the iframe-contained ad creative.” SafeFrames provide an added layer of security by separating the ad from your web page.
We recommend using SafeFrames for banner and native creatives, but there are some things to keep in mind if you do this. For example:
If you don’t trust all your bidders to provide creatives that can safely run inside of SafeFrames, then you’ll want to consider using Send All Bids (the default), which will enable you to allow some bidders to use SafeFrames and some not.
Prebid documentation for each bidder provides information on whether the bidder supports SafeFrames.
Be sure to check with bidders directly if you have questions about their SafeFrame support.