web-dev-qa-db-ja.com

「プロバイダーcom.google.firebase.provider.FirebaseInitProviderを取得できません」エラーパスAndroid

Firebaseに接続されたアプリケーションがあります。問題は、デバイスにアプリをインストールするときです(複数のデバイスで動作します)。多くのフォーラムを読みましたが、誰も動作しません。 here および- this など。ありがとう!!

エラーはこちらです。

E/AndroidRuntime: FATAL EXCEPTION: main
              Process: com.dev.ptruck, PID: 8833
              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.dev.ptruck-17.apk"],nativeLibraryDirectories=[/data/app-lib/com.dev.ptruck-17, /vendor/lib, /system/lib]]
                  at Android.app.ActivityThread.installProvider(ActivityThread.Java:5196)
                  at Android.app.ActivityThread.installContentProviders(ActivityThread.Java:4788)
                  at Android.app.ActivityThread.handleBindApplication(ActivityThread.Java:4728)
                  at Android.app.ActivityThread.access$1500(ActivityThread.Java:166)
                  at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1343)
                  at Android.os.Handler.dispatchMessage(Handler.Java:102)
                  at Android.os.Looper.loop(Looper.Java:136)
                  at Android.app.ActivityThread.main(ActivityThread.Java:5584)
                  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:1268)
                  at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:1084)
                  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.dev.ptruck-17.apk"],nativeLibraryDirectories=[/data/app-lib/com.dev.ptruck-17, /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:5181)
                  at Android.app.ActivityThread.installContentProviders(ActivityThread.Java:4788) 
                  at Android.app.ActivityThread.handleBindApplication(ActivityThread.Java:4728) 
                  at Android.app.ActivityThread.access$1500(ActivityThread.Java:166) 
                  at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1343) 
                  at Android.os.Handler.dispatchMessage(Handler.Java:102) 
                  at Android.os.Looper.loop(Looper.Java:136) 
                  at Android.app.ActivityThread.main(ActivityThread.Java:5584) 
                  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:1268) 
                  at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:1084) 
                  at dalvik.system.NativeStart.main(Native Method) 

こちらがスタートクラスです

public class StartActivity extends Activity {
private static final String FIREBASE_URL = "https://database.firebaseio.com/";
private Firebase myFirebaseRef = null;
View rootView;
String uid;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_start);

    Firebase.setAndroidContext(this);
    final ProgressBar p = (ProgressBar) findViewById(R.id.start_progress_bar);

}
private void checkUserLogin() {
                    myFirebaseRef.addAuthStateListener(new Firebase.AuthStateListener() {
                        @Override
                        public void onAuthStateChanged(AuthData authData) {
                            if (authData != null) {

                                System.out.println(myFirebaseRef.getKey());
                                Intent toMainActivity = new Intent(getApplicationContext(), MenuActivity.class);
                                uid = myFirebaseRef.getAuth().getUid();
                                toMainActivity.putExtra("user_id", uid);
                                finish();
                                startActivity(toMainActivity);

                            } else if (authData == null) {

                                Intent toMainActivity = new Intent(getApplicationContext(), LoginActivity.class);
                                startActivity(toMainActivity);
                                // user is not logged in
                            }
                        }
                    });
}
private Runnable task = new Runnable() {
    public void run() {

        checkUserLogin();
    }
};
@Override
protected void onStart() {
    super.onStart();
    if(myFirebaseRef == null) {
        myFirebaseRef = new Firebase(FIREBASE_URL);
    }
    Handler handler = new Handler();
    handler.postDelayed(task, 3000);

}
@Override
protected void onDestroy() {
    super.onDestroy();

    unbindDrawables(rootView);
    rootView = null;
    System.gc();

}
protected void unbindDrawables(View view) {
    if (view != null) {
        if (view.getBackground() != null) {
            view.getBackground().setCallback(null);
        }
        if (view instanceof ViewGroup && !(view instanceof AdapterView)) {
            for (int i = 0; i < ((ViewGroup) view).getChildCount(); i++) {
                unbindDrawables(((ViewGroup) view).getChildAt(i));
            }
            ((ViewGroup) view).removeAllViews();
        }

    }

}

}

28
azsoftco

また、Multidexのエラーが原因でAPI 19(<4.4.2)デバイスより下でアプリケーションを実行すると、Firebaseで同じ問題に直面しました。次に、以下のsolution私のために働く:

アプリモジュールbuild.gradle

Android {
   ...
   defaultConfig {
       multiDexEnabled true
       ...
   }
}

dependencies {
  // add dependency 
  compile 'com.Android.support:multidex:1.0.1'
}

// ADD THIS AT THE BOTTOM
apply plugin: 'com.google.gms.google-services'

androidManifest.xmlの名前を更新します

<application
    Android:allowBackup="true"
    Android:icon="@mipmap/ic_launcher"
    Android:label="@string/app_name"
    Android:supportsRtl="true"
    Android:name=".MyApplication"
    Android:theme="@style/AppTheme">

     // ...
</application>

MyApplication.Javaファイルを作成する

public class MyApplication extends Application {

    @Override
    protected void attachBaseContext(Context base) {
       super.attachBaseContext(base);
       MultiDex.install(this);
    }

}
74
Garg's

Android Studioでこれを試してください:

  1. 「インスタントラン」を無効にする
  2. これは動作するはずです

This should work

24
Antonio

インスタントランを無効にすると、問題が修正されました。

Android Studio->設定->ビルド、実行、展開->インスタント実行

-「インスタントランを有効にする...」の横のチェックボックスをオフにします

-[OK]をクリックします

2
Chris M

私は同じ問題を抱えています、私がやったことは、デバイス/エミュレータからアプリをアンインストールしてから、それを再インストールします(Android St​​udioから、「実行」ボタン)。

0
Lee

プロジェクトAndroidManifest.xmlファイルにapplicationタグにない場合は、以下の行を挿入するだけです

<meta-data
        Android:name="com.google.Android.gms.version"
        Android:value="@integer/google_play_services_version" />
0

Gradleでfirebaseの依存バージョンを最近変更した場合は、Android SDKマネージャーでも最新バージョンのGoogleリポジトリに更新する必要があります。

その時点でGoogleリポジトリを更新できない場合は、gradle依存関係のバージョンを以前のバージョンに戻してみてください。

0
sats