zoukankan      html  css  js  c++  java
  • android 开发 实现多个动态权限的方法(并且兼容6.0以下的版本权限授权)

    前言

    android开发权限授权因为版本的不同有不同的授权方式,6.0以下的版本使用的是在注册表中添加权限的静态授权(这种授权权限提示只会出现在app安装的时候),而6.0以上(包含6.0)就需要动态授权的方式。

    实现思维:

    1.就算是动态授权依然需要在AndroidManifest.xml里添加静态权限。

    2.动态权限的数组写法与KEY。

    3.判断系统版本。

    4.判断权限是否获取

    5.授权完成后的回调方法执行

    讲解部分

    1.在AndroidManifest.xml里添加静态权限。

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.example.lenovo.mydemoapp">
        <!--此处添加静态权限-->
        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.CAMERA"/>
        <application
            android:name=".myAppCompatActivity.MyApplication"
            android:allowBackup="true"  以下略....

    2.动态权限的数组写法与KEY。

    //因为本人是写一个头像设置的功能,所以需要在进入相机拍照或者相册选择图像中做区分。所以写了一个KEY来处理不同的Button
        private static final int Permissions_GALLERY_KEY = 1;
        private static final int Permissions_CAMERA_KEY = 2;
        //需要的权限 注意请不要将数组写成 private String mPermissions[] = {"Manifest.permission.WRITE_EXTERNAL_STORAGE"};
        //这样加了引号的是错误的,我犯过这种低级错误
        private String mPermissions[] = {Manifest.permission.WRITE_EXTERNAL_STORAGE,
                Manifest.permission.READ_EXTERNAL_STORAGE,
                Manifest.permission.CAMERA};

    另外附危险权限清单(一般情况下只需要关注下面的危险权限一共9组24个,正常权限系统会自动添加,不需要另外授权)

    危险权限组和权限:

    每个组申请一个权限,这个组的其他权限也一并申请了。

    所有危险的 Android 系统权限都属于权限组。如果设备运行的是 Android 6.0(API 级别 23),并且应用的 targetSdkVersion 是 23 或更高版本,则当用户请求危险权限时系统会发生以下行为:

    • 如果应用请求其清单中列出的危险权限,而应用目前在权限组中没有任何权限,则系统会向用户显示一个对话框,描述应用要访问的权限组。对话框不描述该组内的具体权限。例如,如果应用请求READ_CONTACTS 权限,系统对话框只说明该应用需要访问设备的联系信息。如果用户批准,系统将向应用授予其请求的权限。
    • 如果应用请求其清单中列出的危险权限,而应用在同一权限组中已有另一项危险权限,则系统会立即授予该权限,而无需与用户进行任何交互。例如,如果某应用已经请求并且被授予了 READ_CONTACTS 权限,然后它又请求 WRITE_CONTACTS,系统将立即授予该权限。

    任何权限都可属于一个权限组,包括正常权限和应用定义的权限。但权限组仅当权限危险时才影响用户体验。可以忽略正常权限的权限组。

    如果设备运行的是 Android 5.1(API 级别 22)或更低版本,并且应用的 targetSdkVersion 是 22 或更低版本,则系统会在安装时要求用户授予权限。再次强调,系统只告诉用户应用需要的权限组,而不告知具体权限。

    具体的危险权限组和权限如下:

    CALENDAR  日历

    CAMERA  相机

    CONTACTS  通讯录

    LOCATION  位置

    MICROPHONE  麦克风

    PHONE   电话

    SENSORS  传感器

    • BODY_SENSORS  物体传感器(一般指距离,光感,重力等等这些感应接收器)

    SMS  信息

    STORAGE  存储

    代码部分

    下面是一个工具类

    public class PermissionUtil {
        private static final int PERMISSION_REQUEST_CODE = 0xab;
    
        /**
         * 检查单个权限
         *
         * @param context
         * @return true = 已获得授权.
         * false = 未获得授权
         */
        public static boolean checkPermission(Context context, String permission) {
            int result = ContextCompat.checkSelfPermission(context, Manifest.permission.ACCESS_FINE_LOCATION);
            if (result == PackageManager.PERMISSION_GRANTED) {
                return true;
            }
            return false;
        }
    
        /**
         * 检查一组权限
         *
         * @param context
         * @param permissionArray
         * @return 返回未授权的权限list, 如果返回null等于全部权限都已经被授予.
         */
        public static String[] checkPermissions(Context context, String[] permissionArray) {
            if (permissionArray == null || permissionArray.length == 0) {
                return null;
            }
            List<String> notPermissionList = new ArrayList<>();
            for (String permission : permissionArray) {
                int result = ContextCompat.checkSelfPermission(context, permission);
                if (result != PackageManager.PERMISSION_GRANTED) {
                    notPermissionList.add(permission);
                }
            }
            if (notPermissionList.size() == 0) {
                return null;
            }
            return notPermissionList.toArray(new String[notPermissionList.size()]);
        }
    
        /**
         * 申请权限
         *
         * @param activity
         */
        public static void applyPermission(Activity activity, String[] permissionArray, int designationRequestCode) {
            ActivityCompat.requestPermissions(activity, permissionArray, designationRequestCode);
        }
    
        /**
         * 申请权限
         *
         * @param activity
         */
        public static void applyPermission(Activity activity, String[] permissionArray) {
            ActivityCompat.requestPermissions(activity, permissionArray, PERMISSION_REQUEST_CODE);
        }
    
        /**
         * 处理申请权限返回后的结果,此方法可以指定requestCode
         *
         * @param requestCode            返回code
         * @param designationRequestCode 你指定的返回code
         * @param permissions            申请权限
         * @param grantResults           权限申请结果
         * @return String[] == null : 1.requestCode不等于designationRequestCode 2.权限申请未知错误 grantResults小于0
         * String[]长度等于0:全部权限都申请成功
         * String[]长度不等于0:未申请成功的权限
         */
        public static String[] handlerPermissionApplyResults(int requestCode, int designationRequestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
            return handlerResults(requestCode, designationRequestCode, permissions, grantResults);
        }
    
        /**
         * 处理申请权限返回后的结果,此方法使用默认requestCode > PERMISSION_REQUEST_CODE
         *
         * @param requestCode  返回code
         * @param permissions  申请权限
         * @param grantResults 权限申请结果
         * @return String[] == null : 1.requestCode不等于默认PERMISSION_REQUEST_CODE 2.权限申请未知错误 grantResults小于0
         * String[]长度等于0:全部权限都申请成功
         * String[]长度不等于0:未申请成功的权限
         */
        public static String[] handlerPermissionApplyResults(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
            return handlerResults(requestCode, PERMISSION_REQUEST_CODE, permissions, grantResults);
        }
    
        private static String[] handlerResults(int requestCode, int designationRequestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
            if (requestCode == designationRequestCode) {
                if (grantResults.length > 0) {
                    List<String> notPermissionList = new ArrayList<>();
                    for (int i = 0; i < grantResults.length; i++) {
                        int result = grantResults[i];
                        String permission = permissions[i];
                        if (result != PackageManager.PERMISSION_GRANTED) {
                            notPermissionList.add(permission);
                        }
                    }
                    if (!notPermissionList.isEmpty()) {
                        return notPermissionList.toArray(new String[notPermissionList.size()]);
                    }
                    return new String[0];
    
                } else {
                    return null;
                }
            } else {
                return null;
            }
        }
    
    }

    End

  • 相关阅读:
    call和applay
    判断传入的参数是否包含空
    通过函数修改文件中指定字符串
    任一个英文的纯文本文件,统计其中的每个单词出现的个数(注意是每个单词)
    下载进度条实现
    Python 用户登录判断,数据结构-字典
    python 字符串(str)和列表(list)互相转换
    网络编程01
    OpenGL入门学习
    程序的音频输出
  • 原文地址:https://www.cnblogs.com/guanxinjing/p/9708616.html
Copyright © 2011-2022 走看看