Flutter启动时崩溃:在DexPathList路径上找不到class .MainActivity

17

我正在使用启用了MultiDex构建器的Flutter来开发Android应用时,遇到了一个比较棘手的问题。我的应用一直在没有任何异常情况下运行,但是当添加video_player包后,在启动时就会崩溃:

FATAL EXCEPTION: main
Process: com.rsg.anygoal, PID: 5883
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.rsg.anygoal/com.rsg.anygoal.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "com.rsg.anygoal.MainActivity" on path: DexPathList[[zip file "/data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/base.apk"],nativeLibraryDirectories=[/data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/lib/x86, /data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/base.apk!/lib/x86, /system/lib, /vendor/lib]]
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2679)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
    at android.app.ActivityThread.-wrap11(Unknown Source:0)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
    at android.os.Handler.dispatchMessage(Handler.java:106)
    at android.os.Looper.loop(Looper.java:164)
    at android.app.ActivityThread.main(ActivityThread.java:6494)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
 Caused by: java.lang.ClassNotFoundException: Didn't find class "com.rsg.anygoal.MainActivity" on path: DexPathList[[zip file "/data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/base.apk"],nativeLibraryDirectories=[/data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/lib/x86, /data/app/com.rsg.anygoal-tCKWlQXJD-iwdHtVRl0qqA==/base.apk!/lib/x86, /system/lib, /vendor/lib]]
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:125)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
    at android.app.Instrumentation.newActivity(Instrumentation.java:1174)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2669)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856) 
    at android.app.ActivityThread.-wrap11(Unknown Source:0) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589) 
    at android.os.Handler.dispatchMessage(Handler.java:106) 
    at android.os.Looper.loop(Looper.java:164) 
    at android.app.ActivityThread.main(ActivityThread.java:6494) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807

在研究此问题时,我尝试禁用MultiDex,并且看起来解决了问题,但是添加额外的flutter包后,应用程序再次崩溃,所以我决定它并不严格由multiDex引起,于是重新启用它。

在论坛中我找到了另一个修复尝试,即将".MainActivity"重命名为完整的类路径"com.*...*.MainActivity",但这也没有帮助。

希望有人能建议可能的解决方法!以下是我在调查期间收集的一些日志和代码片段,其中可能包含对您有用的线索。

完整的Android logcat日志:https://pastebin.com/vPs614jj

Flutter pubspec(名称和描述被故意省略):

version: 1.0.6+16
environment:
  sdk: ">=2.1.0 <3.0.0"

dependencies:
  flutter:
    sdk: flutter
  cupertino_icons: ^0.1.2
  intl: ^0.15.8
  firebase_core: ^0.4.3+1
  firebase_admob: ^0.9.0+10
  firebase_analytics: ^5.0.9
  firebase_auth: ^0.15.3
  firebase_crashlytics: ^0.1.2+4
  firebase_performance: ^0.3.1+5
  firebase_remote_config: ^0.3.0+1
  firebase_messaging: ^6.0.9
  firebase_dynamic_links: ^0.5.0+9
  cloud_firestore: ^0.13.0+1
  cloud_functions: ^0.4.1+6
  google_sign_in: ^4.1.1
  provider: ^4.0.1
  data_connection_checker: ^0.3.4
  shared_preferences: ^0.5.6
  flutter_markdown: ^0.3.2
  url_launcher: ^5.4.1
  barcode_scan: ^1.0.0
  qr_flutter: ^3.2.0
  share: ^0.6.3+5
  video_player: ^0.10.11+2

dev_dependencies:
  flutter_test:
    sdk: flutter

flutter:
  fonts:
    - family: Raleway
      fonts:
        - asset: fonts/Raleway-Regular.ttf
  uses-material-design: true

Android清单文件:

<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="$APP_DOMAIN">
    <application android:name="io.flutter.app.FlutterApplication" android:label="$APP_NAME" android:icon="@mipmap/ic_launcher">
        <activity android:name=".MainActivity" android:launchMode="singleTop" android:theme="@style/LaunchTheme" android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode" android:hardwareAccelerated="true" android:windowSoftInputMode="adjustResize">
            <meta-data android:name="io.flutter.app.android.SplashScreenUntilFirstFrame" android:value="true" />
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
            <intent-filter>
                <action android:name="FLUTTER_NOTIFICATION_CLICK" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <meta-data android:name="com.google.android.gms.ads.APPLICATION_ID" android:value="$APP_ADS_ID"/>
        <meta-data
            android:name="com.google.firebase.messaging.default_notification_icon"
            android:resource="@drawable/notification_icon" />
    </application>

    <uses-permission android:name="android.permission.INTERNET"/>
</manifest>

MainActivity.java:

import android.os.Bundle;
import io.flutter.app.FlutterActivity;
import io.flutter.plugins.GeneratedPluginRegistrant;

public class MainActivity extends FlutterActivity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    GeneratedPluginRegistrant.registerWith(this);
  }
}

Flutter医生输出(XCode无关):

Doctor summary (to see all details, run flutter doctor -v):
[✓] Flutter (Channel stable, v1.17.5, on Mac OS X 10.15.4 19E287, locale en-BG)
 
[✓] Android toolchain - develop for Android devices (Android SDK version 29.0.3)
[!] Xcode - develop for iOS and macOS
    ✗ Xcode installation is incomplete; a full installation is necessary for iOS development.
      Download at: https://developer.apple.com/xcode/download/
      Or install Xcode via the App Store.
      Once installed, run:
        sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer
        sudo xcodebuild -runFirstLaunch
[✓] Android Studio (version 3.5)
[✓] VS Code (version 1.46.1)
[✓] Connected device (1 available)

1
你找到任何解决方案了吗?我也遇到了这个问题.. @Radi Cho - fajar ainul
@fajarainul 请查看我在 GitHub 上的评论,其中提供了可能的解决方法:https://github.com/flutter/flutter/issues/60831#issuecomment-654070155 - John
你的解决方案对我不起作用。你有其他的解决方案吗? - fajar ainul
我的项目使用Firebase云消息传递(https://pub.dev/packages/firebase_messaging/versions/5.1.8)(我使用v.5.1.8,由于某些原因无法更新),并且想要处理后台消息。当我将Application.java添加到AndroidManifest.xml时,出现了错误。以下是日志记录:在路径上没有找到“id.kasku.kasku_mobile_flutter.Application”的类:DexPathList [[zip文件“/data/app/id.kasku.kasku_mobile_flutter-2/base.apk”]。 - fajar ainul
13个回答

47

我曾经遇到过类似的错误,那是在改"包名"之后。 我的解决方案是: 还要在MainActivity.kt中更新包名。 简而言之,所有包名都应相应地进行修复。

之后,问题就解决了。


这对我有用。我进行了搜索和替换,并将所有旧软件包名称替换为新的软件包名称。我使用了来自pub.dev的change_app_package_name库-但它没有更改MainActivity.kt和project.pbxproj文件。搜索替换解决了这个问题。 - positrix
这是正确的答案,最好的祝福兄弟。 - wesleyhodaj
我实际上需要添加一个正确命名的新包,将更新的 .kt 文件移动到其中,然后删除旧文件。感谢 @ehcp 的答案。 - jasonflaherty

8

我的研究表明,这不是Flutter本身的问题,而是在特定的Flutter包安装后发生的。升级Gradle和AndroidX库后,崩溃问题消失了,但在添加另一个Flutter包后又重新出现。然后我再次清理了Android项目(在IDE中执行 build->clean),问题就被解决了。所以可能是由于我的环境中有一些Gradle混淆,并且可能会偶尔无法正确编译某些类。


1
这是错误的。这不是Flutter的问题。我在使用pub.dev的change_app_package_name更改包名称后遇到了这个问题。显然,它没有在所有地方更改包名称。它没有更改MainActivity.kt和project.pbxproj文件。我进行了搜索和替换,这解决了问题。 - positrix
2
清理项目并重新构建,对我来说可以正常工作。 - Ahmed Rajab

7

解决方案:简单的解决方法是打开MainActivity.kt文件,将包名与AndroidManifest.xml文件中的相应项进行匹配。


你救了我的一天 ✨ - Deekshith Xetty
@DeekshithXetty 很棒! - Imtiaz

5

如果使用Android Studio/Flutter,最简单的解决方法如下:

1:停止应用程序,然后打开MainActivity.kt文件:

path : "**android/src/main/kotlin/MainActivity.kt**"

如果你的MainActivity中的包名与你的应用程序不匹配,请在MainActivity.kt中更新它。

Android Studio

2: 然后进入编辑>查找和替换文件,并在整个应用程序和所有文件中将先前的包名替换为新包名。在进行下一步之前,重新启动Android Studio(无效缓存并重启)。

3: 重启后...打开app/src/build.gradle并启用multidex:

defaultConfig {
    applicationId "com.your.apppackage"
    minSdkVersion 28
    targetSdkVersion 30
    versionCode flutterVersionCode.toInteger()
    versionName flutterVersionName
    multiDexEnabled true //add multidex enabled
}

不要忘记在同一个gradle文件中添加multidex依赖:

**dependencies {**
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
    implementation 'com.google.android.material:material:1.4.0'
    implementation 'androidx.multidex:multidex:2.0.1' // add it as a dependency here
}

最后,使缓存失效并重新启动。 (文件>使缓存失效/重启)。

4
这不是一个完美的解决方案,但它是有效的。 由于某些原因,dex文件没有编译MainActivity。因此,我们直接将FlutterActivity添加到清单中,这解决了我们的问题。
<application
        android:label="morari"
        android:icon="@mipmap/ic_launcher">
        <activity
            android:name="io.flutter.embedding.android.FlutterActivity"
            ...>
            ...
 </application>

Dex files:

enter image description here


作为一个临时解决方案,它非常有效,谢谢! - egarro
完美运作 - undefined

4
当我将包名(应用ID)从com.example.myappone改为com.myapp.one时,发生了这种情况。我以为只需要在android/app/src/main/AndroidManifest.xmlios/Runner.xcodeproj/project.pbxproj中更改值就足够了。
结果发现实际上还需要更改实际的包名,以便编译器可以找到源文件。

3
在我的情况下,这是因为我无意中注释掉(删除)了以下行:

package com.mypackagename

在我编辑"MainActivity.kt"文件时,出现了问题!简单地将其添加回去就解决了。


2
在我的情况下,我将Flutter项目的包名从默认值更改了,但是没有在MainActivity.kt文件中更新包名。
希望这可以帮到你。

你的回答可以通过提供更多支持信息来改进。请编辑以添加进一步的细节,例如引用或文档,以便他人可以确认你的答案是正确的。您可以在帮助中心找到有关如何编写良好答案的更多信息。 - Community

0

我不知道为什么我的MainActivity.java文件不见了,所以我创建了一个新的,然后应用程序就可以工作了。


0
可能原因:标签未正确放置在清单文件中是此错误的原因之一。
解决方案:确保所有标签都正确放置在 /src/main 的 AndroidManifest.xml 文件中。

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