哈哈,现在写适配6.0好像有点马后炮的感觉,不过以前确实没有注意到这些问题。前几天在添加高德地图定位功能的时候发现在Android 6.0系统上有很多的权限需要进行动态申请。
下面先来看一下在Android 6.0中都有哪些权限需要我们来进行动态申请权限的。
危险权限表.jpg
以上就是在Android 6.0系统中需要动态授权的危险权限表,在刚实习面试的时候曾经被问到过一个问题,Android 6.0中需要动态授权的权限一共有多少个... 当时也是被问的一脸懵逼,只是知道概念,从来没有实践过。所以也借助这个机会加深一下印象,一共是9组27个权限,当我们在动态授权时,只要用户允许了一组当中的一个权限,那么系统默认会通过整组的权限,所以我们在动态授权时每组只要将一个permission进行授权即可。
注意!!!在Android O中已经修复此项,系统只会授予应用明确请求的权限。
下面来看一下如何在代码中实现动态授权:
首先,个人建议将以下的动态授权代码放在自己项目的SplashActivity中,这样用户第一次启动应用的时候,最先就能进行授权,避免影响程序在之后的运行,而且这样一来可以进行统一授权。
当项目中有多个危险权限需要动态申请时,见以下代码:
// 声明一个数组,用来存储所有需要动态申请的权限
String[] permissions = new String[]{
Manifest.permission.ACCESS_COARSE_LOCATION,
Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.WRITE_EXTERNAL_STORAGE,
Manifest.permission.READ_EXTERNAL_STORAGE,
Manifest.permission.READ_PHONE_STATE,};
// 声明一个集合,在后面的代码中用来存储用户拒绝授权的权
List mPermissionList = new ArrayList<>();
checkPermission() 调用我们写好的检查权限方法
private void checkPermission() {
mPermissionList.clear();
/**
* 判断哪些权限未授予
* 以便必要的时候重新申请
*/
for (String permission : permissions) {
if (ContextCompat.checkSelfPermission(mContext, permission) != PackageManager.PERMISSION_GRANTED) {
mPermissionList.add(permission);
}
}
/**
* 判断存储委授予权限的集合是否为空
*/
if (!mPermissionList.isEmpty()) {
// 后续操作...
} else {//未授予的权限为空,表示都授予了
// 后续操作...
}
}
回调动态授权结果
boolean mShowRequestPermission = true;//用户是否禁止权限
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode) {
case 1:
for (int i = 0; i < grantResults.length; i++) {
if (grantResults[i] != PackageManager.PERMISSION_GRANTED) {
//判断是否勾选禁止后不再询问
boolean showRequestPermission = ActivityCompat.shouldShowRequestPermissionRationale(ShopNearbyActivity.this, permissions[i]);
if (showRequestPermission) {
// 后续操作...
} else {
// 后续操作...
}
}
}
// 授权结束后的后续操作...
break;
default:
break;
}
}
只要能理解上面的代码,基本上就可以完成对Android 6.0以上版本中需要的动态授权操作。
新人上路,如果各位萌友发现什么问题,欢迎一起交流学习哦,也希望大神们可以多多指教~