В целях отладки и регистрации успешно загруженные объявления предоставляют объект GADResponseInfo
. Этот объект содержит информацию о загруженном объявлении, а также информацию о каскаде медиации, использованном для загрузки объявления.
В случаях успешной загрузки объявления объект объявления имеет свойство GADResponseInfo
. Например, GADInterstitialAd.responseInfo
получает информацию об ответе для загруженной межстраничной рекламы.
В тех случаях, когда объявления не загружаются и доступна только ошибка, GADResponseInfo
доступен с помощью ключа GADErrorUserInfoKeyResponseInfo
в словаре userInfo
ошибки.
Быстрый
fileprivate func loadInterstitial() { GADInterstitialAd.load( withAdUnitID: "ca-app-pub-3940256099942544/4411468910", request: request ) { (ad, error) in if let error = error { let responseInfo = (error as NSError).userInfo[GADErrorUserInfoKeyResponseInfo] as? GADResponseInfo print("\(String(describing: responseInfo))") return } let responseInfo = ad?.responseInfo print("\(String(describing: responseInfo))") } }
Цель-C
- (void)loadInterstitial { [GADInterstitialAd loadWithAdUnitID:@"ca-app-pub-3940256099942544/4411468910" request:request completionHandler:^(GADInterstitialAd *ad, NSError *error) { if (error) { GADResponseInfo *responseInfo = error.userInfo[GADErrorUserInfoKeyResponseInfo]; NSLog(@"%@", responseInfo.description); return; } GADResponseInfo *responseInfo = ad.responseInfo; NSLog(@"%@", responseInfo.description); }]; }
Информация об ответе
Ниже приведен пример вывода, показывающий данные отладки, возвращаемые для загруженного объявления:
** Response Info **
Response ID: CLz5r-KMtfoCFQvv7QodfGAMHw
Network: GADMAdapterGoogleAdMobAds
** Loaded Adapter Response **
Network: GADMAdapterGoogleAdMobAds
Ad Source Name:Reservation campaign
Ad Source ID:7068401028668408324
Ad Source Instance Name:[DO NOT EDIT] Publisher Test Interstitial
Ad Source Instance ID:[DO NOT EDIT] Publisher Test Interstitial
AdUnitMapping:
{
}
Error: (null)
Latency: 0.357
** Extras Dictionary **
{
"mediation_group_name" = Campaign;
}
** Mediation line items **
Entry (1)
Network: GADMAdapterGoogleAdMobAds
Ad Source Name:Reservation campaign
Ad Source ID:7068401028668408324
Ad Source Instance Name:[DO NOT EDIT] Publisher Test Interstitial
Ad Source Instance ID:[DO NOT EDIT] Publisher Test Interstitial
AdUnitMapping:
{
}
Error: (null)
Latency: 0.357
Свойства GADResponseInfo
включают в себя:
Свойство | Описание |
---|---|
adNetworkInfoArray | Возвращает список GADAdNetworkResponseInfo содержащий метаданные для каждого адаптера, включенного в ответ на объявление. Может использоваться для отладки каскадного посредничества и выполнения ставок. Порядок списка соответствует порядку каскада медиации для этого запроса объявления.Дополнительную информацию см. в разделе «Информация об ответе адаптера» . |
loadedAdNetworkResponseInfo | Возвращает GADAdNetworkResponseInfo соответствующий адаптеру, загрузившему объявление. |
adNetworkClassName | Возвращает имя класса адаптера медиации рекламной сети, в которой было загружено объявление. |
responseIdentifier | Идентификатор ответа – это уникальный идентификатор ответа на объявление. Этот идентификатор можно использовать для идентификации и блокировки объявления в Центре просмотра рекламы (ARC) . |
extrasDictionary | Возвращает дополнительную информацию об ответе на объявление. Extras может возвращать следующие ключи:
|
Быстрый
fileprivate func loadInterstitial() { GADInterstitialAd.load( withAdUnitID: "ca-app-pub-3940256099942544/4411468910", request: request ) { (ad, error) in let responseInfo = ad?.responseInfo let responseIdentifier = responseInfo?.responseIdentifier let adNetworkClassName = responseInfo?.adNetworkClassName let adNetworkInfoArray = responseInfo?.adNetworkInfoArray let loadedAdNetworkResponseInfo = responseInfo?.loadedAdNetworkResponseInfo let mediationGroupName = responseInfo?.extrasDictionary["mediation_group_name"] let mediationABTestName = responseInfo?.extrasDictionary["mediation_ab_test_name"] let mediationABTestVariant = responseInfo?.extrasDictionary["mediation_ab_test_variant"] } }
Цель-C
- (void)loadInterstitial { [GADInterstitialAd loadWithAdUnitID:@"ca-app-pub-3940256099942544/4411468910" request:request completionHandler:^(GADInterstitialAd *ad, NSError *error) { GADResponseInfo *responseInfo = ad.responseInfo; NSString *responseIdentifier = responseInfo.responseIdentifier; NSString *adNetworkClassName = responseInfo.adNetworkClassName; NSArray *adNetworkInfoArray = responseInfo.adNetworkInfoArray; GADAdNetworkResponseInfo *loadedAdNetworkResponseInfo = responseInfo.loadedAdNetworkResponseInfo; NSString *mediationGroupName = responseInfo.extrasDictionary[@"mediation_group_name"]; NSString *mediationABTestName = responseInfo.extrasDictionary[@"mediation_ab_test_name"]; NSString *mediationABTestVariant = responseInfo.extrasDictionary[@"mediation_ab_test_variant"]; }]; }
Информация об ответе адаптера
GADAdNetworkResponseInfo
содержит метаданные для каждого адаптера, включенного в ответ на объявление, которые можно использовать для отладки посредничества каскада и выполнения ставок. Порядок списка соответствует порядку каскада медиации для запроса объявления.
Вот пример вывода GADAdNetworkResponseInfo
:
Network: GADMAdapterGoogleAdMobAds
Ad Source Name:Reservation campaign
Ad Source ID:7068401028668408324
Ad Source Instance Name:[DO NOT EDIT] Publisher Test Interstitial
Ad Source Instance ID:[DO NOT EDIT] Publisher Test Interstitial
AdUnitMapping:
{
}
Error: (null)
Latency: 0.277
Для каждой рекламной сети GADAdNetworkResponseInfo
предоставляет следующие свойства:
Свойство | Описание |
---|---|
error | Ошибка, связанная с запросом к сети. Возвращает nil , если сеть успешно загрузила объявление или если попытка подключения к сети не была предпринята. |
adSourceId | Идентификатор источника объявления, связанный с этим ответом адаптера.Для кампаний 6060308706800320801 возвращается для типа цели кампании с посредником, а 7068401028668408324 возвращается для типов целей по показам и кликам. См. «Источники объявлений» , где приведен список возможных идентификаторов источников объявлений, когда рекламная сеть показывает объявление. |
adSourceInstanceId | Идентификатор экземпляра источника объявления, связанный с этим ответом адаптера. |
adSourceInstanceName | Имя экземпляра источника объявления, связанное с этим ответом адаптера. |
adSourceName | Источник объявления, представляющий конкретную рекламную сеть, которая обеспечивает показ. Для кампаний Mediated House Ads возвращается для типа цели кампании «Медиативная реклама», а Reservation Campaign возвращается для типов целей по показам и кликам. См. «Источники объявлений» , где приведен список возможных названий источников объявлений, когда рекламная сеть показывает объявление. |
adNetworkClassName | Имя класса адаптера рекламной сети, загрузившего объявление. |
adUnitMapping | Конфигурация сети, установленная из AdMob Пользовательский интерфейс. |
latency | Время, потраченное рекламной сетью на загрузку объявления. Возвращает 0 , если попытка подключения к сети не предпринималась. |
Быстрый
fileprivate func loadInterstitial() { GADInterstitialAd.load( withAdUnitID: "ca-app-pub-3940256099942544/4411468910", request: request ) { (ad, error) in let responseInfo = ad?.responseInfo let loadedAdNetworkResponseInfo = responseInfo?.loadedAdNetworkResponseInfo let adNetworkError = loadedAdNetworkResponseInfo?.error let adSourceId = loadedAdNetworkResponseInfo?.adSourceID let adSourceInstanceId = loadedAdNetworkResponseInfo?.adSourceInstanceID let adSourceInstanceName = loadedAdNetworkResponseInfo?.adSourceInstanceName let adSourceName = loadedAdNetworkResponseInfo?.adSourceName let adNetworkClassName = loadedAdNetworkResponseInfo?.adNetworkClassName let adUnitMapping = loadedAdNetworkResponseInfo?.adUnitMapping let latency = loadedAdNetworkResponseInfo?.latency } }
Цель-C
- (void)loadInterstitial { [GADInterstitialAd loadWithAdUnitID:@"ca-app-pub-3940256099942544/4411468910" request:request completionHandler:^(GADInterstitialAd *ad, NSError *error) { GADResponseInfo *responseInfo = ad.responseInfo; GADAdNetworkResponseInfo *loadedAdNetworkResponseInfo = responseInfo.loadedAdNetworkResponseInfo; NSError *adNetworkError = loadedAdNetworkResponseInfo.error; NSString *adSourceId = loadedAdNetworkResponseInfo.adSourceID; NSString *adSourceInstanceId = loadedAdNetworkResponseInfo.adSourceInstanceID; NSString *adSourceInstanceName = loadedAdNetworkResponseInfo.adSourceInstanceName; NSString *adSourceName = loadedAdNetworkResponseInfo.adSourceName; NSString *adNetworkClassName = loadedAdNetworkResponseInfo.adNetworkClassName; NSDictionary*adUnitMapping = loadedAdNetworkResponseInfo.adUnitMapping; NSTimeInterval latency = loadedAdNetworkResponseInfo.latency; }]; }