Android(安卓)6.0权限处理问题
Android发展到6.0对于权限的处理有了一些变化,在sdk21之前我们只需要把权限的请求写在AndroidManifest文件中即可。用户安装应用时会提示所需要的权限,如果用户不同意这些权限那么将无法安装应用。
而到了sdk21之后android加入了动态权限机制,将一些敏感权限运行时进行请求,这样如果用户认为某个权限不需要时可以拒绝授予该权限。当然也可以在设置界面对每个app的权限进行查看,以及对单个权限进行授权或者解除授权。
将权限分为两类,一类是Normal Permissions,这类权限一般不涉及用户隐私,是不需要用户进行授权的,比如手机震动、访问网络等;另一类是Dangerous Permission,一般是涉及到用户隐私的,需要用户进行授权,比如读取sdcard、访问通讯录等。
我们来看一看需要在运行时授权的Dangerous Permission:
group:android.permission-group.CONTACTS permission:android.permission.WRITE_CONTACTS permission:android.permission.GET_ACCOUNTS permission:android.permission.READ_CONTACTSgroup: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_VOICEMAILgroup:android.permission-group.CALENDAR permission:android.permission.READ_CALENDAR permission:android.permission.WRITE_CALENDARgroup:android.permission-group.CAMERA permission:android.permission.CAMERAgroup:android.permission-group.SENSORS permission:android.permission.BODY_SENSORSgroup:android.permission-group.LOCATION permission:android.permission.ACCESS_FINE_LOCATION permission:android.permission.ACCESS_COARSE_LOCATIONgroup:android.permission-group.STORAGE permission:android.permission.READ_EXTERNAL_STORAGE permission:android.permission.WRITE_EXTERNAL_STORAGEgroup:android.permission-group.MICROPHONE permission:android.permission.RECORD_AUDIOgroup: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
现在就来说一下添加动态权限的步骤吧:
1.在AndroidManifest文件中添加需要的权限。
这一步和之前没有变化,我们不能去试图申请一个没有声明的权限,那样会导致程序的崩溃。
2.检查权限是否已经授权:
if(ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_DENIED){ }else { //在这里写请求权限的代码 }
ContextCompat.checkSelfPermission方法用于检测该权限是否被授权
返回值有两种PackageManager.PERMISSION_GRANTED和PackageManager.PERMISSION_DENIED
如果返回值为PackageManager.PERMISSION_DENIED时就需要请求权限了
3.申请授权
ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, requestCode);
申请授权的方法,这个方法有三个参数第一个是context;第二个是一个字符串数组,可以一次请求多个权限系统会逐一弹出请求权限的对话框;第三个是requestCode。
4.请求后的回调
@Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); switch (requestCode){ case MY_REQUEST_PERMISSIONS_CODE: if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { } else { } break; } }
此方法在是在FragmentActivity中定义的,我们重写它并通过这个方法查询我们的权限请求结果。
首先通过requestCode进行请求的定位;然后判断grantResults的长度,grantResults的长度取决于我们请求权限时传递的String数组,也就是说有几个权限请求grantResults的长度就是几个。判断grantResults中元素的值是否等于PackageManager.PERMISSION_GRANTED。如果请求成功就可以继续你的操作了,如果失败那么由你来定义请求失败之后做的事。
OK,权限处理问题大致就说到这,虽然代码不多但是也比较麻烦,这里为大家推荐一个权限处理的库可以节省书写代码的时间。
链接:https://github.com/hongyangAndroid/MPermissions
更多相关文章
- Android结合Retrofit实现统一加解密处理(Get、Post、Delete、Put)
- 【幻灯片分享】凡客移动应用之Android(安卓)+ HTML5技术运用 |
- android 蓝牙ble app开发(二) -- 关键概念,连接参数,连接请求
- Linux文件的特殊权限位SUID、SGID作用及编程设置/读取
- 探索新的Android权限模式
- Android硬件入门-照相机
- android 蓝牙ble app开发(二) -- 关键概念,连接参数,连接请求
- Android(安卓)事件全局监听(二)需要root权限 ,使用getevent监听Andr
- android 安全讲座第四层 手机Root授权原理细节全解析(3)