迁移到AndroidX后,我在启动时遇到以下异常:
LoadedApk: Unable to instantiate appComponentFactory
java.lang.ClassNotFoundException: Didn't find class "androidx.core.app.CoreComponentFactory" on path: DexPathList[[],nativeLibraryDirectories=[/data/app/com.apps.entertainmentsolutions.offhole-yUKw5A4ysDVrPyO-DpnhKg==/lib/arm64, /system/lib64, /system/vendor/lib64]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at android.app.LoadedApk.createAppFactory(LoadedApk.java:217)
at android.app.LoadedApk.updateApplicationInfo(LoadedApk.java:329)
at android.app.ActivityThread.handleDispatchPackageBroadcast(ActivityThread.java:5410)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1743)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at com.android.server.SystemServer.run(SystemServer.java:460)
at com.android.server.SystemServer.main(SystemServer.java:300)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:838)
我正在Windows 10中使用Android Studio 3.4.1。
我尝试了所有可以找到的解决方案,但问题仍然存在:
Android design support library for API 28 (P) not working
AndroidX Build Fails in Release Mode regarding appComponentFactory
我添加了-keep类androidx.core.app.CoreComponentFactory {*; }到proguard-rules.pro,我在gradle.properties中添加了android.useAndroidX = true和android.enableJetifier = true ...清理,重建,使chachs无效并重新启动...
也禁用即时运行...
另一个有趣的事实是,我可以从其他类中导入没有问题的类(导入androidx.core.app.CoreComponentFactory;)。
我的gradle文件。项目gradle:
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
jcenter()
maven {
url 'https://maven.fabric.io/public'
}
google()
}
dependencies {
classpath 'com.android.tools.build:gradle:3.4.1'
classpath 'com.google.gms:google-services:4.2.0'
classpath 'io.fabric.tools:gradle:1.28.0'
}
}
allprojects {
repositories {
maven {
url "https://maven.google.com" // Google's Maven repository
}
jcenter()
google()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
应用gradle:
apply plugin: 'com.android.application'
apply plugin: 'io.fabric'
android {
compileSdkVersion 28
defaultConfig {
applicationId "co.offtime.kit"
minSdkVersion 24
targetSdkVersion 28
versionCode 1
versionName "4.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
vectorDrawables.useSupportLibrary = true
}
buildTypes {
beta {
versionNameSuffix ".beta"
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
zipAlignEnabled true
signingConfig signingConfigs.debug
}
debug {
versionNameSuffix ".debug"
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
zipAlignEnabled true
signingConfig signingConfigs.debug
}
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt' ), 'proguard-rules.pro'
signingConfig signingConfigs.debug
}
}
productFlavors {
//main application
kit {
applicationId "co.offtime.kit"
dimension "release"
versionName "v.kit.4.0"
versionCode 236
}
}
packagingOptions {
exclude 'META-INF/DEPENDENCIES'
exclude 'META-INF/LICENSE'
exclude 'META-INF/LICENSE.txt'
exclude 'META-INF/license.txt'
exclude 'META-INF/NOTICE'
exclude 'META-INF/NOTICE.txt'
exclude 'META-INF/notice.txt'
exclude 'META-INF/ASL2.0'
}
}
def AAVersion = '4.6.0'
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
implementation 'com.google.android.material:material:1.0.0'
implementation 'androidx.vectordrawable:vectordrawable:1.0.0'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
annotationProcessor "org.androidannotations:androidannotations:$AAVersion"
implementation "org.androidannotations:androidannotations-api:$AAVersion"
implementation 'org.springframework.android:spring-android-rest-template:2.0.0.M3'
implementation 'com.fasterxml.jackson.core:jackson-core:2.4.1'
implementation 'com.fasterxml.jackson.core:jackson-annotations:2.4.1'
implementation 'com.fasterxml.jackson.core:jackson-databind:2.4.1'
implementation 'com.google.firebase:firebase-core:16.0.9'
implementation 'com.google.firebase:firebase-messaging:18.0.0'
implementation 'com.google.firebase:firebase-core:16.0.9'
implementation 'com.crashlytics.sdk.android:crashlytics:2.10.0'
implementation 'com.google.android.gms:play-services-gcm:16.1.0'
repositories {
maven {
url 'https://repo.spring.io/libs-milestone'
}
}
}
apply plugin: 'com.google.gms.google-services'
Gradle属性:
org.gradle.jvmargs=-Xmx1536m
android.useAndroidX=true
android.enableJetifier=true
Proguard:
-keep class androidx.core.app.CoreComponentFactory { *; }
清单:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<uses-permission android:name="android.permission.BLUETOOTH" />
<uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.REORDER_TASKS" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.DISABLE_KEYGUARD" />
<uses-permission android:name="android.permission.REQUEST_COMPANION_USE_DATA_IN_BACKGROUND" />
<uses-permission android:name="android.permission.EXPAND_STATUS_BAR" />
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.REQUEST_IGNORE_BATTERY_OPTIMIZATIONS" />
<uses-permission android:name="android.permission.ACCESS_NOTIFICATION_POLICY" />
<application
android:name="co.offtime.kit.core.AppGlobals_"
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity
android:name="co.offtime.kit.SplashScreen_"
android:label="@string/app_name"
android:theme="@style/Theme.AppCompat.Light.NoActionBar">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data
android:host="www.offtime.app"
android:scheme="http" />
</intent-filter>
</activity>
<activity
android:name=".ParentActivity_"
android:label="parentActivity" />
<activity
android:name="co.offtime.kit.InitialDataLoadActivity_"
android:parentActivityName=".ParentActivity_" />
<activity
android:name="co.offtime.kit.LoginActivity_"
android:configChanges="orientation|screenSize"
android:label="@string/login_title"
android:theme="@style/Theme.AppCompat.Light.NoActionBar" />
<activity
android:name="co.offtime.kit.NewUserFormActivity_"
android:configChanges="orientation|screenSize"
android:label="@string/new_user_form_title"
android:theme="@style/Theme.AppCompat.Light.NoActionBar" />
<activity
android:name="co.offtime.kit.TestButtonsActivity_"
android:label="@string/app_name"
android:parentActivityName="co.offtime.kit.DisableHardwareButtonsActivity_">
</activity>
<activity
android:name="co.offtime.kit.DisableHardwareButtonsActivity_"
android:label="disableHardwareButtonsActivity" />
<activity
android:name="co.offtime.kit.EventListActivity_"
android:label="@string/event_list_title" />
<activity
android:name="co.offtime.kit.EventDetailFormActivity_"
android:label="@string/new_event_title" />
<!-- ACTIVITIES -->
<activity
android:name="co.offtime.kit.BlockActivity_"
android:configChanges="orientation|screenSize"
android:launchMode="singleTask"
android:parentActivityName="co.offtime.kit.DisableHardwareButtonsActivity_"
android:screenOrientation="portrait" />
<service android:name="co.offtime.kit.core.services.ClosingAppWatcherService_"
android:stopWithTask="false" />
<receiver android:name="co.offtime.kit.core.AvoidCameraUseDeviceAdminReceiver"
android:permission="android.permission.BIND_DEVICE_ADMIN">
<meta-data
android:name="android.app.device_admin"
android:resource="@xml/device_policies" />
<meta-data android:name="com.google.firebase.messaging.default_notification_icon"
android:resource="@drawable/ic_notifications_white_24dp" />
<intent-filter>
<action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
<action android:name="android.app.action.DEVICE_ADMIN_DISABLE_REQUESTED" />
<action android:name="android.app.action.DEVICE_ADMIN_DISABLED" />
</intent-filter>
</receiver>
<receiver android:name="co.offtime.kit.core.broadcastreceiver.CallBlockerReceiver_">
<intent-filter android:priority="9999">
<action android:name="android.intent.action.PHONE_STATE" />
<action android:name="android.intent.action.NEW_OUTGOING_CALL" />
</intent-filter>
</receiver>
<receiver
android:name="co.offtime.kit.core.broadcastreceiver.BootCompleteDeviceBroadcastReceiver_"
android:enabled="true">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<action android:name="android.intent.action.QUICKBOOT_POWERON" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
<service
android:name="co.offtime.kit.core.services.LaunchBlockJobService"
android:label="LaunchBlockJobService"
android:permission="android.permission.BIND_JOB_SERVICE" />
<service android:name="co.offtime.kit.core.services.EventExecutorService_"
android:enabled="true"
android:exported="true"
android:stopWithTask="false" />
<service android:name="co.offtime.kit.core.fcmpushnotifications.MyFirebaseMessagingService">
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT" />
<action android:name="com.google.firebase.INSTANCE_ID_EVENT" />
</intent-filter>
</service>
<service android:name="co.offtime.kit.core.fcmpushnotifications.FcmTokenUpdateService_"
android:enabled="true"
android:exported="true"
android:stopWithTask="false" />
</application>
现在这不会引起ANR,该应用程序可以启动并正常运行,但是我担心它将来会引起问题,我想知道为什么会发生这种情况。
有人遇到过这个问题吗?是怎么解决的?
答案 0 :(得分:1)
看起来CoreComponentFactory
类正在加密。尝试将以上类添加到proguard-rules中。
-keep class androidx.core.app.CoreComponentFactory { *; }
因此CoreComponentFactory
将不再是加密的。
答案 1 :(得分:0)
在查看this question上的Android Issue Tracker错误报告后,我看到了有关multidex支持的提及。我没有在项目中指定multidex标志,所以我尝试在项目中的所有模块上将标志设置为false,然后异常消失了。
这不是永久解决方案;问题稍后又返回了几个版本。
答案 2 :(得分:0)
尝试在AVD模拟器上运行debug
android应用程序时遇到此错误。
从仿真器(从AVD Manager)擦除数据可以解决此问题。