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

Posted

技术标签:

【中文标题】“无法获取提供程序 com.google.firebase.provider.FirebaseInitProvider”错误路径 Android【英文标题】:"Unable to get provider com.google.firebase.provider.FirebaseInitProvider" Error path Android 【发布时间】:2017-01-05 11:42:13 【问题描述】:

我有一个连接到 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();
        

    


【问题讨论】:

试试这个解决方案:***.com/questions/37360126/… 你的代码在哪里 谢谢,但不起作用! 发布你的 build.gradle 文件的依赖部分。 这对我有用***.com/a/38224316/4663544 【参考方案1】:

由于Multidex 的错误,在 API 19(解决方案为我工作:

在应用模块 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);
    


【讨论】:

grt 享受编码 也为我工作! (当我开始使用 Firebase 时,我遇到了这个问题),谢谢 :) 成功了!谢谢:) 我错过了覆盖 attachBaseContext 的最后一步。添加后工作。 添加 attachBaseContext 方法解决了我的 Kitkat 崩溃问题。没有这种方法,在上述所有版本中都可以正常工作。【参考方案2】:

在 AndroidStudio 中尝试这样做:

    ctrl+alt+s 点击“构建、执行、部署” 禁用“即时运行”

这应该可行

【讨论】:

天哪,Android Studio 失败了。 这对我有用,而不是 multidex 解决方案。所以我不能再使用即时运行了? 即时运行在 android studio 中是一个令人痛苦的功能! 经过4小时的调试。这对我有用。我从没想过这会奏效。谢谢。【参考方案3】:

禁用即时运行为我解决了这个问题。

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

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

-点击确定

【讨论】:

您可以在发布重复答案之前阅读上述答案。谢谢 @blueware 有些人可能认为我的回答更彻底。因此,与其通过发布这样的垃圾来浪费我们的时间,不如专注于提供帮助和回答问题。谢谢【参考方案4】:

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

【讨论】:

【参考方案5】:

如果您最近更改了 gradle 中的 firebase 依赖项版本,您可能还需要在 Android SDK 管理器中更新到最新版本的 Google Repository。

如果您当时无法更新 Google 存储库,请尝试将 gradle 依赖项版本更改回较低的版本。

【讨论】:

【参考方案6】:

只需在您的项目AndroidManifest.xml 文件中插入以下行, 如果它们不在 application 标签中

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

【讨论】:

以上是关于“无法获取提供程序 com.google.firebase.provider.FirebaseInitProvider”错误路径 Android的主要内容,如果未能解决你的问题,请参考以下文章