Android 6.0权限封装

简书地址:https://www.jianshu.com/p/7ae6f234f392
GitHub地址:https://github.com/jiahongfei/OKPermission

本篇文章来介绍Android6.0系统申请权限问题以及我自己封装的一个开源库。github地址点击这里
开源库支持:弹出权限说明对话框,单个、多个权限申请。

占位图.png

Android6.0权限

从 Android 6.0(API 级别 23)开始,权限授权方式从应用安装时进行授权,变成在应用运行时向其授予权限。此方法可以简化应用安装过程,因为用户在安装或更新应用时不需要授予权限。

系统权限分为两类:正常权限和危险权限:

正常权限不会直接给用户隐私权带来风险。如果您的应用在AndroidManifest中列出了正常权限,系统将自动授予该权限。
危险权限会授予应用访问用户机密数据的权限。如果您的应用在AndroidManifest中列出了正常权限,系统将自动授予该权限。如果您列出了危险权限,则用户必须明确批准您的应用使用这些权限。
在所有版本的 Android 中,您的应用都需要在其AndroidManifest中同时声明它需要的正常权限和危险权限。不过,该声明的影响因系统版本和应用的目标 SDK 级别的不同而有所差异:

权限在Android版本中的授权形式
  • 如果设备运行的是 Android 5.1 或更低版本,或者应用的目标 SDK 为 22 或更低:如果您在AndroidManifest中列出了危险权限,则用户必须在安装应用时授予此权限;如果他们不授予此权限,系统根本不会安装应用。
  • 如果设备运行的是 Android 6.0 或更高版本,或者应用的目标 SDK 为 23 或更高:应用必须在AndroidManifest中列出权限,并且它必须在运行时请求其需要的每项危险权限。用户可以授予或拒绝每项权限,且即使用户拒绝权限请求,应用仍可以继续运行有限的功能。
    :从 Android 6.0(API 级别 23)开始,用户可以随时从任意应用调用权限,即使应用面向较低的 API 级别也可以调用。无论您的应用面向哪个 API 级别,您都应对应用进行测试,以验证它在缺少需要的权限时行为是否正常。
正常权限
  • 正常权限涵盖应用需要访问其沙盒外部数据或资源,但对用户隐私或其他应用操作风险很小的区域。例如,设置时区的权限就是正常权限。如果应用声明其需要正常权限,系统会自动向应用授予该权限。如下正常权限列表:
  • [ACCESS_LOCATION_EXTRA_COMMANDS]
  • [ACCESS_NETWORK_STATE]
  • [ACCESS_NOTIFICATION_POLICY]
  • [ACCESS_WIFI_STATE]
  • [BLUETOOTH]
  • [BLUETOOTH_ADMIN]
  • [BROADCAST_STICKY]
  • [CHANGE_NETWORK_STATE]
  • [CHANGE_WIFI_MULTICAST_STATE]
  • [CHANGE_WIFI_STATE]
  • [DISABLE_KEYGUARD]
  • [EXPAND_STATUS_BAR]
  • [GET_PACKAGE_SIZE]
  • [INSTALL_SHORTCUT]
  • [INTERNET]
  • [KILL_BACKGROUND_PROCESSES]
  • [MODIFY_AUDIO_SETTINGS]
  • [NFC]
  • [READ_SYNC_SETTINGS]
  • [READ_SYNC_STATS]
  • [RECEIVE_BOOT_COMPLETED]
  • [REORDER_TASKS]
  • [REQUEST_IGNORE_BATTERY_OPTIMIZATIONS]
  • [REQUEST_INSTALL_PACKAGES]
  • [SET_ALARM]
  • [SET_TIME_ZONE]
  • [SET_WALLPAPER]
  • [SET_WALLPAPER_HINTS]]
  • [TRANSMIT_IR]
  • [UNINSTALL_SHORTCUT]
  • [USE_FINGERPRINT]
  • [VIBRATE]
  • [WAKE_LOCK]
  • [WRITE_SYNC_SETTINGS]
危险权限
  • 危险权限涵盖应用需要涉及用户隐私信息的数据或资源,或者可能对用户存储的数据或其他应用的操作产生影响的区域。例如,能够读取用户的联系人属于危险权限。如果应用声明其需要危险权限,则用户必须明确向应用授予该权限。

危险权限都属于各自的权限组,如果在AndroidManifest中设置了危险权限,那么在程序中会向用户显示一个对话框,描述应用要访问的权限组。对话框不描述该组内的具体权限。如果用户授权了这个权限组,那么组内的所有权限都被授权不用重复授权。如下危险权限列表:

group:android.permission-group.CONTACTS
permission:android.permission.WRITE_CONTACTS
permission:android.permission.GET_ACCOUNTS
permission:android.permission.READ_CONTACTS
group:android.permission-group.PHONE
permission:android.permission.READ_CALL_LOG
permission:android.permission.READ_PHONE_STATE
permission:android.permission.CALL_PHONE
permission:android.permission.WRITE_CALL_LOG
permission:android.permission.USE_SIP
permission:android.permission.PROCESS_OUTGOING_CALLS
permission:com.android.voicemail.permission.ADD_VOICEMAIL
group:android.permission-group.CALENDAR
permission:android.permission.READ_CALENDAR
permission:android.permission.WRITE_CALENDAR
group:android.permission-group.CAMERA
permission:android.permission.CAMERA
group:android.permission-group.SENSORS
permission:android.permission.BODY_SENSORS
group:android.permission-group.LOCATION
permission:android.permission.ACCESS_FINE_LOCATION
permission:android.permission.ACCESS_COARSE_LOCATION
group:android.permission-group.STORAGE
permission:android.permission.READ_EXTERNAL_STORAGE
permission:android.permission.WRITE_EXTERNAL_STORAGE
group:android.permission-group.MICROPHONE
permission:android.permission.RECORD_AUDIO
group:android.permission-group.SMS
permission:android.permission.READ_SMS
permission:android.permission.RECEIVE_WAP_PUSH
permission:android.permission.RECEIVE_MMS
permission:android.permission.RECEIVE_SMS
permission:android.permission.SEND_SMS
permission:android.permission.READ_CELL_BROADCASTS

如下介绍我写的Android6.0申请权限的开源库,github地址点击这里

OKPermission

这是一个申请权限的开源库。
开源库支持:弹出权限说明对话框,单个、多个权限申请。

OKPermission对外暴露的类
//OKPermission的管理类,用于申请权限、配置各种参数
class OKPermissionManager

//申请权限的包装类,可以配置提示对话框权限的展示名字和图片
class PermissionItem

//权限申请结束的监听,用于判断权限是否申请成功或者失败
interface OKPermissionListener

//权限提示对话框,点击返回键的监听
interface OKPermissionKeyBackListener
弹出权限申请提示对话框,并且申请多个权限
//申请的权限在这里配置,一个危险权限组只需要申请一个权限即可。
//例如:[LOCATION]权限组,只需要申请[ACCESS_FINE_LOCATION]或者[ACCESS_COARSE_LOCATION]即可,如下配置。
 PermissionItem[] permissionItems = new PermissionItem[]{
                new PermissionItem(Manifest.permission.READ_PHONE_STATE, "手机状态", R.mipmap.ic_launcher),
                new PermissionItem(Manifest.permission.CAMERA, "照相机", R.mipmap.ic_launcher),
                new PermissionItem(Manifest.permission.ACCESS_FINE_LOCATION, "位置信息2", R.mipmap.ic_launcher)};
        OKPermissionManager okPermissionManager = new OKPermissionManager
                .Builder(permissionItems)
               //权限申请的回调方法
                .setOKPermissionListener(new OKPermissionListener() {
                    @Override
                    public void onOKPermission(@NonNull String[] permissions, @NonNull int[] grantResults) {
                        Log.e(TAG, Arrays.toString(permissions));
                    }
                })
                //权限申请提示对话框,点击返回键回调的监听
                .setKeyBackListener(new OKPermissionKeyBackListener() {
                    @Override
                    public void onKeyBackListener() {
                        Log.e(TAG,"OKPermissionKeyBackListener");
                    }
                })
               //开启权限申请提示对话框
                .setShowDialog(true)
                //配置标题
                .setDialogTitle("开启App")
                //配置提示信息
                .setDialogMsg("为了能够正常使用,需要开启以下权限")
                .builder();
        okPermissionManager.applyPermission(mContext);

上面那段代码对应如下图片
申请权限.gif

快速申请权限
//这种方式可申请一个权限也可以申请多个权限
 OKPermissionManager.applyPermissionNoDialog(mContext, new String[]{Manifest.permission.READ_PHONE_STATE}, new OKPermissionListener() {
            @Override
            public void onOKPermission(@NonNull String[] permissions, @NonNull int[] grantResults) {

            }
        });

如下图片:
快速申请权限.gif

如果对您有帮助欢迎访问我的github主页里面还有很多开源库都是工作中用到的,而且一直在维护。

参考文献:
https://developer.android.com/training/permissions/requesting.html?hl=zh-cn
https://developer.android.com/guide/topics/permissions/normal-permissions.html?hl=zh-cn
https://developer.android.com/guide/topics/security/permissions.html?hl=zh-cn#defining

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值