Android 9 (API 28) 活动在启动时崩溃 (setContentView)
Posted
技术标签:
【中文标题】Android 9 (API 28) 活动在启动时崩溃 (setContentView)【英文标题】:Android 9 (API 28) activity crashes on start (setContentView) 【发布时间】:2019-02-08 10:35:39 【问题描述】:将我的手机从 android 8 更新到 9 时出现此问题。 该应用程序之前运行良好。
我试图通过包含相同的依赖项/配置,在我正在开发的其他一些应用程序中复制这一点,但我无法复制该行为。它总是在 setContentView 崩溃,即使对于简单的活动和简单的布局也是如此。
我进行了研究并得出结论,INTERACT_ACROSS_USERS_FULL
权限并不是问题的真正原因。
这种崩溃实际上发生在所有应用活动中,但 TestActivity 是最简单的。在运行 API 28 的三星 S9+ 和运行 Android 9、API 28 的像素模拟器上进行了测试。
编辑:当我将 android:name="...." 属性放入清单定义时,这似乎发生了。由于我确实需要应用程序类,因此我仍在寻找解决方案来完成这项工作。
活动(简化为具有崩溃所需的最少代码):
package com.marhat.albatros import android.os.Bundle import androidx.appcompat.app.AppCompatActivity; class TestActivity : AppCompatActivity() override fun onCreate(savedInstanceState: Bundle?) super.onCreate(savedInstanceState) setContentView(R.layout.activity_test)
布局:
<?xml version="1.0" encoding="utf-8"?> <androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_ android:layout_ tools:context=".TestActivity"> </androidx.coordinatorlayout.widget.CoordinatorLayout>
这是输出:
2019-02-08 11:54:19.088 20298-20298/com.marhat.albatros E/AndroidRuntime: FATAL EXCEPTION: main Process: com.marhat.albatros, PID: 20298 java.lang.RuntimeException: Unable to start activity ComponentInfocom.marhat.albatros/com.marhat.albatros.TestActivity:
java.lang.SecurityException:从用户 0 作为用户 1 调用,但没有 没有权限 INTERACT_ACROSS_USERS 或 INTERACT_ACROSS_USERS_FULL 允许。 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2913) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048) 在 android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) 在 android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108) 在 android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808) 在 android.os.Handler.dispatchMessage(Handler.java:106) 在 android.os.Looper.loop(Looper.java:193) 在 android.app.ActivityThread.main(ActivityThread.java:6669) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 引起:java.lang.SecurityException:从用户 0 作为用户 1 调用,未经许可 INTERACT_ACROSS_USERS 或 不允许 INTERACT_ACROSS_USERS_FULL。 在 android.os.Parcel.createException(Parcel.java:1942) 在 android.os.Parcel.readException(Parcel.java:1910) 在 android.os.Parcel.readException(Parcel.java:1860) 在 android.view.accessibility.IAccessibilityManager$Stub$Proxy.addClient(IAccessibilityManager.java:295) 在 android.view.accessibility.AccessibilityManager.tryConnectToServiceLocked(AccessibilityManager.java:1125) 在 android.view.accessibility.AccessibilityManager.(AccessibilityManager.java:358) 在 android.view.accessibility.AccessibilityManager.getInstance(AccessibilityManager.java:336) 在 android.view.View.setFlags(View.java:14008) 在 android.view.View.(View.java:5565) 在 android.view.ViewGroup.(ViewGroup.java:659) 在 android.view.ViewGroup.(ViewGroup.java:655) 在 android.view.ViewGroup.(ViewGroup.java:651) 在 android.view.ViewGroup.(ViewGroup.java:647) 在 android.widget.FrameLayout.(FrameLayout.java:78) 在 com.android.internal.policy.DecorView.(DecorView.java:255) 在 com.android.internal.policy.PhoneWindow.generateDecor(PhoneWindow.java:2310) 在 com.android.internal.policy.PhoneWindow.installDecor(PhoneWindow.java:2662) 在 com.android.internal.policy.PhoneWindow.getDecorView(PhoneWindow.java:2071) 在 androidx.appcompat.app.AppCompatDelegateImpl.createSubDecor(AppCompatDelegateImpl.java:575) 在 androidx.appcompat.app.AppCompatDelegateImpl.ensureSubDecor(AppCompatDelegateImpl.java:518) 在 androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:466) 在 androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:140) 在 com.marhat.albatros.TestActivity.onCreate(TestActivity.kt:9) 在 android.app.Activity.performCreate(Activity.java:7136) 在 android.app.Activity.performCreate(Activity.java:7127) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2893) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048) 在 android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) 在 android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108) 在 android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808) 在 android.os.Handler.dispatchMessage(Handler.java:106) 在 android.os.Looper.loop(Looper.java:193) 在 android.app.ActivityThread.main(ActivityThread.java:6669) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 引起:android.os.RemoteException:远程堆栈跟踪: 在 com.android.server.accessibility.AccessibilityManagerService$SecurityPolicy.resolveCallingUserIdEnforcingPermissionsLocked(AccessibilityManagerService.java:3522) 在 com.android.server.accessibility.AccessibilityManagerService.addClient(AccessibilityManagerService.java:487) 在 android.view.accessibility.IAccessibilityManager$Stub.onTransact(IAccessibilityManager.java:82) 在 android.os.Binder.execTransact(Binder.java:731)
清单:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.marhat.albatros"> <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-feature android:name="android.hardware.usb.host" android:required="true"/> <uses-feature android:name="android.hardware.location.gps"/> <application android:name=".AlbatrossApplication" android:allowBackup="true" android:icon="@mipmap/ic_icon_main" android:label="@string/app_name" android:roundIcon="@mipmap/ic_icon_main_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".TestActivity" android:label="@string/title_activity_test" android:theme="@style/AppTheme.NoActionBar"> <intent-filter> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent-filter> </activity> <activity android:name=".TasksActivity" android:label="@string/title_activity_tasks" android:theme="@style/AppTheme.NoActionBar"/> <meta-data android:name="com.google.android.geo.API_KEY" android:value="xxx"/> <activity android:name=".MainActivity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent-filter> </activity> <service android:name=".UsbService" android:enabled="true"/> <activity android:name=".FPViewActivity"/> <activity android:name=".SplashActivity" android:theme="@style/AppTheme.Launcher"> <intent-filter> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent-filter> </activity> <activity android:name=".TaskViewActivity" android:theme="@style/AppTheme"> <intent-filter android:label="@string/app_name"> <action android:name="android.intent.action.VIEW"/> <category android:name="android.intent.category.DEFAULT"/> <category android:name="android.intent.category.BROWSABLE"/> <data android:mimeType="*/*"/> <data android:scheme="file"/> <data android:scheme="content"/> <data android:pathPattern=".*\\.xfd"/> <data android:host="*"/> </intent-filter> </activity> <activity android:name=".SettingsActivity" android:windowSoftInputMode="stateVisible|adjustResize"/> </application> </manifest>
项目 gradle 文件:
// Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript ext.kotlin_version = '1.3.21' repositories google() jcenter() maven url 'https://maven.fabric.io/public' dependencies classpath 'com.android.tools.build:gradle:3.2.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" classpath 'com.google.gms:google-services:4.2.0' classpath 'io.fabric.tools:gradle:1.25.4' allprojects repositories google() jcenter() maven url 'https://maven.google.com/' maven url "https://jitpack.io" task clean(type: Delete) delete rootProject.buildDir
app/gradle 文件:
apply plugin: 'com.android.application' apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' apply plugin: 'kotlin-kapt' apply plugin: 'io.fabric' android compileSdkVersion 28 defaultConfig applicationId "com.marhat.albatros" minSdkVersion 18 targetSdkVersion 28 multiDexEnabled true versionCode 1 versionName "1.0" testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" // vectorDrawables.useSupportLibrary = true buildTypes release minifyEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' compileOptions sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 dataBinding enabled = true dependencies implementation fileTree(include: ['*.jar', '*.aar'], dir: 'libs') implementation 'com.android.support:multidex:1.0.3' implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version" implementation 'androidx.appcompat:appcompat:1.0.2' implementation 'com.android.support:appcompat-v7:28' implementation 'androidx.constraintlayout:constraintlayout:2.0.0-alpha3' implementation 'com.google.android.material:material:1.0.0' implementation 'androidx.legacy:legacy-support-v4:1.0.0' implementation 'androidx.vectordrawable:vectordrawable:1.0.1' implementation 'com.github.QuadFlask:colorpicker:0.0.13' testImplementation 'junit:junit:4.12' androidTestImplementation 'androidx.test:runner:1.1.1' androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1' implementation 'com.android.support:support-core-utils:28.0.0' implementation 'com.android.support:design:28.0.0' implementation 'com.google.firebase:firebase-core:16.0.7' implementation 'com.crashlytics.sdk.android:crashlytics:2.9.8' implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.0.1' implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.0.1' implementation 'com.google.android.gms:play-services-maps:16.1.0' implementation 'com.google.maps.android:android-maps-utils:0.5' def room_version = "2.1.0-alpha04" implementation "androidx.room:room-runtime:$room_version" kapt "androidx.room:room-compiler:$room_version" testImplementation "androidx.room:room-testing:$room_version" def lifecycle_version = "2.0.0" implementation "androidx.lifecycle:lifecycle-extensions:$lifecycle_version" kapt "androidx.lifecycle:lifecycle-compiler:$lifecycle_version" implementation "androidx.lifecycle:lifecycle-common-java8:$lifecycle_version" implementation "androidx.lifecycle:lifecycle-reactivestreams:$lifecycle_version" testImplementation "androidx.arch.core:core-testing:$lifecycle_version" implementation 'io.reactivex.rxjava2:rxandroid:2.1.0' implementation 'com.google.code.gson:gson:2.8.5' implementation 'com.squareup.retrofit2:retrofit:2.4.0' implementation 'com.squareup.retrofit2:converter-gson:2.3.0' implementation 'com.squareup.retrofit2:converter-scalars:2.3.0' implementation 'com.squareup.okhttp3:logging-interceptor:3.8.0' apply plugin: 'com.google.gms.google-services'
【问题讨论】:
Android permission.INTERACT_ACROSS_USERS_FULL的可能重复 存在重复的依赖项、奇怪的版本号等。很难相信这个build.gradle
曾经正确构建过——即使没有覆盖 .getUserId()
... 要么使用 com.android.support
- 要么使用androidx
;不是两者。
【参考方案1】:
问题在于应用程序类实现了一个名为 getUserId 的方法。 重命名该方法后,一切都重新开始在 Android 9 上运行。
【讨论】:
【参考方案2】:我终于找到了可行的解决方案....魅力 1) -> 将 Parse 复制到您的 Manifest
<!--Support Android Pie 9-->
<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
<uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL" android:protectionLevel="signature" />
2) -> 查找并替换所有getUserId的出现 对于 Mac 用户:使用 Cmd+Shift+R MAC 上的示例
https://i.stack.imgur.com/eLtWR.png
【讨论】:
以上是关于Android 9 (API 28) 活动在启动时崩溃 (setContentView)的主要内容,如果未能解决你的问题,请参考以下文章
Socket.io 无法在 Android 9(API 级别 28)上运行