Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
This example demonstrates how to add media for responsive ads and image ad extensions.
Tip
Use the language selector in the documentation header to choose C#, Java, Php, or Python.
To get access and refresh tokens for your Microsoft Advertising user and make your first service call using the Bing Ads API, see the Quick Start guide. You'll want to review the Get Started guide and walkthroughs for your preferred language e.g., C#, Java, Php, and Python.
Supporting files for C#, Java, Php, and Python examples are available at GitHub. You can clone each repository or repurpose snippets as needed.
using System;
using System.IO;
using System.Linq;
using System.ServiceModel;
using System.Drawing;
using System.Threading.Tasks;
using Microsoft.BingAds.V13.CampaignManagement;
using Microsoft.BingAds;
namespace BingAdsExamplesLibrary.V13
{
/// <summary>
/// How to manage images in an account's media library.
/// </summary>
public class ImageMedia : ExampleBase
{
// To run this example you'll need to provide your own images.
// For required aspect ratios and recommended dimensions please see
// Image remarks at https://go.microsoft.com/fwlink/?linkid=872754.
private const string MediaFilePath = "c:\\dev\\media\\";
private const string ResponsiveAdMediaFileName = "imageresponsivead1200x628.png";
private const string ImageAdExtensionMediaFileName = "imageadextension300x200.png";
public override string Description
{
get { return "Image Media | Campaign Management V13"; }
}
public async override Task RunAsync(AuthorizationData authorizationData)
{
try
{
ApiEnvironment environment = ((OAuthDesktopMobileAuthCodeGrant)authorizationData.Authentication).Environment;
CampaignManagementExampleHelper CampaignManagementExampleHelper = new CampaignManagementExampleHelper(
OutputStatusMessageDefault: this.OutputStatusMessage);
CampaignManagementExampleHelper.CampaignManagementService = new ServiceClient<ICampaignManagementService>(
authorizationData: authorizationData,
environment: environment);
var responsiveAdImageMedia = GetImageMedia(
"Image191x100",
MediaFilePath + ResponsiveAdMediaFileName,
System.Drawing.Imaging.ImageFormat.Png);
var imageAdExtensionMedia = GetImageMedia(
"Image15x10",
MediaFilePath + ImageAdExtensionMediaFileName,
System.Drawing.Imaging.ImageFormat.Png);
var addMedia = new Media[]
{
responsiveAdImageMedia,
imageAdExtensionMedia
};
OutputStatusMessage("Ready to upload image media:");
CampaignManagementExampleHelper.OutputArrayOfMedia(addMedia);
OutputStatusMessage("-----\nAddMedia:");
AddMediaResponse addMediaResponse = await CampaignManagementExampleHelper.AddMediaAsync(
accountId: authorizationData.AccountId,
media: addMedia);
long[] mediaIds = addMediaResponse.MediaIds.ToArray();
OutputStatusMessage("MediaIds:");
CampaignManagementExampleHelper.OutputArrayOfLong(mediaIds);
// Get the media representations to confirm the stored dimensions
// and get the Url where you can later view or download the media.
OutputStatusMessage("-----\nGetMediaMetaDataByAccountId:");
var getResponsiveAdMediaMetaData = (await CampaignManagementExampleHelper.GetMediaMetaDataByAccountIdAsync(
mediaEnabledEntities: MediaEnabledEntityFilter.ResponsiveAd,
pageInfo: null)).MediaMetaData;
OutputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.OutputArrayOfMediaMetaData(getResponsiveAdMediaMetaData);
OutputStatusMessage("-----\nGetMediaMetaDataByAccountId:");
var getImageAdExtensionMediaMetaData = (await CampaignManagementExampleHelper.GetMediaMetaDataByAccountIdAsync(
mediaEnabledEntities: MediaEnabledEntityFilter.ImageAdExtension,
pageInfo: null)).MediaMetaData;
OutputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.OutputArrayOfMediaMetaData(getImageAdExtensionMediaMetaData);
OutputStatusMessage("-----\nGetMediaMetaDataByIds:");
var getMediaMetaData = (await CampaignManagementExampleHelper.GetMediaMetaDataByIdsAsync(
mediaIds: mediaIds)).MediaMetaData;
OutputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.OutputArrayOfMediaMetaData(getMediaMetaData);
// Delete the account's media.
OutputStatusMessage("-----\nDeleteMedia:");
await CampaignManagementExampleHelper.DeleteMediaAsync(
accountId: authorizationData.AccountId,
mediaIds: mediaIds);
foreach (var id in mediaIds)
{
OutputStatusMessage(string.Format("Deleted Media Id {0}", id));
}
}
// Catch authentication exceptions
catch (OAuthTokenRequestException ex)
{
OutputStatusMessage(string.Format("Couldn't get OAuth tokens. Error: {0}. Description: {1}", ex.Details.Error, ex.Details.Description));
}
// Catch Campaign Management service exceptions
catch (FaultException<AdApiFaultDetail> ex)
{
OutputStatusMessage(string.Join("; ", ex.Detail.Errors.Select(error => string.Format("{0}: {1}", error.Code, error.Message))));
}
catch (FaultException<ApiFaultDetail> ex)
{
OutputStatusMessage(string.Join("; ", ex.Detail.OperationErrors.Select(error => string.Format("{0}: {1}", error.Code, error.Message))));
OutputStatusMessage(string.Join("; ", ex.Detail.BatchErrors.Select(error => string.Format("{0}: {1}", error.Code, error.Message))));
}
catch (FaultException<EditorialApiFaultDetail> ex)
{
OutputStatusMessage(string.Join("; ", ex.Detail.OperationErrors.Select(error => string.Format("{0}: {1}", error.Code, error.Message))));
OutputStatusMessage(string.Join("; ", ex.Detail.BatchErrors.Select(error => string.Format("{0}: {1}", error.Code, error.Message))));
}
catch (Exception ex)
{
OutputStatusMessage(ex.Message);
}
}
/// <summary>
/// Get image media that can be managed with the Campaign Management API.
/// </summary>
/// <param name="mediaType">The media type reflects the aspect ratio.</param>
/// <param name="imageFileName">The file name and path.</param>
/// <param name="imageFormat">For supported image formats see <see href="https://go.microsoft.com/fwlink/?linkid=872754">Image remarks</see>.</param>
/// <returns>A Campaign Management Image object.</returns>
private Microsoft.BingAds.V13.CampaignManagement.Image GetImageMedia(
string mediaType,
string imageFileName,
System.Drawing.Imaging.ImageFormat imageFormat)
{
var image = new Microsoft.BingAds.V13.CampaignManagement.Image();
image.Data = GetBmpBase64String(imageFileName, imageFormat);
image.MediaType = mediaType;
image.Type = "Image";
return image;
}
/// <summary>
/// Get the image media as base64 string.
/// </summary>
/// <param name="imageFileName">The file name and path.</param>
/// <param name="imageFormat">For supported image formats see <see href="https://go.microsoft.com/fwlink/?linkid=872754">Image remarks</see>.</param>
/// <returns></returns>
private string GetBmpBase64String(
string imageFileName,
System.Drawing.Imaging.ImageFormat imageFormat)
{
var bmp = new Bitmap(imageFileName);
using (MemoryStream ms = new MemoryStream())
{
bmp.Save(ms, imageFormat);
byte[] imageBytes = ms.ToArray();
string base64String = Convert.ToBase64String(imageBytes);
return base64String;
}
}
}
}
package com.microsoft.bingads.examples.v13;
import java.util.ArrayList;
import java.util.Base64;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.io.File;
import java.nio.file.Files;
import com.microsoft.bingads.*;
import com.microsoft.bingads.v13.campaignmanagement.*;
public class ImageMedia extends ExampleBase {
public static void main(java.lang.String[] args) {
// To run this example you'll need to provide your own images.
// For required aspect ratios and recommended dimensions please see
// Image remarks at https://go.microsoft.com/fwlink/?linkid=872754.
java.lang.String MEDIA_FILE_PATH = "c:\\dev\\media\\";
java.lang.String RESPONSIVE_AD_MEDIA_FILE_NAME = "imageresponsivead1200x628.png";
java.lang.String IMAGE_AD_EXTENSION_MEDIA_FILE_NAME = "imageadextension300x200.png";
try
{
authorizationData = getAuthorizationData();
CampaignManagementExampleHelper.CampaignManagementService = new ServiceClient<ICampaignManagementService>(
authorizationData,
API_ENVIRONMENT,
ICampaignManagementService.class);
Image responsiveAdImageMedia = getImageMedia(
"Image191x100",
MEDIA_FILE_PATH + RESPONSIVE_AD_MEDIA_FILE_NAME);
Image imageAdExtensionMedia = getImageMedia(
"Image15x10",
MEDIA_FILE_PATH + IMAGE_AD_EXTENSION_MEDIA_FILE_NAME);
ArrayOfMedia addMedia = new ArrayOfMedia();
addMedia.getMedias().add(responsiveAdImageMedia);
addMedia.getMedias().add(imageAdExtensionMedia);
outputStatusMessage("Ready to upload image media:");
CampaignManagementExampleHelper.outputArrayOfMedia(addMedia);
outputStatusMessage("-----\nAddMedia:");
ArrayOflong mediaIds = CampaignManagementExampleHelper.addMedia(
authorizationData.getAccountId(),
addMedia).getMediaIds();
outputStatusMessage("MediaIds:");
CampaignManagementExampleHelper.outputArrayOflong(mediaIds);
// Get the media representations to confirm the stored dimensions
// and get the Url where you can later view or download the media.
ArrayList<MediaEnabledEntityFilter> responsiveAdFilter = new ArrayList<MediaEnabledEntityFilter>();
responsiveAdFilter.add(MediaEnabledEntityFilter.RESPONSIVE_AD);
outputStatusMessage("-----\nGetMediaMetaDataByAccountId:");
ArrayOfMediaMetaData getResponsiveAdMediaMetaData = CampaignManagementExampleHelper.getMediaMetaDataByAccountId(
responsiveAdFilter,
null).getMediaMetaData();
outputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.outputArrayOfMediaMetaData(getResponsiveAdMediaMetaData);
ArrayList<MediaEnabledEntityFilter> imageAdExtensionFilter = new ArrayList<MediaEnabledEntityFilter>();
imageAdExtensionFilter.add(MediaEnabledEntityFilter.IMAGE_AD_EXTENSION);
outputStatusMessage("-----\nGetMediaMetaDataByAccountId:");
ArrayOfMediaMetaData getImageAdExtensionMediaMetaData = CampaignManagementExampleHelper.getMediaMetaDataByAccountId(
imageAdExtensionFilter,
null).getMediaMetaData();
outputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.outputArrayOfMediaMetaData(getImageAdExtensionMediaMetaData);
outputStatusMessage("-----\nGetMediaMetaDataByIds:");
ArrayOfMediaMetaData getMediaMetaData = CampaignManagementExampleHelper.getMediaMetaDataByIds(
mediaIds).getMediaMetaData();
outputStatusMessage("MediaMetaData:");
CampaignManagementExampleHelper.outputArrayOfMediaMetaData(getMediaMetaData);
// Delete the account's media.
outputStatusMessage("-----\nDeleteMedia:");
CampaignManagementExampleHelper.deleteMedia(
authorizationData.getAccountId(),
mediaIds);
for (java.lang.Long id : mediaIds.getLongs())
{
outputStatusMessage(String.format("Deleted Media Id %s", id));
}
}
catch (Exception ex) {
String faultXml = ExampleExceptionHelper.getBingAdsExceptionFaultXml(ex, System.out);
outputStatusMessage(faultXml);
String message = ExampleExceptionHelper.handleBingAdsSDKException(ex, System.out);
outputStatusMessage(message);
}
}
// Get image media that can be managed with the Campaign Management API.
static Image getImageMedia(
java.lang.String mediaType,
java.lang.String imageFileName) throws UnsupportedEncodingException, IOException
{
Image image = new Image();
image.setData(getBmpBase64String(imageFileName));
image.setMediaType(mediaType);
image.setType("Image");
return image;
}
// Get the image media as base64 string.
static java.lang.String getBmpBase64String(
java.lang.String imageFileName) throws UnsupportedEncodingException, IOException
{
File fi = new File(imageFileName);
byte[] imageBytes = Files.readAllBytes(fi.toPath());
java.lang.String base64String = new java.lang.String(Base64.getEncoder().encode(imageBytes), "UTF-8");
return base64String;
}
}
<?php
namespace Microsoft\BingAds\Samples\V13;
// For more information about installing and using the Bing Ads PHP SDK,
// see https://go.microsoft.com/fwlink/?linkid=838593.
require_once __DIR__ . "/../vendor/autoload.php";
include __DIR__ . "/AuthHelper.php";
include __DIR__ . "/OutputHelper.php";
include __DIR__ . "/CampaignManagementExampleHelper.php";
use SoapVar;
use SoapFault;
use Exception;
// Specify the Microsoft\BingAds\V13\CampaignManagement classes that will be used.
use Microsoft\BingAds\V13\CampaignManagement\Image;
use Microsoft\BingAds\V13\CampaignManagement\MediaEnabledEntityFilter;
// Specify the Microsoft\BingAds\Auth classes that will be used.
use Microsoft\BingAds\Auth\ServiceClient;
use Microsoft\BingAds\Auth\ServiceClientType;
// Specify the Microsoft\BingAds\Samples classes that will be used.
use Microsoft\BingAds\Samples\V13\AuthHelper;
use Microsoft\BingAds\Samples\V13\CampaignManagementExampleHelper;
// To run this example you'll need to provide your own images.
// For required aspect ratios and recommended dimensions please see
// Image remarks at https://go.microsoft.com/fwlink/?linkid=872754.
$mediaFilePath = "c:\\dev\\media\\";
$responsiveAdMediaFileName = "imageresponsivead1200x628.png";
$imageAdExtensionMediaFileName = "imageadextension300x200.png";
try
{
// Authenticate user credentials and set the account ID for the sample.
AuthHelper::Authenticate();
$responsiveAdImageMedia = GetImageMedia(
"Image191x100",
$mediaFilePath . $responsiveAdMediaFileName
);
$imageAdExtensionMedia = GetImageMedia(
"Image15x10",
$mediaFilePath . $imageAdExtensionMediaFileName
);
$addMedia = array();
$addMedia[] = $responsiveAdImageMedia;
$addMedia[] = $imageAdExtensionMedia;
print("Ready to upload image media:\r\n");
CampaignManagementExampleHelper::OutputArrayOfMedia($addMedia);
print("-----\r\nAddMedia:\r\n");
$mediaIds = CampaignManagementExampleHelper::AddMedia(
$GLOBALS['AuthorizationData']->AccountId,
$addMedia
)->MediaIds;
print("MediaIds:\r\n");
CampaignManagementExampleHelper::OutputArrayOfLong($mediaIds);
// Get the media representations to confirm the stored dimensions
// and get the Url where you can later view or download the media.
print("-----\r\nGetMediaMetaDataByAccountId:\r\n");
$mediaMetaData =CampaignManagementExampleHelper::GetMediaMetaDataByAccountId(
MediaEnabledEntityFilter::ResponsiveAd,
null
)->MediaMetaData;
print("MediaMetaData:\r\n");
CampaignManagementExampleHelper::OutputArrayOfMediaMetaData($mediaMetaData);
print("-----\r\nGetMediaMetaDataByAccountId:\r\n");
$mediaMetaData = CampaignManagementExampleHelper::GetMediaMetaDataByAccountId(
MediaEnabledEntityFilter::ImageAdExtension,
null
)->MediaMetaData;
print("MediaMetaData:\r\n");
CampaignManagementExampleHelper::OutputArrayOfMediaMetaData($mediaMetaData);
print("-----\r\nGetMediaMetaDataByIds:\r\n");
$mediaMetaData = CampaignManagementExampleHelper::GetMediaMetaDataByIds(
$mediaIds
)->MediaMetaData;
print("MediaMetaData:\r\n");
CampaignManagementExampleHelper::OutputArrayOfMediaMetaData($mediaMetaData);
// Delete the account's media.
print("-----\r\nDeleteMedia:\r\n");
CampaignManagementExampleHelper::DeleteMedia(
$GLOBALS['AuthorizationData']->AccountId,
$mediaIds
);
foreach ($mediaIds->long as $id)
{
printf("Deleted Media Id %s\r\n", $id);
}
}
catch (SoapFault $e)
{
printf("-----\r\nFault Code: %s\r\nFault String: %s\r\nFault Detail: \r\n", $e->faultcode, $e->faultstring);
var_dump($e->detail);
print "-----\r\nLast SOAP request/response:\r\n";
print $GLOBALS['Proxy']->GetWsdl() . "\r\n";
print $GLOBALS['Proxy']->GetService()->__getLastRequest()."\r\n";
print $GLOBALS['Proxy']->GetService()->__getLastResponse()."\r\n";
}
catch (Exception $e)
{
// Ignore fault exceptions that we already caught.
if ($e->getPrevious())
{ ; }
else
{
print $e->getCode()." ".$e->getMessage()."\n\n";
print $e->getTraceAsString()."\n\n";
}
}
function GetImageMedia(
$mediaType,
$imageFileName){
$image = new Image();
$image->Data = GetBase64ImageData($imageFileName);
$image->MediaType = $mediaType;
$image->Type = "Image";
$encodedImage = new SoapVar(
$image,
SOAP_ENC_OBJECT,
'Image',
$GLOBALS['CampaignManagementProxy']->GetNamespace()
);
return $encodedImage;
}
function GetBase64ImageData($imageFileName){
$imageData = file_get_contents($imageFileName);
$base64ImageData = base64_encode($imageData);
return $base64ImageData;
}
import os
import base64
from auth_helper import *
from openapi_client.models.campaign import *
# Media file paths - update with your own images
MEDIA_FILE_PATH = "c:\\dev\\media\\"
RESPONSIVE_AD_MEDIA_FILE_NAME = "imageresponsivead703x368.png"
IMAGE_AD_EXTENSION_MEDIA_FILE_NAME = "imageadextension300x200.png"
def get_base64_image_data(image_file_path):
"""
Read an image file and return its base64 encoded data.
Args:
image_file_path: Path to the image file
Returns:
Base64 encoded string of the image data
"""
with open(image_file_path, 'rb') as image_file:
image_data = image_file.read()
return base64.b64encode(image_data).decode('utf-8')
def get_image_media(media_type, image_file_name):
"""
Create an Image media object with the specified type and file.
Args:
media_type: The media type (e.g., "Image191x100", "Image15x10")
image_file_name: Path to the image file
Returns:
Image object ready to be added to the account
"""
image = Image(
data=get_base64_image_data(image_file_name),
media_type=media_type,
type="Image"
)
return image
def main(authorization_data):
try:
# Prepare the image media objects
print("Preparing image media...")
responsive_ad_image_path = os.path.join(MEDIA_FILE_PATH, RESPONSIVE_AD_MEDIA_FILE_NAME)
image_ad_extension_path = os.path.join(MEDIA_FILE_PATH, IMAGE_AD_EXTENSION_MEDIA_FILE_NAME)
# Check if files exist
if not os.path.exists(responsive_ad_image_path):
print(f"Warning: File not found: {responsive_ad_image_path}")
print("Please update MEDIA_FILE_PATH and file names with your actual image files.")
return
if not os.path.exists(image_ad_extension_path):
print(f"Warning: File not found: {image_ad_extension_path}")
print("Please update MEDIA_FILE_PATH and file names with your actual image files.")
return
responsive_ad_image_media = get_image_media(
"Image191x100",
responsive_ad_image_path
)
image_ad_extension_media = get_image_media(
"Image15x10",
image_ad_extension_path
)
add_media = [responsive_ad_image_media, image_ad_extension_media]
# Add media to the account
print("\nAdding media to account...")
add_media_request = AddMediaRequest(
account_id=authorization_data.account_id,
media=add_media
)
add_media_response = campaign_service.add_media(
add_media_request=add_media_request
)
media_ids = add_media_response.MediaIds
print(f"Added Media IDs: {media_ids}")
# Get media metadata
print("\nGetting media metadata...")
get_metadata_request = GetMediaMetaDataByIdsRequest(
media_ids=media_ids
)
get_metadata_response = campaign_service.get_media_meta_data_by_ids(
get_media_meta_data_by_ids_request=get_metadata_request
)
media_meta_data = get_metadata_response.MediaMetaData
print(f"Media Metadata:")
for metadata in media_meta_data:
if metadata:
print(f" Media ID: {metadata.Id}")
print(f" Media Type: {metadata.MediaType}")
if hasattr(metadata, 'Dimensions') and metadata.Dimensions:
print(f" Dimensions: {metadata.Dimensions}")
if hasattr(metadata, 'Urls') and metadata.Urls:
print(f" URLs: {metadata.Urls}")
if get_metadata_response.PartialErrors:
print(f"Partial Errors: {get_metadata_response.PartialErrors}")
# Delete the media
print("\nDeleting media...")
delete_media_request = DeleteMediaRequest(
account_id=authorization_data.account_id,
media_ids=media_ids
)
delete_media_response = campaign_service.delete_media(
delete_media_request=delete_media_request
)
if delete_media_response.PartialErrors:
print(f"Partial Errors: {delete_media_response.PartialErrors}")
else:
print(f"Deleted Media IDs: {media_ids}")
except FileNotFoundError as ex:
print(f"File not found: {str(ex)}")
print("Please update MEDIA_FILE_PATH and file names with your actual image files.")
except Exception as ex:
print(f"Error occurred: {str(ex)}")
import traceback
traceback.print_exc()
if __name__ == '__main__':
print("Loading the web service client...")
authorization_data = AuthorizationData(
account_id=None,
customer_id=None,
developer_token=DEVELOPER_TOKEN,
authentication=None,
)
authenticate(authorization_data)
campaign_service = ServiceClient(
service='CampaignManagementService',
version=13,
authorization_data=authorization_data,
environment=ENVIRONMENT,
)
main(authorization_data)