android申请权限一次性申请多个,Android适配6.0动态申请权限,多权限同时申请

本文介绍了在Android 6.0中引入的动态权限申请机制,详细讲解了如何处理高德地图定位功能所需的权限。在Android 6.0上,开发者需要对9组27个危险权限进行动态申请。文章提供了一段示例代码,展示如何在SplashActivity中检查和请求权限,确保应用在首次启动时获取所需权限。同时,提到了在Android O中权限管理的改变,系统只会授予明确请求的权限。
摘要由CSDN通过智能技术生成

哈哈,现在写适配6.0好像有点马后炮的感觉,不过以前确实没有注意到这些问题。前几天在添加高德地图定位功能的时候发现在Android 6.0系统上有很多的权限需要进行动态申请。

下面先来看一下在Android 6.0中都有哪些权限需要我们来进行动态申请权限的。

e84e8c9f9912

危险权限表.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以上版本中需要的动态授权操作。

新人上路,如果各位萌友发现什么问题,欢迎一起交流学习哦,也希望大神们可以多多指教~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值