无法获取提供程序com.google.firebase.provider.FirebaseInitProvider的错误路径 Android。

31
我有一个连接到Firebase的应用程序。问题是当在设备上安装应用程序时(在多个设备上工作),出现了问题。我阅读了很多论坛,但没有一个有效。我在这里这里等等阅读过。谢谢!错误在这里。
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();
        }

    }

}

}


尝试这个解决方案:https://dev59.com/2FoU5IYBdhLWcg3wi3SW - M.Waqas Pervez
1
你的代码在哪里? - vipin agrahari
1
谢谢,但是不起作用! - azsoftco
请发布您的 build.gradle 文件中的依赖项部分。 - Bob Snyder
1
这对我有用 https://dev59.com/2FoU5IYBdhLWcg3wi3SW#38224316 - Jeba Ranganathan
显示剩余2条评论
6个回答

84

在运行 API 19(< 4.4.2)以下设备时,我也曾遇到 Firebase 的同样问题,原因是 Multidex 错误。下面的 解决方案 对我有用:

在应用程序模块的 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);
    }

}

5
添加了最后一步重写attachBaseContext方法,现在可以使用了。 - gdenuf
1
添加attachBaseContext方法解决了我的Kitkat崩溃问题。在没有这个方法的所有上面版本中都可以正常工作。 - SourabhMore
Plugin with id 'com.google.gms.google-services' not found. - php_nub_qq

25
在AndroidStudio中,请尝试执行以下操作:
  1. 按下ctrl+alt+s
  2. 点击“Build, Execution, Deployment”
  3. 禁用“即时运行”
这样应该可以解决问题。

8
哎呀,这个Android Studio出了大问题。 - Michalsx
1
这对我有效,但不是multidex解决方案。那么我就不能再使用即时运行了吗? - Christian
2
即时运行是Android Studio中一个令人痛苦的功能! - VSB
1
经过4个小时的调试,这对我起作用了。我从来没有想到这会起作用。谢谢。 - Pooja

4

禁用即时运行功能对我来说解决了问题。

Android Studio -> 首选项 -> 构建、执行、部署 -> 即时运行

-取消选中“启用即时运行…”旁边的复选框

-点击确定


在发布重复答案之前,请先阅读上面的答案。谢谢。 - blueware

0
如果你最近在 gradle 中更改了 Firebase 依赖版本,那么你可能也需要更新 Android SDK 管理器中的 Google 存储库到最新版本。
如果你无法及时更新 Google 存储库,请尝试将 gradle 依赖版本降低。

0
我遇到了同样的问题,我所做的是从设备/模拟器中卸载该应用程序,然后再次安装它(从Android Studio中的“运行”按钮)。

-1
只需将以下行插入到您的项目AndroidManifest.xml文件中,如果它们不在application标记中。
<meta-data
        android:name="com.google.android.gms.version"
        android:value="@integer/google_play_services_version" />

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接