设备管理概览

设备管理弃用。从 Android 9(API 级别 28)开始,部分管理员政策在由设备管理员调用时将被标记为已弃用。我们建议您立即着手准备应对此项变更。如需了解详情并查看迁移选项,请参阅 设备管理弃用

Android 通过提供 Android Device 管理 API 来支持企业应用。Device Admin API 在系统级别提供设备管理功能。借助这些 API,您可以创建在企业环境中有用的安全感知应用,在企业环境中,IT 专业人员需要对员工设备进行丰富的控制。例如,内置的 Android 电子邮件应用已利用这些 API 改进了 Exchange 支持。通过电子邮件应用,Exchange 管理员可以跨设备强制执行密码政策,包括字母数字密码或数字 PIN 码。管理员还可以远程清除(即恢复出厂默认设置)丢失或被盗手机上的数据。Exchange 用户可以同步自己的电子邮件和日历数据。

本文档面向希望针对搭载 Android 的设备开发企业解决方案的开发者。本文讨论了 Device 管理 API 提供的各种功能,这些功能旨在为搭载 Android 的员工设备提供更强大的安全保护。

注意:如需了解如何为 Android for Work 部署构建工作政策控制器,请参阅构建设备政策控制器

无头设备所有者模式

Android 14(API 级别 34)引入了无头系统用户模式(即 UserManager.isHeadlessSystemUserMode 返回 true 的设备)。在无头系统用户模式下,系统用户是后台用户,并依赖于其他前台用户进行最终用户互动。Android 14 还引入了无头设备所有者关联模式,它会为所有关联用户(设置了设备所有者的系统用户除外)添加资料所有者。

在配置了无头系统用户的设备(系统用户在后台运行)中,只有全局范围内的设备政策(适用于所有用户的政策)才会应用于前台用户。如需了解详情,请参阅 addUserRestriction

Android 设备制造商可以参阅 source.android.com 上发布的指南

Device Administration API 概览

下面的示例展示了可能使用 Device Administration API 的应用类型:

  • 电子邮件客户端。
  • 执行远程清除的安全应用。
  • 设备管理服务和应用。

该如何使用?

您可以使用 Device 管理 API 编写用户在其设备上安装的设备管理应用。设备管理应用会强制执行所需的政策。具体方法如下:

  • 系统管理员会编写一个设备管理应用,用于强制执行远程/本地设备安全政策。这些政策可以硬编码到应用中,或者应用可以从第三方服务器动态提取政策。
  • 该应用已安装在用户的设备上。Android 目前还没有自动配置解决方案。系统管理员将应用分发给用户的一些方式包括:
    • Google Play。
    • 从其他商店启用安装。
    • 通过其他方式分发应用,例如电子邮件或网站。
  • 系统会提示用户启用设备管理应用。发生这种情况的方式和时间取决于应用的实现方式。
  • 用户启用设备管理应用后,便受其政策的约束。遵守这些政策通常会带来诸多好处,例如访问敏感系统和数据。

如果用户未启用设备管理应用,则该应用会保留在设备上,但处于不活动状态。用户将不会受到其政策的约束,相反也不会获得该应用的任何优势(例如,他们可能无法同步数据)。

如果用户未能遵守这些政策(例如,如果用户设置的密码违反了相关准则),则由应用来决定如何处理。不过,这通常会导致用户无法同步数据。

如果设备尝试连接到服务器,而该服务器需要 Device 管理 API 不支持的政策,则系统将不允许连接。Device Admin API 当前不允许部分配置。换句话说,如果设备(例如旧版设备)不支持所有声明的政策,则无法允许设备进行连接。

如果设备包含多个已启用的管理应用,系统会强制执行最严格的政策。无法以特定管理应用作为目标。

如需卸载现有的设备管理应用,用户需要先以管理员身份取消注册该应用。

政策

在企业环境中,员工设备通常必须遵循一组严格的政策,用以约束设备的使用。Device 管理 API 支持表 1 中列出的政策。请注意,Device 管理 API 目前仅支持用于屏幕锁定的密码:

表 1. Device Administration API 支持的政策。

政策 说明
密码已启用 需要设备要求输入 PIN 码或密码。
密码最小长度 设置密码所需的字符数。例如,您可以要求 PIN 码或密码至少包含 6 个字符。
需要输入字母数字密码 要求密码使用字母和数字组合。可以包含符号字符。
需要输入复杂的密码 要求密码必须包含至少一个字母、一个数字和一个特殊符号。此属性是在 Android 3.0 中引入的。
密码中要求的最少字母数 所有管理员或特定管理员的密码中要求的最少字母数。在 Android 3.0 中引入。
密码中要求的最少小写字母数 所有管理员或特定管理员的密码中要求的最少小写字母数量。在 Android 3.0 中引入。
密码中要求的最少非字母字符数 所有管理员或特定管理员的密码中要求的最少非字母字符数。在 Android 3.0 中引入。
密码中要求的最少数字位数 所有管理员或特定管理员的密码中要求的最少数字位数。在 Android 3.0 中引入。
密码中要求的最少符号数 所有管理员或特定管理员的密码中要求的最少符号数。在 Android 3.0 中引入。
密码中要求的最少大写字母数 所有管理员或特定管理员的密码中要求的最少大写字母数。在 Android 3.0 中引入。
密码过期超时时间 密码何时过期,表示为从设备管理员设置过期超时时间起的增量值(以毫秒为单位)。在 Android 3.0 中引入。
密码历史记录限制 此政策可防止用户重复使用最近使用的 n 个唯一密码。 此政策通常与 setPasswordExpirationTimeout() 结合使用,后者会强制用户在经过指定的时间后更新其密码。 在 Android 3.0 中引入。
错误密码尝试次数上限 指定在设备擦除其数据之前,用户可以输入错误密码的次数。Device 管理 API 还允许管理员远程将设备重置为出厂默认设置。这样可以在设备丢失或被盗时保护数据。
最长不活动时间锁定 设置从用户上次轻触屏幕或按下按钮到设备锁定屏幕之间的时长。发生这种情况时,用户需要再次输入其 PIN 码或密码,才能使用其设备并访问数据。该值可介于 1 到 60 分钟之间。
需要存储加密 指定应对存储区域进行加密(如果设备支持)。在 Android 3.0 中引入。
停用摄像头 指定应停用相机。请注意,这不一定是永久停用。可以根据情境、时间等因素动态启用/停用相机。在 Android 4.0 中引入。

其他功能

除了支持上表中列出的政策之外,Device 管理 API 还允许您执行以下操作:

  • 提示用户设置新密码。
  • 立即锁定设备。
  • 清除设备的数据(也就是将设备恢复到出厂默认设置)。

示例应用

本页使用的示例基于 Device 管理 API 示例,该示例包含在 SDK 示例(通过 Android SDK 管理器提供)中,并以 <sdk_root>/ApiDemos/app/src/main/java/com/example/android/apis/app/DeviceAdminSample.java 的形式位于您的系统中。

该示例应用演示了设备管理功能。它为用户提供了一个界面,以便用户启用设备管理应用。启用该应用后,他们可以使用界面中的按钮执行以下操作:

  • 设置密码质量。
  • 指定对用户密码的要求,例如最小长度、必须包含的最少数字字符数等。
  • 设置密码。如果密码不符合指定政策,系统会返回错误。
  • 设置在设备被擦除(即恢复出厂设置)之前,可以尝试密码失败的次数。
  • 设置从现在起密码多久会过期。
  • 设置密码历史记录长度(长度是指历史记录中存储的旧密码数量)。 这可以防止用户重复使用他们之前使用过的最近 n 个密码。
  • 指定应对存储区域进行加密(如果设备支持)。
  • 设置设备锁定前可处于不活动状态的时间上限。
  • 立即锁定设备。
  • 清除设备的数据(即恢复出厂设置)。
  • 停用相机。

图 1. 示例应用的屏幕截图

开发设备管理应用

系统管理员可以使用 Device 管理 API 编写一个应用,用于强制执行远程/本地设备安全政策。本部分总结了创建设备管理应用所涉及的步骤。

创建清单

如需使用 Device 管理 API,应用的清单必须包含以下内容:

以下代码摘录自设备管理示例清单:

<activity android:name=".app.DeviceAdminSample"
            android:label="@string/activity_sample_device_admin">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.SAMPLE_CODE" />
    </intent-filter>
</activity>
<receiver android:name=".app.DeviceAdminSample$DeviceAdminSampleReceiver"
        android:label="@string/sample_device_admin"
        android:description="@string/sample_device_admin_description"
        android:permission="android.permission.BIND_DEVICE_ADMIN">
    <meta-data android:name="android.app.device_admin"
            android:resource="@xml/device_admin_sample" />
    <intent-filter>
        <action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
    </intent-filter>
</receiver>

请注意:

  • 以下属性是指示例应用位于 ApiDemos/res/values/strings.xml 中的字符串资源。如需详细了解资源,请参阅应用资源
    • android:label="@string/activity_sample_device_admin" 是指 activity 的用户可读标签。
    • android:label="@string/sample_device_admin" 是指权限的用户可读标签。
    • android:description="@string/sample_device_admin_description" 是指权限的用户可读说明。说明通常比标签更长且信息更丰富。
  • android:permission="android.permission.BIND_DEVICE_ADMIN" DeviceAdminReceiver 子类必须具有的权限,以确保只有系统可以与接收器交互(不能向任何应用授予此权限)。这样可以防止其他应用滥用您的设备管理应用。
  • android.app.action.DEVICE_ADMIN_ENABLEDDeviceAdminReceiver 子类必须处理才能获准管理设备的主要操作。当用户启用设备管理应用时,系统会将此属性设置为接收者。您的代码通常会在 onEnabled() 中处理此操作。要获得支持,接收器还必须请求 BIND_DEVICE_ADMIN 权限,以防止其他应用滥用该权限。
  • 当用户启用设备管理应用后,接收者将有权执行操作以响应特定系统事件的广播。当发生相应的事件时,应用便可以施加某项政策。例如,如果用户尝试设置不符合政策要求的新密码,应用可以提示用户选择符合要求的其他密码。
  • 请避免在发布应用后更改接收器名称。如果清单中的名称发生变化,系统会在用户更新应用时停用设备管理功能。如需了解详情,请参阅 <receiver>
  • android:resource="@xml/device_admin_sample" 可声明元数据中使用的安全政策。元数据提供了特定于设备管理员的其他信息,由 DeviceAdminInfo 类进行解析。以下是 device_admin_sample.xml 的内容:
<device-admin xmlns:android="http://schemas.android.com/apk/res/android">
  <uses-policies>
    <limit-password />
    <watch-login />
    <reset-password />
    <force-lock />
    <wipe-data />
    <expire-password />
    <encrypted-storage />
    <disable-camera />
  </uses-policies>
</device-admin>

在设计设备管理应用时,您无需包含所有政策,只需添加与您的应用相关的政策。

如需详细了解清单文件,请参阅 Android 开发者指南

实现代码

Device Administration API 包含以下类:

DeviceAdminReceiver
用于实现设备管理组件的基类。此类为解释系统发送的原始 intent 操作提供了便利。您的设备管理应用必须包含一个 DeviceAdminReceiver 子类。
DevicePolicyManager
用于管理设备上强制执行的政策的类。此类的大多数客户端必须已发布用户当前已启用的 DeviceAdminReceiverDevicePolicyManager 可管理一个或多个 DeviceAdminReceiver 实例的政策
DeviceAdminInfo
此类用于指定设备管理员组件的元数据。

这些类为功能完善的设备管理应用奠定了基础。本部分的其余部分介绍了如何使用 DeviceAdminReceiverDevicePolicyManager API 编写设备管理应用。

对 DeviceAdminReceiver 进行子类化

如需创建设备管理应用,您必须创建 DeviceAdminReceiver 的子类。DeviceAdminReceiver 类由一系列回调组成,这些回调发生特定事件时触发。

在其 DeviceAdminReceiver 子类中,示例应用仅显示一条 Toast 通知来响应特定事件。例如:

Kotlin

class DeviceAdminSample : DeviceAdminReceiver() {

    private fun showToast(context: Context, msg: String) {
        context.getString(R.string.admin_receiver_status, msg).let { status ->
            Toast.makeText(context, status, Toast.LENGTH_SHORT).show()
        }
    }

    override fun onEnabled(context: Context, intent: Intent) =
            showToast(context, context.getString(R.string.admin_receiver_status_enabled))

    override fun onDisableRequested(context: Context, intent: Intent): CharSequence =
            context.getString(R.string.admin_receiver_status_disable_warning)

    override fun onDisabled(context: Context, intent: Intent) =
            showToast(context, context.getString(R.string.admin_receiver_status_disabled))

    override fun onPasswordChanged(context: Context, intent: Intent, userHandle: UserHandle) =
            showToast(context, context.getString(R.string.admin_receiver_status_pw_changed))
...
}

Java

public class DeviceAdminSample extends DeviceAdminReceiver {

    void showToast(Context context, String msg) {
        String status = context.getString(R.string.admin_receiver_status, msg);
        Toast.makeText(context, status, Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onEnabled(Context context, Intent intent) {
        showToast(context, context.getString(R.string.admin_receiver_status_enabled));
    }

    @Override
    public CharSequence onDisableRequested(Context context, Intent intent) {
        return context.getString(R.string.admin_receiver_status_disable_warning);
    }

    @Override
    public void onDisabled(Context context, Intent intent) {
        showToast(context, context.getString(R.string.admin_receiver_status_disabled));
    }

    @Override
    public void onPasswordChanged(Context context, Intent intent, UserHandle userHandle) {
        showToast(context, context.getString(R.string.admin_receiver_status_pw_changed));
    }
...
}

启用应用

设备管理应用必须处理的一个重大事件是用户启用应用。用户必须明确启用应用才能强制执行政策。如果用户选择不启用应用,该应用仍会保留在设备上,但系统不会强制执行其政策,而且用户将无法获得应用的任何优势。

当用户执行触发 ACTION_ADD_DEVICE_ADMIN intent 的操作时,启用应用的流程即会开始。在示例应用中,当用户点击 Enable Admin 复选框时,就会发生这种情况。

当用户点击 Enable Admin 复选框时,显示内容会更改为提示用户激活设备管理应用,如图 2 所示。

图 2. 示例应用:激活应用

下面显示了用户点击 Enable Admin 复选框时执行的代码。这样做的效果是触发 onPreferenceChange() 回调。当用户已更改此 Preference 的值以及要设置和/或保留该值时,系统将调用此回调。如果用户正在启用应用,则显示屏会更改为提示用户激活设备管理应用,如图 2 所示。否则,系统会停用设备管理应用。

Kotlin

override fun onPreferenceChange(preference: Preference, newValue: Any): Boolean {
    if (super.onPreferenceChange(preference, newValue)) return true
    val value = newValue as Boolean
    if (preference == enableCheckbox) {
        if (value != adminActive) {
            if (value) {
                // Launch the activity to have the user enable our admin.
                val intent = Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN).apply {
                    putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, deviceAdminSample)
                    putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,
                            activity.getString(R.string.add_admin_extra_app_text))
                }
                startActivityForResult(intent, REQUEST_CODE_ENABLE_ADMIN)
                // return false - don't update checkbox until we're really active
                return false
            } else {
                dpm.removeActiveAdmin(deviceAdminSample)
                enableDeviceCapabilitiesArea(false)
                adminActive = false
            }
        }
    } else if (preference == disableCameraCheckbox) {
        dpm.setCameraDisabled(deviceAdminSample, value)
    }
    return true
}

Java

@Override
public boolean onPreferenceChange(Preference preference, Object newValue) {
    if (super.onPreferenceChange(preference, newValue)) {
        return true;
    }
    boolean value = (Boolean) newValue;
    if (preference == enableCheckbox) {
        if (value != adminActive) {
            if (value) {
                // Launch the activity to have the user enable our admin.
                Intent intent = new Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
                intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, deviceAdminSample);
                intent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,
                        activity.getString(R.string.add_admin_extra_app_text));
                startActivityForResult(intent, REQUEST_CODE_ENABLE_ADMIN);
                // return false - don't update checkbox until we're really active
                return false;
            } else {
                dpm.removeActiveAdmin(deviceAdminSample);
                enableDeviceCapabilitiesArea(false);
                adminActive = false;
            }
        }
    } else if (preference == disableCameraCheckbox) {
        dpm.setCameraDisabled(deviceAdminSample, value);
    }
    return true;
}

intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, mDeviceAdminSample) 行声明 mDeviceAdminSample(它是一个 DeviceAdminReceiver 组件)是目标政策。此行会调用图 2 所示的界面,该界面会引导用户将设备管理员添加到系统中(或允许用户拒绝添加)。

如果应用需要执行的操作取决于启用的设备管理应用,它会确认该应用处于活跃状态。为此,它使用 DevicePolicyManager 方法 isAdminActive()。请注意,DevicePolicyManager 方法 isAdminActive()DeviceAdminReceiver 组件作为其参数:

Kotlin

private lateinit var dpm: DevicePolicyManager
...
private fun isActiveAdmin(): Boolean = dpm.isAdminActive(deviceAdminSample)

Java

DevicePolicyManager dpm;
...
private boolean isActiveAdmin() {
    return dpm.isAdminActive(deviceAdminSample);
}

管理政策

DevicePolicyManager 是一个公共类,用于管理在设备上强制执行的政策。DevicePolicyManager 可管理一个或多个 DeviceAdminReceiver 实例的政策。

您会获得 DevicePolicyManager 的句柄,如下所示:

Kotlin

dpm = getSystemService(Context.DEVICE_POLICY_SERVICE) as DevicePolicyManager

Java

DevicePolicyManager dpm =
    (DevicePolicyManager)getSystemService(Context.DEVICE_POLICY_SERVICE);

本部分介绍如何使用 DevicePolicyManager 执行管理任务:

设置密码政策

DevicePolicyManager 包含用于设置和强制执行设备密码政策的 API。在 Device Admin API 中,密码仅适用于屏幕锁定。本部分介绍了常见的密码相关任务。

为设备设置密码

此代码显示了提示用户设置密码的界面:

Kotlin

Intent(DevicePolicyManager.ACTION_SET_NEW_PASSWORD).also { intent ->
    startActivity(intent)
}

Java

Intent intent = new Intent(DevicePolicyManager.ACTION_SET_NEW_PASSWORD);
startActivity(intent);
设置密码质量

密码质量可以是以下 DevicePolicyManager 常量之一:

PASSWORD_QUALITY_ALPHABETIC
用户必须输入至少包含字母(或其他符号)字符的密码。
PASSWORD_QUALITY_ALPHANUMERIC
用户必须输入至少同时包含数字字母(或其他符号)字符的密码。
PASSWORD_QUALITY_NUMERIC
用户必须输入至少包含数字字符的密码。
PASSWORD_QUALITY_COMPLEX
用户必须输入至少包含一个字母、一个数字和一个特殊符号的密码。
PASSWORD_QUALITY_SOMETHING
该政策要求提供某种密码,但并不关心具体密码。
PASSWORD_QUALITY_UNSPECIFIED
此政策对密码没有要求。

下面的示例展示了如何设置密码政策,以要求提供字母数字密码:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
...
dpm.setPasswordQuality(deviceAdminSample, DevicePolicyManager.PASSWORD_QUALITY_ALPHANUMERIC)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
...
dpm.setPasswordQuality(deviceAdminSample, DevicePolicyManager.PASSWORD_QUALITY_ALPHANUMERIC);
设置密码内容要求

从 Android 3.0 开始,DevicePolicyManager 类包含一些方法,可让您对密码内容进行微调。例如,您可以设置一项政策,要求密码必须至少包含 n 个大写字母。以下是微调密码内容的方法:

例如,以下代码段指明密码必须包含至少 2 个大写字母:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val pwMinUppercase = 2
...
dpm.setPasswordMinimumUpperCase(deviceAdminSample, pwMinUppercase)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
int pwMinUppercase = 2;
...
dpm.setPasswordMinimumUpperCase(deviceAdminSample, pwMinUppercase);
设置密码最小长度

您可以指定密码必须至少为指定的最小长度。例如:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val pwLength: Int = ...
...
dpm.setPasswordMinimumLength(deviceAdminSample, pwLength)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
int pwLength;
...
dpm.setPasswordMinimumLength(deviceAdminSample, pwLength);
设置错误密码尝试次数上限

您可以设置在擦除设备(即恢复出厂设置)之前,允许尝试密码失败次数上限。例如:

Kotlin

val dPM:DevicePolicyManager
private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val maxFailedPw: Int = ...
...
dpm.setMaximumFailedPasswordsForWipe(deviceAdminSample, maxFailedPw)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
int maxFailedPw;
 ...
dpm.setMaximumFailedPasswordsForWipe(deviceAdminSample, maxFailedPw);
设置密码过期超时时间

从 Android 3.0 开始,您可以使用 setPasswordExpirationTimeout() 方法设置密码的过期时间,表示为从设备管理员设置过期超时时间起的增量值(以毫秒为单位)。例如:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val pwExpiration: Long = ...
...
dpm.setPasswordExpirationTimeout(deviceAdminSample, pwExpiration)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
long pwExpiration;
...
dpm.setPasswordExpirationTimeout(deviceAdminSample, pwExpiration);
根据历史记录限制密码

从 Android 3.0 开始,您可以使用 setPasswordHistoryLength() 方法限制用户重复使用旧密码的能力。此方法采用 length 参数,该参数指定存储的旧密码数量。启用此政策后,用户将无法输入与最近 n 个密码匹配的新密码。这可以防止用户反复使用相同的密码。此政策通常与 setPasswordExpirationTimeout() 结合使用,后者会强制用户在经过指定的时间后更新其密码。

例如,此代码段禁止用户重复使用最近使用过的 5 个密码中的任意一个:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val pwHistoryLength = 5
...
dpm.setPasswordHistoryLength(deviceAdminSample, pwHistoryLength)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
int pwHistoryLength = 5;
...
dpm.setPasswordHistoryLength(deviceAdminSample, pwHistoryLength);

设置设备锁定

您可以设置在设备锁定之前用户可能处于非活动状态的时间上限。例如:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
private val timeMs: Long = 1000L * timeout.text.toString().toLong()
...
dpm.setMaximumTimeToLock(deviceAdminSample, timeMs)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
...
long timeMs = 1000L*Long.parseLong(timeout.getText().toString());
dpm.setMaximumTimeToLock(deviceAdminSample, timeMs);

您还能够以编程方式告知设备立即锁定:

Kotlin

private lateinit var dpm: DevicePolicyManager
dpm.lockNow()

Java

DevicePolicyManager dpm;
dpm.lockNow();

执行数据清除

您可以使用 DevicePolicyManager 方法 wipeData() 将设备恢复出厂设置。如果设备丢失或被盗,此设置非常有用。通常情况下,擦除设备的决定是满足特定条件的结果。例如,您可以使用 setMaximumFailedPasswordsForWipe() 声明在密码尝试失败特定次数后应擦除设备。

清除数据的方法如下所示:

Kotlin

private lateinit var dpm: DevicePolicyManager
dpm.wipeData(0)

Java

DevicePolicyManager dpm;
dpm.wipeData(0);

wipeData() 方法将其他选项的位掩码作为其参数。目前,该值必须为 0。

停用相机

从 Android 4.0 开始,您可以停用相机。请注意,这不一定是永久停用。可以根据具体情况、时间等因素动态启用/停用相机。

您可以使用 setCameraDisabled() 方法控制是否停用相机。例如,以下代码段根据复选框设置将相机设置为启用或停用:

Kotlin

private lateinit var disableCameraCheckbox: CheckBoxPreference
private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
...
dpm.setCameraDisabled(deviceAdminSample, mDisableCameraCheckbox.isChecked)

Java

private CheckBoxPreference disableCameraCheckbox;
DevicePolicyManager dpm;
ComponentName deviceAdminSample;
...
dpm.setCameraDisabled(deviceAdminSample, mDisableCameraCheckbox.isChecked());

存储加密

从 Android 3.0 开始,您可以使用 setStorageEncryption() 方法设置要求对存储区域进行加密的政策(如果支持)。

例如:

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var deviceAdminSample: ComponentName
...
dpm.setStorageEncryption(deviceAdminSample, true)

Java

DevicePolicyManager dpm;
ComponentName deviceAdminSample;
...
dpm.setStorageEncryption(deviceAdminSample, true);

如需查看有关如何启用存储加密的完整示例,请参阅 Device 管理 API 示例。

更多代码示例

Android AppRestrictionEnforcerDeviceOwner 示例进一步说明了如何使用本页介绍的 API。