安卓手机APP开发_____通过设备管理政策增强安全性

2024-06-05 21:20

本文主要是介绍安卓手机APP开发_____通过设备管理政策增强安全性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安卓手机APP开发_____通过设备管理政策增强安全性

目录

概述

定义并声明政策

创建设备管理接收器

激活设备管理器

实现设备政策控制器


概述

设备管理弃用。部分管理员政策在由设备管理员调用时被标记为已弃用。
如需了解详情并查看迁移选项,请参阅 设备管理弃用。

从 Android 2.2(API 级别 8)开始,Android 平台通过设备管理 API
提供系统级设备管理功能。

在本课中,您将学习如何创建一个安全感知型应用,通过强制执行设备
管理政策来管理对其内容的访问权限。具体来说,可以对应用进行配置,
以确保在向用户显示受限内容之前设置足够强度的屏幕锁定密码。

定义并声明政策

首先,您需要定义要在职能层面支持的政策类型。政策可能涵盖屏幕锁定
密码强度、失效超时和加密等。

您必须在 res/xml/device_admin.xml 文件中声明所选政策集,该政策集
将由应用强制执行。Android 清单还应引用声明的政策集。

每项声明的政策都对应于 DevicePolicyManager 中一定数量的相关设备
政策方法(定义密码最小长度和最小大写字符数量是两个示例)。如果
应用尝试调用的方法未在 XML 中声明相应政策,则会导致在运行时出现
SecurityException。如果应用打算管理其他类型的政策,则还可以使用
force-lock 等其他权限。稍后您将看到,在设备管理员激活过程中,系
统会在系统屏幕上向用户显示已声明的政策列表。

以下代码段在 res/xml/device_admin.xml 中声明了限制密码政策:

<device-admin xmlns:android="http://schemas.android.com/apk/res/android">
    <uses-policies>
        <limit-password />
    </uses-policies>
</device-admin>

Android 清单中引用的政策声明 XML:

<receiver android:name=".Policy$PolicyAdmin"
    android:permission="android.permission.BIND_DEVICE_ADMIN">
    <meta-data android:name="android.app.device_admin"
        android:resource="@xml/device_admin" />
    <intent-filter>
        <action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
    </intent-filter>
</receiver>

创建设备管理接收器

创建设备管理功能广播接收器,用于接收与您声明支持的政策相关的事件的通知。
应用可以选择性地替换回调方法。

在示例应用 Device Admin 中,当用户停用设备管理员时,已配置的政策会从共
享偏好设置中清除。您应考虑实现与您的用例相关的业务逻辑。例如,应用可能会
采取一些操作来降低安全风险,方法是实现删除设备上的敏感数据、停用远程同步、
提醒管理员等某种组合。

为了让广播接收器正常工作,请确保在 Android 清单中注册它,如上面的代码段所示。
Kotlin
 

class PolicyAdmin : DeviceAdminReceiver() {override fun onDisabled(context: Context, intent: Intent) {// Called when the app is about to be deactivated as a device administrator.// Deletes previously stored password policy.super.onDisabled(context, intent)context.getSharedPreferences(APP_PREF, Activity.MODE_PRIVATE).edit().apply {clear()apply()}}
}

激活设备管理器

在强制执行任何政策之前,用户都需要以设备管理员的身份手动激活应用。以下代
码段说明了如何触发设置 activity,供用户激活您的应用。一种很好的做法是在
intent 中指定 EXTRA_ADD_EXPLANATION extra,从而添加说明文本来向用户强调
应用为何请求成为设备管理员。


Kotlin

if (!policy.isAdminActive()) {val activateDeviceAdminIntent = Intent(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN)activateDeviceAdminIntent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN,policy.getPolicyAdmin())// It is good practice to include the optional explanation text to// explain to user why the application is requesting to be a device// administrator. The system will display this message on the activation// screen.activateDeviceAdminIntent.putExtra(DevicePolicyManager.EXTRA_ADD_EXPLANATION,resources.getString(R.string.device_admin_activation_message))startActivityForResult(activateDeviceAdminIntent, REQ_ACTIVATE_DEVICE_ADMIN)
}

如果用户选择“启用”,应用会成为设备管理员,并且可以开始配置和强制执行该政策。

应用还需要做好准备,以应对用户通过点击“Cancel”按钮、“返回”键或“主屏幕”键放弃
激活流程的预设情况。因此,政策设置 activity 中的 onResume() 需要具有用于重新
评估条件的逻辑,并在需要时向用户显示设备管理员激活选项。

实现设备政策控制器

成功激活设备管理器后,应用会使用请求的政策配置设备政策管理器。请注意,
Android 会随每个版本添加新的政策。如果在支持旧版平台的情况下使用新政策,
则最好在应用中执行版本检查。例如,“密码最小大小写”政策仅适用于 API 级别
11 (Honeycomb) 及更高级别。以下代码演示了如何在运行时检查版本。

Kotlin

private lateinit var dpm: DevicePolicyManager
private lateinit var policyAdmin: ComponentNamedpm = context.getSystemService(Context.DEVICE_POLICY_SERVICE) as DevicePolicyManager
policyAdmin = ComponentName(context, PolicyAdmin::class.java)dpm.apply {setPasswordQuality(policyAdmin, PASSWORD_QUALITY_VALUES[passwordQuality])setPasswordMinimumLength(policyAdmin, passwordLength)if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {setPasswordMinimumUpperCase(policyAdmin, passwordMinUpperCase)}
}

此时,应用能够强制执行该政策。虽然应用无法访问实际所用的屏幕锁定密码,但可
以通过 Device Policy Manager API 确定现有密码是否符合要求的政策。如果发现
现有的屏幕锁定密码不够用,则设备管理 API 不会自动采取纠正措施。该应用负责
在“设置”应用中明确启动系统密码更改屏幕。例如:

Kotlin


if (!dpm.isActivePasswordSufficient) {// Triggers password change screen in Settings.Intent(DevicePolicyManager.ACTION_SET_NEW_PASSWORD).also { intent ->startActivity(intent)}
}

通常,用户可以从可用的锁定机制中选择一种,例如“无”“图案”“PIN 码(数字)”
或“密码”(字母数字)。配置密码政策时,会停用弱于政策中所定义密码类型的
密码类型。例如,如果配置了“数字”密码质量,则用户可以仅选择 PIN 码(数字)
或密码(字母数字)密码。

通过设置适当的屏幕锁定密码来妥善保护设备后,应用将允许访问受保护的内容。
Kotlin

when {!dpm.isAdminActive(policyAdmin) -> {// Activates device administrator....}!dpm.isActivePasswordSufficient -> {// Launches password set-up screen in Settings....}else -> {// Grants access to secure content....startActivity(Intent(context, SecureActivity::class.java))}
}

这篇关于安卓手机APP开发_____通过设备管理政策增强安全性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1034207

相关文章

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与