2016-11-03 4 views
0

私の現在のプロジェクトでは、通知用にFCMを使用しています。その良いと正常に動作しますが、私はlolypop未満のデバイス、つまりバージョン21でアプリケーションを開こうとすると、最初はクラッシュします。<= Lolypopデバイスで動作していないFirebaseライブラリ

私は多くのSO投稿をチェックアウトしましたが、誰も回答としてそれを修正していることはありませんでした。

私は助けてください

compile 'com.google.android.gms:play-services:9.8.0' 
compile 'com.google.android.gms:play-services-auth:9.8.0' 
compile 'com.google.firebase:firebase-core:9.8.0' 
compile 'com.google.firebase:firebase-messaging:9.8.0' 

以下のように最新バージョンのライブラリを使用しています、私はjellybean機器件まで少なくともサポートを提供する必要があります。

クラッシュログ:

FATAL EXCEPTION: main 
Process: com.arpaul.geocare, PID: 3127 
java.lang.RuntimeException: Unable to get provider com.google.firebase.provider.FirebaseInitProvider: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.arpaul.geocare-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.arpaul.geocare-2, /vendor/lib, /system/lib]] 
    at android.app.ActivityThread.installProvider(ActivityThread.java:4793) 
    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4385) 
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4325) 
    at android.app.ActivityThread.access$1500(ActivityThread.java:135) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:136) 
    at android.app.ActivityThread.main(ActivityThread.java:5017) 
    at java.lang.reflect.Method.invokeNative(Native Method) 
    at java.lang.reflect.Method.invoke(Method.java:515) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
    at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/com.arpaul.geocare-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.arpaul.geocare-2, /vendor/lib, /system/lib]] 
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:497) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:457) 
    at android.app.ActivityThread.installProvider(ActivityThread.java:4778) 
    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4385)  
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4325)  
    at android.app.ActivityThread.access$1500(ActivityThread.java:135)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop 
+1

クラッシュログを投稿できますか? –

答えて

1

com.google.android.gms:play-services:9.8.0への依存は、Googleがあなたが必要としないそのほとんどがサービスAPIを、再生ALL含めています。これは不必要にAPKのサイズを増やし、時間を短縮します。おそらく古いアプリでMultidexが必要な64Kを超えるメソッドリファレンスをアプリケーションにexplained hereとしてもたせることになります。

代わりにcom.google.android.gms:play-services:9.8.0の依存関係を削除し、必要な特定のAPIに置き換える必要があります。そのための手順は、のセクションのprovided hereです。実行可能ファイルにAPIを選択的にコンパイルします。

+0

うん、いいですね。でも、Firebaseを使用する必要があります。それが問題の原因です。 – Ari

+0

Firebaseライブラリを組み込んでも問題は発生していません。インクルードされているライブラリの総数が大きすぎるため、Firebaseのメソッドが見つかりません。 –

+0

これも試してみます。私はマップと認証が必要な場合はマップと認証とfirebase今のところ、私はマップと私はメッセージングのためのプレイサービスを見つけることができない理由がある場合は動作しますか? – Ari

関連する問題