Flutter - 在运行Android 4.4(Kitkat)的小米设备上崩溃 - Firebase错误

3

我在小米设备上遇到了这个错误,尤其是在 Android 4.4(KitKat)上。

我的应用程序在启动时突然崩溃了,我已经捕获了错误日志:

E/AndroidRuntime(15685): FATAL EXCEPTION: main
E/AndroidRuntime(15685): Process: z.zapps, PID: 15685
E/AndroidRuntime(15685): 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/z.zapps-1.apk"],nativeLibraryDirectories=[/data/app-lib/z.zapps-1, /vendor/lib, /system/lib]]
E/AndroidRuntime(15685):    at android.app.ActivityThread.installProvider(ActivityThread.java:4828)
E/AndroidRuntime(15685):    at android.app.ActivityThread.installContentProviders(ActivityThread.java:4420)
E/AndroidRuntime(15685):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4360)
E/AndroidRuntime(15685):    at android.app.ActivityThread.access$1500(ActivityThread.java:141)
E/AndroidRuntime(15685):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272)
E/AndroidRuntime(15685):    at android.os.Handler.dispatchMessage(Handler.java:102)
E/AndroidRuntime(15685):    at android.os.Looper.loop(Looper.java:136)
E/AndroidRuntime(15685):    at android.app.ActivityThread.main(ActivityThread.java:5052)
E/AndroidRuntime(15685):    at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(15685):    at java.lang.reflect.Method.invoke(Method.java:515)
E/AndroidRuntime(15685):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796)
E/AndroidRuntime(15685):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612)
E/AndroidRuntime(15685):    at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(15685): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.firebase.provider.FirebaseInitProvider" on path: DexPathList[[zip file "/data/app/z.zapps-1.apk"],nativeLibraryDirectories=[/data/app-lib/z.zapps-1, /vendor/lib, /system/lib]]
E/AndroidRuntime(15685):    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
E/AndroidRuntime(15685):    at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
E/AndroidRuntime(15685):    at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
E/AndroidRuntime(15685):    at android.app.ActivityThread.installProvider(ActivityThread.java:4813)
E/AndroidRuntime(15685):    ... 12 more
W/ActivityManager( 1065):   Force finishing activity z.zapps/.MainActivity

我在pubspec.yaml文件中使用了Firebase库:

firebase_auth: ^0.8.2firebase_messaging: ^4.0.0+4

有什么解决方法吗?


这可能是该手机上Google Play服务(已过时)出现了问题。您是否尝试过创建一个集成Firebase的虚拟本地项目? - danypata
1个回答

4

简短回答: 使用以下命令生成APK文件:flutter build apk --target-platform=android-arm

详细解答: 问题出在设备的处理器类型上。在安卓世界中,有7种不同的处理器类型(mips、mips64、X86、X86–64、armeabi、arm64-v8a、armeabi-v7a)。标准的flutter build apk命令不能生成通用文件。

我认为您遇到的问题是使用ARM架构的armeabi处理器。

要解决这个问题,您需要制作一个特定的APK以支持该设备(系列)。为此,您可能需要使用以下命令:

flutter build apk --target-platform=android-arm

这是否意味着对于同一个应用程序你将会有两个不同版本的APK?是的。

这里有更多信息,这里是Google的官方文档。


1
好的,祝你好运 :) 我的应用程序在一些小米用户(特别是安卓6.0.1上的红米4和其他几款手机)上也遇到了同样的问题。最终,通过上述方法,我甚至可以在运行安卓4.4.x的红米1上运行它。 - Sukhi

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