Android Lollipop 成为设备管理员不起作用

Posted

技术标签:

【中文标题】Android Lollipop 成为设备管理员不起作用【英文标题】:Android Lollipop becoming device admininistrator doesn't work 【发布时间】:2014-12-29 01:24:12 【问题描述】:

我正在关注this guide,了解如何让我的应用请求成为设备管理员。 这适用于任何手机的任何 4.x android 版本,但不适用于 Lollipop(我在 Nexus 5 和 Nexus 7 上尝试过)。

Logcat 出现以下错误:

 *11-02 07:37:09.649: W/DeviceAdminAdd(10020): Cannot start ADD_DEVICE_ADMIN as a new task*  

有没有其他人在使用 Lollipop 时遇到过这个问题?可能是什么原因? 我已经阅读了指南的所有部分,并确保我的 XML、清单、接收器等都是应有的(同样,它确实适用于我尝试过的任何其他版本的操作系统或手机)。

如果这很重要,出于兼容性原因,我将使用 target API=17 和 min API=14 编译我的应用程序。


添加清单文件:

<?xml version='1.0' encoding='utf-8'?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.my.package"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="14"
        android:targetSdkVersion="17" />

     <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.WRITE_SYNC_SETTINGS" />
    <uses-permission android:name="com.mycompany.permission.NFProvider_WRITE" />
    <uses-permission android:name="com.mycompany.permission.NFProvider_READ" />
    <uses-permission android:name="android.permission.READ_LOGS" />

    <application
        android:name="com.mycompany.myapp.Application"
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >

        <receiver
            android:name="com.mycompany.myapp.NFAdminReceiver"
            android:permission="android.permission.BIND_DEVICE_ADMIN">
            <meta-data
                android:name="android.app.device_admin"
                android:resource="@xml/admin"/>
            <intent-filter>
                <action android:name="android.app.action.DEVICE_ADMIN_ENABLED"/>
            </intent-filter>
        </receiver>

        <activity
            android:name="com.mycompany.myapp.ConnectMainActivity"
            android:label="@string/title_activity_connect_main"
            android:process="com.mycompany.ui"
            android:launchMode="singleInstance"
            android:screenOrientation="portrait" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>


        <service
            android:name="com.mycompany.myapp.MainService"
            android:enabled="true" />

        <meta-data android:name="applicationVersion" android:value="1.2.0.213" />


    </application>
</manifest>

创建 Intent 的代码:

ComponentName mComponentName = new ComponentName(activity, NFAdminReceiver.class); 
Intent intent = new Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);     
intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, mComponentName);
intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION, ADMIN_REQUEST_TITLE);
activity.startActivityForResult(intent, ADMIN_INTENT); 

变量activity是ConnectMainActivity的一个实例

【问题讨论】:

如果你知道的话,这里有 device_owner.xml 的概念 -->developer.android.com/about/versions/android-5.0.html 谢谢,d.i.v.a,但从我读到的设备所有者是设备管理员之外的东西,而且只能有一个,我认为我的应用不需要它。如果我理解正确的话,device-admin 应该仍然可用并且可以像以前一样工作,并且 device-owner 是比管理员更强大的东西。 好的,如果你只想启用设备管理员,那么 android 5.0 工作正常,发布你的清单 【参考方案1】:

似乎是 singleInstance launchMode 选项导致了问题,我仍然很想知道为什么它会导致 Lollipop 而不是其他版本的问题。

目前,将 launchMode 设置为 singleTask 可以解决问题,并且似乎仍然符合应用流程的设计。

【讨论】:

【参考方案2】:

此错误消息的根本原因在于DeviceAdminAdd.java。有this check:

if ((getIntent().getFlags()&Intent.FLAG_ACTIVITY_NEW_TASK) != 0) 
         Log.w(TAG, "Cannot start ADD_DEVICE_ADMIN as a new task");
         finish();
         return;

4.0.1 中已经存在此检查:API 级别 14 !

此检查的 Intent 主题是触发操作的 Intent:DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN。

来自the docs:

“singleInstance”活动不允许其他活动成为其任务的一部分。

它没有解释 API 21 和 API

【讨论】:

显然错误来自 android 库(特别是 DeviceAdmin 代码),我看不出这如何解释任何事情,尤其是它如何解释相同代码在 Android 4 上工作但不是5. 这是意图创建代码: ComponentName mComponentName = new ComponentName(activity, NFAdminReceiver.class);意图意图 = 新意图(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN); intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN,mComponentName); intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,ADMIN_REQUEST_TITLE); activity.startActivityForResult(intent, ADMIN_INTENT);没有任何改变,相同的代码在 Android 4 上有效,在 5 上无效(在单实例模式下),并且在这两个应用程序上都不是管理员。 上一条评论中的变量activity是ConnectMainActivity的一个实例。

以上是关于Android Lollipop 成为设备管理员不起作用的主要内容,如果未能解决你的问题,请参考以下文章

GPS 可在除 Lollipop 之外的所有设备上运行

在 Android 5.0 Lollipop 上不支持 calendarViewShown

在Pre-Lollipop设备中使用.xml向量时,应用程序崩溃Xamarin.Android

android tv lollipop 支持 WebRTC 吗?

用于 Pre-Lollipop 设备的具有弯曲背景的 Android Ripple 按钮

Android Studio 项目适用于 Lollipop,但不适用于 Kitkat