Recuperar informações sobre a resposta do anúncio

Para fins de depuração e geração de registros, os anúncios carregados fornecem um objeto GADResponseInfo. Esse objeto contém informações sobre o anúncio carregado, além de informações sobre a hierarquia de mediação usada para carregar o anúncio.

Para casos em que um anúncio é carregado, o objeto de anúncio tem uma propriedade GADResponseInfo. Por exemplo, GADInterstitialAd.responseInfo recebe as informações de resposta de um anúncio intersticial carregado.

Nos casos em que os anúncios não são carregados e apenas um erro estiver disponível, o GADResponseInfo estará disponível usando a chave GADErrorUserInfoKeyResponseInfo no dicionário userInfo do erro.

Swift

fileprivate func loadInterstitial() {
  GADInterstitialAd.load(
    withAdUnitID: "/6499/example/interstitial", 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))")
  }
}

Objective-C

- (void)loadInterstitial {
  [GADInterstitialAd
   loadWithAdUnitID:@"/6499/example/interstitial"
   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);
  }];
}

Informações de resposta

Este é um exemplo de saída que mostra os dados de depuração retornados para um anúncio carregado:

** Response Info **
    Response ID: BmnCZaSbE_6Mur8P5su8gAY
    Network: GADMAdapterGoogleAdMobAds

  ** Loaded Adapter Response **
    Network: GADMAdapterGoogleAdMobAds
    Ad Source Name:AdMob Network
    Ad Source ID:
    Ad Source Instance Name:AdMob (default)
    Ad Source Instance ID:AdMob (default)
    AdUnitMapping:
{
    pubid = "ca-pub-9939518381636264//21775744923/example/rewarded_interstitial/cak=no_cache&cadc=b0&caqid=BmnCZZjMEvzpkPIP5cWfQA";
}
    Error: (null)
    Latency: 2.724

  ** Extras Dictionary **
    {
    }

  ** Mediation line items **
    Entry (1)
    Network: GADMAdapterGoogleAdMobAds
    Ad Source Name:AdMob Network
    Ad Source ID:
    Ad Source Instance Name:AdMob (default)
    Ad Source Instance ID:AdMob (default)
    AdUnitMapping:
{
    pubid = "ca-pub-9939518381636264//21775744923/example/rewarded_interstitial/cak=no_cache&cadc=b0&caqid=BmnCZZjMEvzpkPIP5cWfQA";
}
    Error: (null)
    Latency: 2.724

As propriedades em GADResponseInfo incluem:

Propriedade Descrição
adNetworkInfoArray Retorna a lista de GADAdNetworkResponseInfo que contém metadados para cada adaptador incluído na resposta do anúncio. Pode ser usado para depurar a mediação em hierarquia e a execução dos lances. A ordem da lista corresponde à ordem da hierarquia de mediação dessa solicitação de anúncio.

Consulte Informações sobre a resposta do adaptador para mais informações.

loadedAdNetworkResponseInfo Retorna o GADAdNetworkResponseInfo correspondente ao adaptador que carregou o anúncio.
adNetworkClassName Retorna o nome da classe do adaptador de mediação da rede de publicidade que carregou o anúncio.
responseIdentifier O identificador de resposta é um identificador exclusivo da resposta do anúncio. Esse identificador pode ser usado para identificar e bloquear o anúncio na Central de revisão de anúncios (ARC).
extrasDictionary

Retorna informações extras sobre a resposta do anúncio.

Swift

fileprivate func loadInterstitial() {
  GADInterstitialAd.load(
    withAdUnitID: "/6499/example/interstitial", 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
  }
}

Objective-C

- (void)loadInterstitial {
  [GADInterstitialAd
   loadWithAdUnitID:@"/6499/example/interstitial"
   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;
  }];
}

Informações de resposta do adaptador

GADAdNetworkResponseInfo contém metadados para cada adaptador incluído na resposta do anúncio, que podem ser usados para depurar a mediação em hierarquia e a execução dos lances. A ordem da lista corresponde à ordem da hierarquia de mediação da solicitação de anúncio.

Confira um exemplo de saída de GADAdNetworkResponseInfo:

    Network: GADMAdapterGoogleAdMobAds
    Ad Source Name:AdMob Network
    Ad Source ID:
    Ad Source Instance Name:AdMob (default)
    Ad Source Instance ID:AdMob (default)
    AdUnitMapping:
{
    pubid = "ca-pub-9939518381636264//21775744923/example/rewarded_interstitial/cak=no_cache&cadc=b0&caqid=BmnCZZjMEvzpkPIP5cWfQA";
}
    Error: (null)
    Latency: 2.724

Para cada rede de publicidade, GADAdNetworkResponseInfo fornece as seguintes propriedades:

Propriedade Descrição
error O erro associado à solicitação para a rede. Retorna nil se a rede carregou um anúncio ou se não foi tentada a rede.
adSourceId O ID da origem de anúncios associado a essa resposta do adaptador.
adSourceInstanceId O ID da instância da origem de anúncios associada a essa resposta do adaptador.
adSourceInstanceName O nome da instância da origem do anúncio associada a esta resposta do adaptador. Retorna uma string vazia se não for preenchida por um grupo de rendimento.
adSourceName A origem de anúncios que representa a rede de publicidade específica que veicula a impressão.
adNetworkClassName O nome da classe do adaptador da rede de publicidade que carregou o anúncio.
adUnitMapping A configuração de rede definida a partir da interface Ad Manager .
latency O tempo que a rede de publicidade gastou carregando um anúncio. Retorna 0 se não houve tentativa de tentativa de rede.

Swift

fileprivate func loadInterstitial() {
  GADInterstitialAd.load(
    withAdUnitID: "/6499/example/interstitial", 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
  }
}

Objective-C

- (void)loadInterstitial {
  [GADInterstitialAd
   loadWithAdUnitID:@"/6499/example/interstitial"
   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;
  }];
}