打造简洁高效的动态权限管理器

原创 2017年02月16日 12:01:14

转载请说明出处!
作者:kqw攻城狮
出处:个人站 | CSDN


效果图

这里写图片描述

GitHub地址:PermissionsManager

随着Android 6.0的普及,动态权限的重要性也开始时慢慢体现出来。为了更好的保护用户隐私,Android 6.0要求在进行敏感操作之前,必须要向用户请示申请权限。

如何使用,在之前的文章里也已经介绍过了,但是用起来比较麻烦。Android6.0动态获取权限

我希望可以封装一下,使用之前创建一个动态权限的管理对象,他有两个回调来告诉我权限申请成功或者失败,像这样:

mPermissionsManager = new PermissionsManager(this) {
    @Override
    public void authorized(int requestCode) {
        // TODO 权限通过
    }

    @Override
    public void noAuthorization(int requestCode, String[] lacksPermissions) {
        // TODO 有权限没有通过
    }
};

使用的时候,可以直接调用一个方法,把要请示的权限传进去就可以进行校验,像这样:

// 检查权限
mPermissionsManager.checkPermissions("请求码", "要校验的权限");

于是乎,下面封装的动态权限管理器就来了:

动态权限管理器

package com.kongqw.permissionslibrary;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.provider.Settings;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;

import java.util.ArrayList;

/**
 * Created by kongqingwei on 2017/2/15.
 * 检查权限的类
 */

public abstract class PermissionsManager {

    private static final String PACKAGE_URL_SCHEME = "package:";
    private Activity mTargetActivity;

    public abstract void authorized(int requestCode);

    public abstract void noAuthorization(int requestCode, String[] lacksPermissions);

    public PermissionsManager(Activity targetActivity) {
        mTargetActivity = targetActivity;
    }

    /**
     * 检查权限
     *
     * @param requestCode 请求码
     * @param permissions 准备校验的权限
     */
    public void checkPermissions(int requestCode, String... permissions) {

        ArrayList<String> lacks = new ArrayList<>();
        for (String permission : permissions) {
            if (ContextCompat.checkSelfPermission(mTargetActivity.getApplicationContext(), permission) == PackageManager.PERMISSION_DENIED) {
                lacks.add(permission);
            }
        }

        if (!lacks.isEmpty()) {
            // 有权限没有授权
            String[] lacksPermissions = new String[lacks.size()];
            lacksPermissions = lacks.toArray(lacksPermissions);
            //申请CAMERA权限
            ActivityCompat.requestPermissions(mTargetActivity, lacksPermissions, requestCode);
        } else {
            // 授权
            authorized(requestCode);
        }
    }

    /**
     * 复查权限
     * <p>
     * 调用checkPermissions方法后,会提示用户对权限的申请做出选择,选择以后(同意或拒绝)
     * TargetActivity会回调onRequestPermissionsResult方法,
     * 在onRequestPermissionsResult回调方法里,我们调用此方法来复查权限,检查用户的选择是否通过了权限申请
     *
     * @param requestCode  请求码
     * @param permissions  权限
     * @param grantResults 授权结果
     */
    public void recheckPermissions(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        for (int grantResult : grantResults) {
            if (grantResult == PackageManager.PERMISSION_DENIED) {
                // 未授权
                noAuthorization(requestCode, permissions);
                return;
            }
        }
        // 授权
        authorized(requestCode);
    }

    /**
     * 进入应用设置
     *
     * @param context context
     */
    public static void startAppSettings(Context context) {
        Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        intent.setData(Uri.parse(PACKAGE_URL_SCHEME + context.getPackageName()));
        context.startActivity(intent);
    }
}

应用

使用起来的逻辑也比较清晰简单,一共3步:

1. 初始化权限管理器

// 初始化
mPermissionsManager = new PermissionsManager(this) {
    @Override
    public void authorized(int requestCode) {
        Toast.makeText(getApplicationContext(), requestCode + " : 全部权限通过", Toast.LENGTH_SHORT).show();
    }

    @Override
    public void noAuthorization(int requestCode, String[] lacksPermissions) {
        Toast.makeText(getApplicationContext(), requestCode + " : 有权限没有通过!需要授权", Toast.LENGTH_SHORT).show();
        for (String permission : lacksPermissions) {
            Log.i(TAG, "noAuthorization: " + permission);
        }
    }
};

2. 检查权限

// 要校验的权限
String[] PERMISSIONS = new String[]{Manifest.permission.RECORD_AUDIO, Manifest.permission.CAMERA};
// 检查权限
mPermissionsManager.checkPermissions(0, PERMISSIONS);

3. 复查权限

用户对权限申请的提示做出选择以后,要重写TargetActivity的onRequestPermissionsResult方法来复查权限,检查权限是否通过。

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    // 用户做出选择以后复查权限,判断是否通过了权限申请
    mPermissionsManager.recheckPermissions(requestCode, permissions, grantResults);
}

进入应用设置页面

最后,权限没有通过,是不能使用的,如果一定要用,一般要提示用户缺少权限,到应用设置页面去吧权限打开,再回来使用。
对话框就不写了,进入到应用的设置页面可以直接调用PermissionsManager里的startAppSettings方法,进入到该应用的设置页面,修改权限

PermissionsManager.startAppSettings(getApplicationContext());
版权声明:本文为博主原创文章,未经博主允许不得转载。

权限管理系统

  • 2017年11月08日 08:38
  • 4.69MB
  • 下载

权限管理系统。

1 系统采用的是spring4.0.2+springmvc+mybatis3.2.6+maven3.3.3+easyui1.3.3框架。 2 系统的环境是myeclipse10+jdk1.8...
  • qq_34661464
  • qq_34661464
  • 2017年08月09日 15:33
  • 122

基于角色的权限管理系统设计思路

概述权限管理功能是项目中重要的部分,通过权限系统可以控制系统中各用户所拥有的权限,比如能否打开一个页面,能否进行某项操作,合理的权限控制可以规避误操作的风险,提高系统的可用性。 权限管理的思路一般为...
  • u011897301
  • u011897301
  • 2017年05月18日 18:05
  • 3456

权限管理框架

之前看的视频笔记, 做个备份,以免想找的时候总找不到。  Shiro:权限管理框架 权限管理:          基本上涉及到用户参与的系统都要进行权限管理,权限管理属于系统...
  • d124939312
  • d124939312
  • 2018年01月02日 18:21
  • 187

权限管理解决方案

一:什么是粗粒度和细粒度权限?        粗粒度权限:对资源类型的权限管理。资源类型比如:url链接,菜单,用户添加页面,页面中按钮,用户信息,类方法等          细粒度权限:对资源实...
  • Lee_Ho_
  • Lee_Ho_
  • 2017年06月08日 22:32
  • 232

权限管理系统和日志管理z

  • 2017年09月01日 23:21
  • 10.86MB
  • 下载

权限管理系统

  • 2017年08月28日 14:57
  • 5.32MB
  • 下载

权限管理

关于权限菜单的设计 http://blog.csdn.net/bearyb1982/article/details/2448301 权限设计(初稿)  ...
  • weixin_40474161
  • weixin_40474161
  • 2017年12月29日 20:24
  • 120

权限管理

摘要 权限管理,一般指根据系统设置的安全规则或者安全策略,用户可以访问而且只能访问自己被授权的资源,不多不少。权限管理几乎出现在任何系统里面,只要有用户和密码的系统。 很多人,常将“用户身份认证”...
  • joeyon
  • joeyon
  • 2014年12月25日 09:29
  • 704

权限管理及实现思路

一个系统包含众多模块,要求能够通过权限管理,控制不同用户对模块的访问权限,而且需要控制到对某个模块的某个操作(增删改查)的级别。一般情况下,通过角色对用户进行统一授权,在某些特殊情况下,能够单独对用户...
  • liusong0605
  • liusong0605
  • 2013年02月28日 21:25
  • 11838
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:打造简洁高效的动态权限管理器
举报原因:
原因补充:

(最多只允许输入30个字)