设备管理弃用。从 Android 9(API 级别 28)开始,当某项设备管理调用某些管理政策时,系统会将它们标记为“已弃用”。我们建议您立即着手准备应对此项变更。如需了解详情并查看迁移选项,请参阅 设备管理员弃用。
Android 通过提供 Android Device Administration API 来支持企业应用。该 Device Administration API 在系统级别提供设备管理功能。借助这些 API,您能够创建在企业环境中非常实用的注重安全性的应用;在企业环境中,IT 专业人员需要有力地对员工设备进行控制。例如,内置的 Android 电子邮件应用利用这些 API 改善了对 Exchange 的支持。通过电子邮件应用,Exchange 管理员可以跨设备强制执行密码政策(包括字母数字密码或数字 PIN 码)。管理员还可以远程清除(即恢复出厂默认设置)丢失或被盗手机上的数据。Exchange 用户可以同步他们的电子邮件和日历数据。
本文档适用于想要针对搭载 Android 的设备开发企业解决方案的开发者。它介绍了 Device Administration 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 Administration API 来编写用户在其设备上安装的设备管理应用。该设备管理应用会强制执行所需的政策。具体方法如下:
- 系统管理员会编写一个能够强制执行远程/本地设备安全政策的设备管理应用。这些政策可以硬编码到应用中,或者应用可以从第三方服务器动态获取这些政策。
- 该应用已安装在用户的设备上。Android 目前没有自动配置解决方案。系统管理员向用户分发应用的一些方式如下:
- Google Play。
- 从其他商店启用安装。
- 通过其他方式分发应用,例如电子邮件或网站。
- 系统会提示用户启用设备管理应用。此类情况发生的方式和时间取决于应用的实现方式。
- 用户启用该设备管理应用后,便要受到其政策的约束。遵守这些政策通常可带来诸多优势,例如访问敏感系统和数据。
如果用户未启用设备管理应用,则该应用会保留在设备上,但处于不活动状态。用户将不会受到其政策的约束,相反也不会获得该应用的任何优势(例如,他们可能无法同步数据)。
如果用户未能遵守这些政策(例如,如果用户设置的密码违反了准则),则由应用来决定如何进行处理。不过,这通常会导致用户无法同步数据。
如果设备尝试连接到某个服务器,而该服务器需要 Device Administration API 不支持的政策,则系统将不允许建立此类连接。Device Administration API 目前不支持部分配置。换言之,如果设备(例如旧版设备)不支持所有声明的政策,则系统便无法允许设备进行连接。
如果设备包含多个已启用的管理应用,则系统会强制执行最严格的政策。无法仅执行某个特定管理应用的政策。
如需卸载现有的设备管理应用,用户需要先以管理员的身份取消注册该应用。
政策
在企业环境中,员工设备通常必须遵守一系列规范设备使用的严格政策。Device Administration 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 Administration API 还允许管理员将设备远程重置为出厂默认设置。这可以在设备丢失或被盗的情况下保护用户数据。 |
最长不活动时间锁定 | 设置从用户上次触摸屏幕或按下按钮到设备锁定屏幕之间经过的时长。发生这种情况时,用户需要再次输入其 PIN 码或密码,然后才能使用设备和访问数据。该值可介于 1 到 60 分钟之间。 |
需要存储加密 | 指定应对存储区域进行加密(如果设备支持)。在 Android 3.0 中引入。 |
停用摄像头 | 指定应停用相机。请注意,这不一定是永久停用。可以根据具体情况、时间等因素动态启用/停用相机。在 Android 4.0 中引入。 |
其他功能
除了支持上表中列出的政策外,Device Administration API 还支持您执行以下操作:
- 提示用户设置新密码。
- 立即锁定设备。
- 清除设备的数据(也就是将设备恢复到出厂默认设置)。
示例应用
本页中使用的示例基于 Device Administration API 示例,该示例包含在 SDK 示例(可通过 Android SDK 管理器获取)中,并且位于您的系统上:<sdk_root>/ApiDemos/app/src/main/java/com/example/android/apis/app/DeviceAdminSample.java
。
该示例应用演示了设备管理功能。它为用户提供了一个界面,让用户可以启用设备管理应用。用户启用该应用后,便可以使用界面上的按钮执行以下操作:
- 设置密码质量。
- 指定针对用户密码的要求,例如最小长度、必须包含的最少数字字符数等。
- 设置密码。如果密码不符合指定政策,则系统会返回错误。
- 设置在设备清除数据(即恢复出厂设置)之前,可以发生的错误密码尝试次数。
- 设置从现在起密码多久会过期。
- 设置密码历史记录长度(长度表示历史记录中存储的旧密码数)。这样可以防止用户重复使用最近使用过的 n 个密码之一。
- 指定应对存储区域进行加密(如果设备支持)。
- 设置设备锁定前可处于不活动状态的时间上限。
- 立即锁定设备。
- 清除设备的数据(即恢复出厂设置)。
- 停用相机。
开发设备管理应用
系统管理员可以使用 Device Administration API 来编写一个能够强制执行远程/本地设备安全政策的应用。本部分总结了创建设备管理应用所涉及的步骤。
创建清单
如需使用 Device Administration API,应用的清单必须包含以下内容及功能:
- 包含以下内容的
DeviceAdminReceiver
的子类:BIND_DEVICE_ADMIN
权限。- 能够响应
ACTION_DEVICE_ADMIN_ENABLED
intent,在清单中表示为 intent 过滤器。
- 元数据中使用的安全政策声明。
以下代码摘录自设备管理示例清单:
<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_ENABLED
是DeviceAdminReceiver
子类必须处理才能获准管理设备的主要操作。当用户启用设备管理应用后,系统会针对接收器设置此操作。您的代码通常会在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
- 用于管理设备上强制执行的政策的类。此类的大多数客户端必须已经发布了一个用户当前已启用的
DeviceAdminReceiver
。DevicePolicyManager
可管理一个或多个DeviceAdminReceiver
实例的政策 DeviceAdminInfo
- 此类用于指定设备管理员组件的元数据。
这些类为功能完善的设备管理应用奠定了基础。本部分的其余部分介绍了如何使用 DeviceAdminReceiver
和 DevicePolicyManager
API 编写设备管理应用。
对 DeviceAdminReceiver 进行子类化
如需创建设备管理应用,您必须对 DeviceAdminReceiver
进行子类化。DeviceAdminReceiver
类包含一系列发生特定事件时触发的回调。
在其 DeviceAdminReceiver
子类中,示例应用只会显示 Toast
通知以响应特定事件。例如:
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)) ... }
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 所示。
下面显示了用户点击 Enable Admin 复选框时执行的代码。这具有触发 onPreferenceChange()
回调的作用。当用户已更改此 Preference
的值以及要设置和/或保留该值时,系统将调用此回调。如果用户正在启用该应用,则显示屏会改为提示用户激活设备管理应用,如图 2 所示。否则,系统会停用设备管理应用。
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 }
@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
组件作为其参数:
private lateinit var dpm: DevicePolicyManager ... private fun isActiveAdmin(): Boolean = dpm.isAdminActive(deviceAdminSample)
DevicePolicyManager dpm; ... private boolean isActiveAdmin() { return dpm.isAdminActive(deviceAdminSample); }
管理政策
DevicePolicyManager
是用于管理在设备上强制执行的政策的公共类。DevicePolicyManager
可管理一个或多个 DeviceAdminReceiver
实例的政策。
您会获得 DevicePolicyManager
的句柄,如下所示:
dpm = getSystemService(Context.DEVICE_POLICY_SERVICE) as DevicePolicyManager
DevicePolicyManager dpm = (DevicePolicyManager)getSystemService(Context.DEVICE_POLICY_SERVICE);
本部分介绍了如何使用 DevicePolicyManager
执行管理任务:
设置密码政策
DevicePolicyManager
包含用于设置和强制执行设备密码政策的 API。在 Device Administration API 中,该密码仅适用于屏幕锁定。本部分介绍了常见的密码相关任务。
为设备设置密码
此代码显示了提示用户设置密码的界面:
Intent(DevicePolicyManager.ACTION_SET_NEW_PASSWORD).also { intent -> startActivity(intent) }
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
- 该政策对密码没有要求。
下面的示例展示了如何设置密码政策,以要求提供字母数字密码:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName ... dpm.setPasswordQuality(deviceAdminSample, DevicePolicyManager.PASSWORD_QUALITY_ALPHANUMERIC)
DevicePolicyManager dpm; ComponentName deviceAdminSample; ... dpm.setPasswordQuality(deviceAdminSample, DevicePolicyManager.PASSWORD_QUALITY_ALPHANUMERIC);
设置密码内容要求
从 Android 3.0 开始,DevicePolicyManager
类包括可让您微调密码内容的方法。例如,您可以设置一项政策,声明密码必须包含至少 n 个大写字母。下面显示了对密码内容进行微调的方法:
setPasswordMinimumLetters()
setPasswordMinimumLowerCase()
setPasswordMinimumUpperCase()
setPasswordMinimumNonLetter()
setPasswordMinimumNumeric()
setPasswordMinimumSymbols()
例如,以下代码段指明密码必须包含至少 2 个大写字母:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val pwMinUppercase = 2 ... dpm.setPasswordMinimumUpperCase(deviceAdminSample, pwMinUppercase)
DevicePolicyManager dpm; ComponentName deviceAdminSample; int pwMinUppercase = 2; ... dpm.setPasswordMinimumUpperCase(deviceAdminSample, pwMinUppercase);
设置密码最小长度
您可以指定密码必须至少为指定的最小长度。例如:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val pwLength: Int = ... ... dpm.setPasswordMinimumLength(deviceAdminSample, pwLength)
DevicePolicyManager dpm; ComponentName deviceAdminSample; int pwLength; ... dpm.setPasswordMinimumLength(deviceAdminSample, pwLength);
设置错误密码尝试次数上限
您可以设置在设备清除数据(即恢复出厂设置)之前,允许的错误密码尝试次数上限。例如:
val dPM:DevicePolicyManager private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val maxFailedPw: Int = ... ... dpm.setMaximumFailedPasswordsForWipe(deviceAdminSample, maxFailedPw)
DevicePolicyManager dpm; ComponentName deviceAdminSample; int maxFailedPw; ... dpm.setMaximumFailedPasswordsForWipe(deviceAdminSample, maxFailedPw);
设置密码过期超时时间
从 Android 3.0 开始,您可以使用 setPasswordExpirationTimeout()
方法设置密码何时过期,表示为从设备管理员设置过期超时时间起的增量值(以毫秒为单位)。例如:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val pwExpiration: Long = ... ... dpm.setPasswordExpirationTimeout(deviceAdminSample, pwExpiration)
DevicePolicyManager dpm; ComponentName deviceAdminSample; long pwExpiration; ... dpm.setPasswordExpirationTimeout(deviceAdminSample, pwExpiration);
根据历史记录限制密码
从 Android 3.0 开始,您可以使用 setPasswordHistoryLength()
方法限制用户重复使用旧密码。此方法采用长度参数,该参数可指定存储的旧密码数量。启用此政策后,用户将无法输入与最近使用的 n 个密码匹配的新密码。这可以防止用户反复使用同一个密码。此政策通常与 setPasswordExpirationTimeout()
结合使用,后者会强制用户在经过指定的时间后更新他其密码。
例如,此代码段禁止用户重复使用最近使用过的 5 个密码中的任意一个:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val pwHistoryLength = 5 ... dpm.setPasswordHistoryLength(deviceAdminSample, pwHistoryLength)
DevicePolicyManager dpm; ComponentName deviceAdminSample; int pwHistoryLength = 5; ... dpm.setPasswordHistoryLength(deviceAdminSample, pwHistoryLength);
设置设备锁定
您可以设置在设备锁定之前,用户可处于不活动状态的时间上限。例如:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName private val timeMs: Long = 1000L * timeout.text.toString().toLong() ... dpm.setMaximumTimeToLock(deviceAdminSample, timeMs)
DevicePolicyManager dpm; ComponentName deviceAdminSample; ... long timeMs = 1000L*Long.parseLong(timeout.getText().toString()); dpm.setMaximumTimeToLock(deviceAdminSample, timeMs);
您还能够以编程方式告知设备立即锁定:
private lateinit var dpm: DevicePolicyManager dpm.lockNow()
DevicePolicyManager dpm; dpm.lockNow();
执行数据清除
您可以使用 DevicePolicyManager
方法 wipeData()
将设备重置为出厂设置。这在设备丢失或被盗时非常有用。清除设备数据的决定通常多个条件促成的。例如,您可以使用 setMaximumFailedPasswordsForWipe()
声明在特定错误密码尝试次数后清除设备数据。
清除数据的方法如下所示:
private lateinit var dpm: DevicePolicyManager dpm.wipeData(0)
DevicePolicyManager dpm; dpm.wipeData(0);
wipeData()
方法将其他选项的位掩码作为其参数。目前,该值必须为 0。
停用相机
从 Android 4.0 开始,您可以停用相机。请注意,这不一定是永久停用。可以根据具体情况、时间等因素动态启用/停用相机。
您可以使用 setCameraDisabled()
方法控制相机是否已停用。例如,以下代码段根据复选框设置将相机设置为启用或停用:
private lateinit var disableCameraCheckbox: CheckBoxPreference private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName ... dpm.setCameraDisabled(deviceAdminSample, mDisableCameraCheckbox.isChecked)
private CheckBoxPreference disableCameraCheckbox; DevicePolicyManager dpm; ComponentName deviceAdminSample; ... dpm.setCameraDisabled(deviceAdminSample, mDisableCameraCheckbox.isChecked());
存储加密
从 Android 3.0 开始,您可以使用 setStorageEncryption()
方法设置要求加密存储区域的政策(如果支持)。
例如:
private lateinit var dpm: DevicePolicyManager private lateinit var deviceAdminSample: ComponentName ... dpm.setStorageEncryption(deviceAdminSample, true)
DevicePolicyManager dpm; ComponentName deviceAdminSample; ... dpm.setStorageEncryption(deviceAdminSample, true);
有关如何启用存储加密的完整示例,请参阅 Device Administration API 示例。
更多代码示例
Android AppRestrictionEnforcer 和 DeviceOwner 示例进一步演示了如何使用本页介绍的 API。