Android进行设备管理(针对企业开发)

设备管理

Android从2.2版本开始,提供了一套设备管理API来进行Android手机设备的管理工作,其中包含设备锁屏、禁用启用摄像头(4.0开始提供)、擦除用户数据(也可擦除sdcard中的数据,不过要到2.3)等一系列的设备管理策略,具体可参见DevicePolicyManager类中的定义(http://developer.android.com/reference/android/app/admin/DevicePolicyManager.html),下面是一些具体的步骤~

声明和定义策略

在使用设备管理功能前需在res/xml/device_admin.xml 中声明和定义要使用的设备策略,这些声明和定义的策略将会被我们的应用程序执行,如果你执行了没在  res/xml/device_admin.xml  声明和定义的策略,那将会抛出 SecurityException  异常,具体定义如下

<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 />
        <disable-keyguard-features />
    </uses-policies>
</device-admin>

接收设备管理中一些事件

在进行设备管理的操作中,根据具体的业务逻辑可能需要知晓一些重要事件,比如取消激活设备管理事件,这个事件就很重要了,我们必须得知道用户进行了此项操作,从而来进行一些逻辑的处理或者提示用户,还有许多的事件这里就不一一说了,具体详见DeviceAdminReceiver(http://developer.android.com/training/enterprise/device-management-policy.html#CreateDeviceAdminReceiver),我们可以继承DeviceAdminReceiver,覆写一些回调方法,具体可能如下

public class AdminReceiver extends DeviceAdminReceiver {
 
 @Override
 public DevicePolicyManager getManager(Context context) {
  return super.getManager(context);
 }
 
 @Override
 public ComponentName getWho(Context context) {
  return super.getWho(context);
 }
 
 /**
  * 禁用
  */
 @Override
 public void onDisabled(Context context, Intent intent) {
 
  Toast.makeText(context, "禁用设备管理", Toast.LENGTH_SHORT).show();
 
  super.onDisabled(context, intent);
 }
 @Override
 public CharSequence onDisableRequested(Context context, Intent intent) {
  return super.onDisableRequested(context, intent);
 }
 
 /**
  * 激活
  */
 @Override
 public void onEnabled(Context context, Intent intent) {
 
  Toast.makeText(context, "启动设备管理", Toast.LENGTH_SHORT).show();
 
  super.onEnabled(context, intent);
 }
 @Override
 public void onPasswordChanged(Context context, Intent intent) {
  super.onPasswordChanged(context, intent);
 }
 @Override
 public void onPasswordFailed(Context context, Intent intent) {
  super.onPasswordFailed(context, intent);
 }
 @Override
 public void onPasswordSucceeded(Context context, Intent intent) {
  super.onPasswordSucceeded(context, intent);
 }
 @Override
 public void onReceive(Context context, Intent intent) {
  super.onReceive(context, intent);
 }
 @Override
 public IBinder peekService(Context myContext, Intent service) {
  //Logger.d("------" + "peekService" + "------");
  return super.peekService(myContext, service);
 }
 
}

当然还需像正常的Receiver一样得在Manifest文件中进行注册,还行注意的是在注册过程中还需引用我们刚才声明定义好的策略列表

        <receiver
            android:name=".receiver.AdminReceiver"
            android:description="@string/device_des"
            android:label="@string/device_label"
            android:permission="android.permission.BIND_DEVICE_ADMIN" >
            <meta-data
                android:name="android.app.device_admin"
                android:resource="@xml/device_manager" />

            <intent-filter>
                <action android:name="android.app.action.DEVICE_ADMIN_ENABLED" />
            </intent-filter>
        </receiver>