5

我正在尝试将 AdMob 广告添加到我的 android 应用程序,但每当我打开应该显示广告的活动时,我都会收到此错误:

I/Ads(11448): adRequestUrlHtml: <html><head><script src="http://media.admob.com/sdk-core-v40.js"></script><script>AFMA_getSdkConstants();AFMA_buildAdURL({"kw":[],"preqs":4,"session_id":"17111845472336325405","u_sd":2,"seq_num":"5","slotname":"MYUSERIDHERE","u_w":360,"msid":"com.lazyprogrammer.dartscore","adtest":"on","js":"afma-sdk-a-v6.0.1","mv":"8011019.com.android.vending","isu":"70069487A7A68D24BEF2581104A73318","cipa":0,"format":"360x50_mb","net":"wi","smart_h":"auto","app_name":"1.android.com.lazyprogrammer.dartscore","hl":"en","smart_w":"full","u_h":613,"carrier":"26203","ptime":225498,"u_audio":1});</script></head><body></body></html>
E/Ads(11448): JS: Uncaught ReferenceError: AFMA_getSdkConstants is not defined (about:blank:1)
E/Web Console(11448): Uncaught ReferenceError: AFMA_getSdkConstants is not defined at about:blank:1
I/Ads(11448): AdLoader timed out after 60000ms while getting the URL.
D/webviewglue(11448): nativeDestroy view: 0x2bc958
I/Ads(11448): onFailedToReceiveAd(A network error occurred.)
I/Ads(11448): AdLoader timed out after 60000ms while getting the URL.
D/webviewglue(11448): nativeDestroy view: 0x5a1850
I/Ads(11448): onFailedToReceiveAd(A network error occurred.)

我在谷歌或其他地方找不到关于这个问题的任何东西,我不认为我做错了什么。

以防万一,这是我应该显示广告的 xml 片段:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:ads="http://schemas.android.com/apk/lib/com.google.ads"
    ...

    <com.google.ads.AdView
        android:id="@+id/adView"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        ads:adSize="SMART_BANNER"
        ads:adUnitId="MyIDhere"
        ads:loadAdOnCreate="true"
        ads:testDevices="70069487A7A68D24BEF2581104A73318" />

</RelativeLayout>

当然,我为这个问题取出了所有 - 我认为 - 不必要的代码,但如果有必要查看它,我也会在这里发布。

我还拿出了我的 AdMob UnitID,您可能已经猜到了,但我在这里写这篇文章是为了避免缺少 UnitId 的答案。

我的清单列出了正确的权限:
android.permission.ACCESS_NETWORK_STATE
android.permission.INTERNET

而且我还添加了正确的 configChanges 的 AdActivity

4

5 回答 5

10

是连接问题。我通过卸载我的广告拦截器来修复它...

于 2013-04-10T20:50:14.187 回答
10

我也有这个错误,并通过在单独的线程中加载广告来解决(在 ICS 中,您不允许在主线程中执行网络操作)

(new Thread() {
                public void run() {
                     Looper.prepare();
                    adView.loadAd(new AdRequest());
                }
            }).start();
于 2012-06-15T10:59:16.900 回答
3

只需检查您所有的互联网连接。我的笔记本电脑有互联网,而手机没有。我确实尝试连接到笔记本电脑上的网络服务器,它工作正常。所以在尝试使用手机后,我重新启动了我的 DSL 路由器。一切都很好,然后恢复正常。

于 2013-04-07T15:14:06.137 回答
2

在网络之间移动并让模拟器运行时,我遇到了这个问题。

我发现连接到新网络后只需重新启动模拟器即可解决问题。

于 2013-02-05T08:36:16.380 回答
1

检查 /etc/hosts 文件。许多自定义 rom 都有 adblock 条目...

于 2014-01-09T12:45:42.390 回答