Admob 显示带有测试 adUnitId 的测试广告,但对于真正的 adUnitId 应用程序崩溃了
Admob shows Test ads with test adUnitId but for real adUnitId app crashed
当我使用 test(ca-app-pub-3940256099942544/6300978111) adUnitId 测试我的应用程序时,它会显示广告,但是当我将测试 adUnitId 替换为真正的应用程序时,它会崩溃。
错误日志:
E/AndroidRuntime: FATAL EXCEPTION: Thread-13
Process: biz.coolpage.aashish.app, PID: 13682
java.lang.NoClassDefFoundError: Failed resolution of: Lorg/apache/http/ProtocolVersion;
at jp.b(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):3)
at jo.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):3)
at jq.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):19)
at com.google.android.gms.ads.internal.util.aq.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):15)
at iu.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):19)
at iu.run(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):8)
Caused by: java.lang.ClassNotFoundException: Didn't find class "org.apache.http.ProtocolVersion" on path: DexPathList[[zip file "/data/user_de/0/com.google.android.gms/app_chimera/m/0000000f/AdsDynamite.apk"],nativeLibraryDirectories=[/data/user_de/0/com.google.android.gms/app_chimera/m/0000000f/AdsDynamite.apk!/lib/x86, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at ad.loadClass(:com.google.android.gms.dynamite_dynamiteloader@14799084@14.7.99 (100700-223214910):4)
xml 文件中的 LinearLayout 内部:
<com.google.android.gms.ads.AdView
xmlns:ads="http://schemas.android.com/apk/res-auto"
android:id="@+id/adView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom|center_horizontal"
ads:adSize="SMART_BANNER"
ads:adUnitId="@string/banner_ad_unit_id">
</com.google.android.gms.ads.AdView>
OnCreate 方法内部:
MobileAds.initialize(this, getString(R.string.AdMob_app_id));
mAdView = findViewById(R.id.adView);
AdRequest adRequest = new AdRequest.Builder().build();
mAdView.loadAd(adRequest);
在浪费了这么多时间之后,我终于找到了这次崩溃的根本原因。
当您在 AdMob 帐户中添加应用程序时,默认情况下,基于位置的广告已开启。因此,如果您的应用没有位置权限,则应用会崩溃。
解法:--
或者您将关闭基于 AdMob 帐户位置的广告
或
您可以要求您的用户提供对其位置的访问权限。
当我使用 test(ca-app-pub-3940256099942544/6300978111) adUnitId 测试我的应用程序时,它会显示广告,但是当我将测试 adUnitId 替换为真正的应用程序时,它会崩溃。
错误日志:
E/AndroidRuntime: FATAL EXCEPTION: Thread-13
Process: biz.coolpage.aashish.app, PID: 13682
java.lang.NoClassDefFoundError: Failed resolution of: Lorg/apache/http/ProtocolVersion;
at jp.b(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):3)
at jo.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):3)
at jq.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):19)
at com.google.android.gms.ads.internal.util.aq.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):15)
at iu.a(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):19)
at iu.run(:com.google.android.gms.dynamite_adsdynamite@14799084@14.7.99 (100700-223214910):8)
Caused by: java.lang.ClassNotFoundException: Didn't find class "org.apache.http.ProtocolVersion" on path: DexPathList[[zip file "/data/user_de/0/com.google.android.gms/app_chimera/m/0000000f/AdsDynamite.apk"],nativeLibraryDirectories=[/data/user_de/0/com.google.android.gms/app_chimera/m/0000000f/AdsDynamite.apk!/lib/x86, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at ad.loadClass(:com.google.android.gms.dynamite_dynamiteloader@14799084@14.7.99 (100700-223214910):4)
xml 文件中的 LinearLayout 内部:
<com.google.android.gms.ads.AdView
xmlns:ads="http://schemas.android.com/apk/res-auto"
android:id="@+id/adView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom|center_horizontal"
ads:adSize="SMART_BANNER"
ads:adUnitId="@string/banner_ad_unit_id">
</com.google.android.gms.ads.AdView>
OnCreate 方法内部:
MobileAds.initialize(this, getString(R.string.AdMob_app_id));
mAdView = findViewById(R.id.adView);
AdRequest adRequest = new AdRequest.Builder().build();
mAdView.loadAd(adRequest);
在浪费了这么多时间之后,我终于找到了这次崩溃的根本原因。
当您在 AdMob 帐户中添加应用程序时,默认情况下,基于位置的广告已开启。因此,如果您的应用没有位置权限,则应用会崩溃。
解法:--
或者您将关闭基于 AdMob 帐户位置的广告
或
您可以要求您的用户提供对其位置的访问权限。