Erros de carregamento de anúncios

如果广告加载失败,则会调用 回调 ,以此来提供 LoadAdError对象。

对于 an AdView,系统将调用以下内容:

以下代码段说明了广告加载失败时可用的信息:

Java

@Override
public void onAdFailedToLoad(LoadAdError error) {
  // Gets the domain from which the error came.
  String errorDomain = error.getDomain();
  // Gets the error code. See
  // https://developers.google.com/android/reference/com/google/android/gms/ads/AdRequest#constant-summary
  // for a list of possible codes.
  int errorCode = error.getCode();
  // Gets an error message.
  // For example "Account not approved yet". See
  // https://support.google.com/admob/answer/9905175 for explanations of
  // common errors.
  String errorMessage = error.getMessage();
  // Gets additional response information about the request. See
  // https://developers.google.com/admob/android/response-info for more
  // information.
  ResponseInfo responseInfo = error.getResponseInfo();
  // Gets the cause of the error, if available.
  AdError cause = error.getCause();
  // All of this information is available using the error's toString() method.
  Log.d("Ads", error.toString());
}

Kotlin

override fun onAdFailedToLoad(error: LoadAdError) {
  // Gets the domain from which the error came.
  val errorDomain = error.domain
  // Gets the error code. See
  // https://developers.google.com/android/reference/com/google/android/gms/ads/AdRequest#constant-summary
  // for a list of possible codes.
  val errorCode = error.code
  // Gets an error message.
  // For example "Account not approved yet". See
  // https://support.google.com/admob/answer/9905175 for explanations of
  // common errors.
  val errorMessage = error.message
  // Gets additional response information about the request. See
  // https://developers.google.com/admob/android/response-info for more
  // information.
  val responseInfo = error.responseInfo
  // Gets the cause of the error, if available.
  val cause = error.cause
  // All of this information is available using the error's toString() method.
  Log.d("Ads", error.toString())
}

此信息可用于更准确地确定导致广告加载失败的原因。 特别要指出的是,对于网域 MobileAds.ERROR_DOMAIN 下的错误,消息 的更多详细说明可在这篇帮助中心文章中查看,并了解在解决问题时可以采取的措施。

调试常见错误日志记录消息

在 Google 移动广告 SDK 23.5.0 版中,增强了详细日志记录功能,以包含广告无法加载位置的堆栈轨迹。这些消息并非指示崩溃,而是用于标识错误的唯一来源。下表提供了常见的错误日志、说明和建议的解决措施:

错误日志 说明 建议采取的措施
com.google.android.gms.ads.nonagon.render.cp: * 广告服务器未返回广告或任何中介广告来源。 如需详细了解此类常见的新手入门问题,请参阅解决常见的新手入门问题
com.google.android.gms.ads.nonagon.render.e: * 中介广告瀑布流中的所有广告来源都未能加载。具体错误表示上次失败的广告来源。 如需详细了解如何记录每个中介广告来源的失败原因,请参阅 响应信息
com.google.android.gms.ads.internal.util.*: Unable to obtain a JavascriptEngine. 由于特权进程中不允许使用 WebView,因此广告请求未能成功。
  • 请检查您的互联网设置。
  • 移除 android:sharedUserId="android.uid.system",并将应用安装为系统应用。
由于网络连接缓慢,广告请求未能成功。 请尝试改善网络连接,然后重试。
com.google.android.gms.ads.nonagon.load.a 广告请求超时。
com.google.android.gms.ads.internal.util.*: Error while connecting to ad server: Unable to resolve host "pubads.g.doubleclick.net": No address associated with hostname 由于网络连接问题,广告请求失败。
com.google.android.gms.ads.internal.util.*: Error building request URL: Cannot determine request type. Is your ad unit id correct? 广告单元 ID 与预期的正则表达式不匹配。 检查您的广告单元 ID 是否正确无误。
com.google.android.gms.ads.internal.render.bt: Unable to instantiate mediation adapter class. Google 移动广告 SDK 找不到中介适配器。
  • 在广告检查器中,使用查看可用适配器来诊断 Google 移动广告 SDK 找不到哪些适配器。
  • 将缺少的适配器添加到您的项目中。如需了解如何为每个广告来源完成此步骤,请参阅 广告联盟详情
com.google.android.gms.internal.ads.*: Received error HTTP response code: 403 AdMob 服务器拒绝了请求。 请稍后再试。如果问题可重复出现,请使用广告检查器捕获请求网址,然后与支持团队联系。