Show Video Ads with DFP (Beta)

In this tutorial, we’ll show how to set up Prebid to show a video ad from DFP. We’ll use the Video.js player and the AppNexus AST bidder, but the principles are the same across different video players and video-enabled bidders.


The code example below was built using the following libraries:

Also, you need to make sure to build Prebid.js with:

  • Support for at least one video-enabled bidder
  • Support for the dfpAdServerVideo ad server adapter, which will provide the video ad support

For example, to build with the AppNexus AST bidder adapter and the DFP Video ad server adapter, use the following command:

gulp build --modules=dfpAdServerVideo,appnexusAstBidAdapter

For more information about how to build with modules, see the Prebid.js project README.

Finally, your ad ops team needs to have set up line items in DFP following the instructions at Setting up Prebid Video in DFP.


This section will take you through the code you need to write to show video ads using Prebid.js and Video.js.

1. Create a video ad unit

First you need a video ad unit. It should look something like this. Don’t forget to add your own valid placement ID.

var videoAdUnit = {
    code: 'video',
    sizes: [640, 480],
    mediaTypes: {
        video: {
            context: "instream"
    bids: [{
        bidder: 'appnexusAst',
        params: {
            placementId: '9333431',
            video: {
                skippable: true,
                playback_methods: ['auto_play_sound_off']

2. Implement Custom Price Buckets

By default, Prebid.js caps all CPMs at $20. As a video seller, you may expect to see CPMs over $20. In order to receive those bids, you’ll need to implement custom price buckets using the setPriceGranularity method.

For instructions, see Custom Price Bucket with setPriceGranularity.

3. Request bids, build video URL

Next, we need to do the standard Prebid “add ad units and request bids” dance.

In the example below, our callback builds the video URL the player needs using the buildVideoUrl method from the DFP ad server module that we built into our copy of Prebid.js in the Prerequisites section.

For more information, see the API documentation for pbjs.adServers.dfp.buildVideoUrl. Understanding the arguments to this method is especially important if you plan to pass any custom parameters to DFP. The params key in the argument to buildVideoUrl supports all parameters from the DFP API.

Prebid Cache must be enabled
You must enable Prebid Cache as shown below in order for the DFP Ad Server Video module’s call to buildVideoUrl to work.

pbjs.que.push(function() {

    /* Required for the DFP video URL to be built correctly in the
    `bidsBackHandler` */
        usePrebidCache: true

        bidsBackHandler: function(bids) {
            var videoUrl = pbjs.adServers.dfp.buildVideoUrl({
                adUnit: videoAdUnit,
                params: {
                    iu: '/19968336/prebid_cache_video_adunit'

4. Invoke video player on Prebid video URL

In the body of the page, the following HTML and JS will show the ad:

<div class="example-video-container">
  <video id="vid1" class="video-js vjs-default-skin vjs-big-play-centered" controls
    <source src="" type='video/mp4'/>
    <source src="" type='video/webm'/>
    <source src="" type='video/ogg'/>

  function invokeVideoPlayer(url) {
    videojs("vid1").ready(function() {
        adTagUrl: url,
        playAdAlways: true,
        verbosity: 0,
        vpaidFlashLoaderPath: "",
        autoplay: true

If you have set up your ad server line items and creatives correctly, you should see an instream pre-roll video ad followed by the oceans video from the video.js homepage.

Working Examples

Note: Prebid video is designed to work across devices and browsers. This demo has been developed and tested only for Chrome desktop, Firefox desktop, and Chrome Android; additional device/browser support is planned to be added at a later date.

Below, find links to end-to-end “working examples” integrating Prebid.js demand with various video players: