Construct a Wistia Embed Code

Learn to programmatically construct an embed code starting with just the video ID!

If you need to build lots of embed codes for your videos dynamically, this guide breaks down how to dynamically construct or request embed codes for each embed type.

πŸ“

Note

The Wistia APIs were specifically built for videos in projects. We do not formally support using our APIs for audio files in projects, or audio or video episodes in Channels at this time. For the most reliable experience, we recommend continuing to use these for videos in projects.

Embed Code Types

Before we get started, let's define some jargon around embed code types. At this time, the two (and a half) embed code types you can use with Wistia are:

  • async - in the Wistia app we call this the "Standard" embed. If you want to use the Player API to interact with your video, use this embed type.
  • iframe - in the Wistia app we call this the "Fallback" embed. It's super simple, supported almost everywhere, and easy to build.
  • popover - our async embed, but with more

Using the oEmbed Endpoint

Here's a quick primer on using the Wistia oEmbed endpoint, which is the easiest way to generate each of the Wistia embed code types.

The Endpoint

Our oEmbed endpoint is: https://fast.wistia.net/oembed

By default, the endpoint returns JSON, but use https://fast.wistia.net/oembed.xml to return XML.

Our oEmbed endpoint recognizes two URL formats, iframe embed URLs and public media URLs.

iframe Embed URLs

You can build these for single videos or generate them through your account. If you're looking to build these for a playlist, that feature has been deprecated and we recommend using embed links.

Examples

  • single video - https://fast.wistia.net/embed/iframe/26sk4lmiix

Public Media URLs

Public Media URLs are the address to a video in your account.

  • example - https://support.wistia.com/medias/26sk4lmiix

The Regex

If you're looking to automatically detect Wistia URLs and run them against our
endpoint, we recommend using this regular expression:

/https?:\/\/(.+)?(wistia\.com|wi\.st)\/(medias|embed)\/.*/

Or if you don't speak regex, here's what we're matching:

http(s)://*wistia.com/medias/*
http(s)://*wistia.com/embed/*
http(s)://*wi.st/medias/*
http(s)://*wi.st/embed/*

Note, it's likely we'll add support for more URLs in the future so feel free to use a more general regular expression so you don't miss out on future enhancements! Perhaps this:

/https?:\/\/(.+)?(wistia\.com|wi\.st)\/.*/

oEmbed Parameters

The required URL parameter that's passed in supports all the options detailed in the Player API.

We also accept some additional parameters that can change the output of the embed code:

NameTypeDescription
callbackstringOnly applicable to JSON requests. When specified, json is wrapped in a javascript function given by the callback param. This is to facilitate JSONP requests.
embedTypestringOnly applicable to videos and playlists. Accepts async, iframe, async_popover, playlist_iframe, playlist_api, playlist_popover, and open_graph_tags (videos only).
widthintegerThe requested width of the video embed. Defaults to the native size of the video or 640, whichever is smaller.
heightintegerThe requested height of the video embed. Defaults to the native size of the video or 360, whichever is smaller.
handlestringOnly applicable to async, and playlist_api embed types. Sets the javascript handle. Default is wistiaEmbed for medias and wistiaPlaylist for playlists.

You can also get a popover embed code by using the async embedType, and adding popover=true to the URL. Check out our tutorial for a full break down.

If given a width, height, maxwidth, or maxheight parameter (or any combination of those), the other dimensions in the resulting embed code may change so that the video's aspect ratio is preserved.

πŸ“

Note

These parameters are attached to the Wistia media URL, and not the oEmbed call. So they must be URL-encoded to travel with the Wistia URL.

Troubleshooting

  1. If an invalid URL (one that doesn't match our regular expression above) is given, the endpoint will return 404 Not Found.
  2. If an unparseable URL is given in the URL param, the endpoint will return 404 Not Found.
  3. If a media is found but has no available embed code, the endpoint will return 501 Not Implemented. Only videos are embeddable.
  4. If a playlist is found but has no videos, the endpoint will return 501 Not Implemented.

Standard (async) Embed Tutorial

Using the oEmbed

Here is how we can get the embed code and some information for a video at https://support.wistia.com/medias/26sk4lmiix in JSON format:

Quick noteβ€”we have yet to update the oEmbed return to automatically return the Standard (async) embed code type. Currently, this is Wistia's recommended embed type. To call the Standard embed:

curl "https://fast.wistia.net/oembed?url=https%3A%2F%2Fsupport.wistia.com%2Fmedias%2F26sk4lmiix&embedType=async"

Which returns:

{
  "version":"1.0",
  "type":"video",
  "html":"<script charset=\"ISO-8859-1\" src=\"//fast.wistia.com/assets/external/E-v1.js\" async></script><div class=\"wistia_embed wistia_async_26sk4lmiix\" style=\"height:540px;width:960px\">&nbsp;</div>",
  "width":960,
  "height":540,
  "provider_name":"Wistia, Inc.",
  "provider_url":"https://wistia.com",
  "title":"Nice.",
  "thumbnail_url":"https://embed-ssl.wistia.com/deliveries/56cacb9a5d6ea04b1f29defaf4b55d1ec979e1b0.jpg?image_crop_resized=960x540",
  "thumbnail_width":960,
  "thumbnail_height":540,
  "duration":44.457
}

The html returned in the JSON body is the Standard embed code you can use to add this video to your website.

For all the fine details about the options supported, see the official oEmbed spec.

Using a Template Approach (Standard)

If you want to avoid making the additional request against the oEmbed endpoint, you can also build an Standard embed code template, and then add in the video's hashed ID.

For this example we'll be using a hashed ID of 'abcde12345'.

The basic Standard embed code looks like this:

<script charset="ISO-8859-1" src="//fast.wistia.com/assets/external/E-v1.js" async></script><div class="wistia_embed wistia_async_<media-hashed-id>" style="height:366px;width:600px">&nbsp;</div>

So to use this template with the hashed ID 'abcde12345', we insert it in
place of <media-hashed-id>:

<script charset="ISO-8859-1" src="//fast.wistia.com/assets/external/E-v1.js" async></script><div class="wistia_embed wistia_async_abcde12345" style="height:366px;width:600px">&nbsp;</div>

πŸ“

Note

Because height and width will change based on your video's content, the template approach is probably best when your entire library uses a consistent size.

If you'd like to use a responsive template:

<script charset="ISO-8859-1" src="//fast.wistia.com/assets/external/E-v1.js" async></script><div class="wistia_responsive_padding" style="padding:56.25% 0 28px 0;position:relative;"><div class="wistia_responsive_wrapper" style="height:100%;left:0;position:absolute;top:0;width:100%;"><div class="wistia_embed wistia_async_abcde12345 videoFoam=true" style="height:100%;width:100%">&nbsp;</div></div></div>

Popover Embed Tutorial

To grab a popover oEmbed, you can use the embedType=async_popover, or add &popover=true to the request:

curl "https://fast.wistia.net/oembed?url=https%3A%2F%2Fsupport.wistia.com%2Fmedias%2F26sk4lmiix&embedType=async&popover=true"
curl "https://fast.wistia.net/oembed?url=https%3A%2F%2Fsupport.wistia.com%2Fmedias%2F26sk4lmiix&embedType=async_popover"

Both options return:

{
  "version":"1.0",
  "type":"video",
  "html":"<script charset=\"ISO-8859-1\" src=\"//fast.wistia.com/assets/external/E-v1.js\" async></script><span class=\"wistia_embed wistia_async_26sk4lmiix popover=true\" style=\"display:inline-block;height:100px;width:150px\">&nbsp;</span>",
  "width":960,
  "height":540,
  "provider_name":"Wistia, Inc.",
  "provider_url":"https://wistia.com",
  "title":"Nice.",
  "thumbnail_url":"https://embed-ssl.wistia.com/deliveries/56cacb9a5d6ea04b1f29defaf4b55d1ec979e1b0.jpg?image_crop_resized=960x540",
  "thumbnail_width":960,
  "thumbnail_height":540,
  "duration":44.457
}

For more fun embed options, check out the full list of embed options.

Fallback (iframe) Embed Tutorial

Using the oEmbed

And finally, here's a quick tutorial for calling the iframe (Fallback) embed. You may also call the iframe embed code type:

curl "https://fast.wistia.net/oembed?url=https%3A%2F%2Fsupport.wistia.com%2Fmedias%2F26sk4lmiix"

This returns:

{
  "version":"1.0",
  "type":"video","
  html":"<iframe src=\"//fast.wistia.net/embed/iframe/26sk4lmiix\"  title=\"Nice. Video\" allow=\"autoplay; fullscreen\" allowtransparency=\"true\" frameborder=\"0\" scrolling=\"no\" class=\"wistia_embed\" name=\"wistia_embed\" msallowfullscreen width=\"960\" height=\"540\"></iframe>\n<script src=\"https://fast.wistia.net/assets/external/E-v1.js\" async></script>",
  "width":960,
  "height":540,
  "provider_name":"Wistia, Inc.",
  "provider_url":"https://wistia.com",
  "title":"Nice.",
  "thumbnail_url":"https://embed-ssl.wistia.com/deliveries/56cacb9a5d6ea04b1f29defaf4b55d1ec979e1b0.jpg?image_crop_resized=960x540",
  "thumbnail_width":960,
  "thumbnail_height":540,
  "player_color":"f27398",
  "duration":44.42
}

Note the html returned in the JSON body is the iframe embed code you can use to add this video to your website.

Using a Template Approach (Fallback)

Just like the Standard embed, you can build an iframe embed code template, and swap out the video's hashed ID.

Again, for this example we'll be using a hashed ID of 'abcde12345'.

The basic iframe embed code looks like this:

<iframe src="https://fast.wistia.net/embed/iframe/<media-hashed-id>?seo=true&videoFoam=false" title="video-title" allow="autoplay; fullscreen" allowtransparency="true" frameborder="0" scrolling="no" class="wistia_embed" name="wistia_embed" msallowfullscreen width="640" height="360"></iframe>
<script src="https://fast.wistia.net/assets/external/E-v1.js" async></script>

So to use this template with the hashed ID 'abcde12345', we insert it in place of <media-hashed-id>:

<iframe src="//fast.wistia.net/embed/iframe/abcde12345?seo=true&videoFoam=false" title="video title " allow="autoplay; fullscreen" allowtransparency="true" frameborder="0" scrolling="no" class="wistia_embed" name="wistia_embed" msallowfullscreen width="640" height="360"></iframe>
<script src="https://fast.wistia.net/assets/external/E-v1.js" async></script>

πŸ“

Note

Because height and width will change based on your video's content, the template approach is probably best when your entire library uses a consistent size.

Just like the Standard embed, the iframe embed can be responsive. Here's the template:

<div class="wistia_responsive_padding" style="padding:56.25% 0 0 0;position:relative;"><div class="wistia_responsive_wrapper" style="height:100%;left:0;position:absolute;top:0;width:100%;"><iframe src="https://fast.wistia.net/embed/iframe/abcde12345?seo=true&videoFoam=true" title="video title " allow="autoplay; fullscreen" allowtransparency="true" frameborder="0" scrolling="no" class="wistia_embed" name="wistia_embed" msallowfullscreen width="100%" height="100%"></iframe></div></div>
<script src="https://fast.wistia.net/assets/external/E-v1.js" async></script>

AMP Embed Tutorial

Wistia videos are compatible with AMP HTML pages as well! You'll just want to make sure your AMP webpage includes the following script:

<script async custom-element="amp-wistia-player" src="https://cdn.ampproject.org/v0/amp-wistia-player-0.1.js"></script>

Then you can embed your Wistia video by placing it inside of an amp-wistia-player tag like so:

 <amp-wistia-player
    data-media-hashed-id="abc123"
    width="700"
    height="394"
    ></amp-wistia-player>

We have an example of how that all looks on a live webpage here. For further information regarding supported layouts for the embed, you can go to the AMP webpage here.

Using JSONP

JSONP is a javascript technique used to get information from a server that is not the same origin as your current domain. This means they can avoid cross-domain security issues.

In this example, we'll write some javascript to pull data for our video against the oEmbed endpoint, utilizing JSONP. Then, we'll manipulate the data returned to embed the thumbnail image.

Given the oEmbed base URL, your account URL, and a media hashed id, we can use the jQuery getJSON function to call against the oEmbed endpoint to return the video data.

Note this function also takes a callback function as a parameter. We'll set up that callback function next.

var baseUrl = "https://fast.wistia.com/oembed/?url=";
var accountUrl = encodeURIComponent("https://home.wistia.com/medias/");
var mediaHashedId = "01a1d9f97c";

function getThumbnailUrl(hashedId, callback) {
  $.getJSON(baseUrl + accountUrl + hashedId + "&format=json&callback=?", callback);
}

This function will return a JSON data object, and pass it to our callback function, which will parse the JSON and log the thumbnail URL. Let's write that callback function now:

function parseJSON(json) {
  console.log(json.thumbnail_url);
};

Finally, we'll setup something to call these functions for our media hashed id:

getThumbnailUrl(mediaHashedId, parseJSON);

Working With The Thumbnail

Part of the JSON returned by the oEmbed is the thumbnail_url. This URL is a direct link to the thumbnail image asset. If your implementation involves using the thumbnail image (i.e. building your own 'popover' embeds, displaying your own play button, etc.) you should use this thumbnail image, which by default has no Wistia play button overlaid on it.

See our working with Wistia images guide for more info!

Embedding Options and Plugins

Once you have your embed code built, you probably want to tailor the appearance and behavior to your wishes. You may also want to add a plugin like Turnstile or a Call-to-Action.

For a list of available embedding options to be used with the Customize API, check our Embedding Options Documentation.

Retrieving .m3u8 files

For those that would like to create an .m3u8 playlist for all video’s assets, the fast.wistia.net/embed/medias/<hashed_id>.m3u8 endpoint will return the .m3u8 manifest and allow for adaptive playback. We do not recommend using this method as it will pull the video file outside of our player; as a result, you don’t get any stats, analytics, or customizations. Using them, however, does count towards your account’s bandwidth.