哈哈,现在写适配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以上版本中需要的动态授权操作。

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

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

  1. android调用相机与相册的方法,手把手教你:android调用系统相机、相册功能,适配6.0权限获取以及7.0之后获取URI(兼容多版本)...

    Android中调用系统相机来拍摄照片的代码,以下:html 一.首先设置Uri获取判断以及相机请求Codejava public final int TYPE_TAKE_PHOTO = 1;//Ur ...

  2. Android 系统自带图片裁剪功能(适配7.0、8.0、对了还有小米手机)

    前段时间写了如何获取相册和拍照之后的照片并且进行显示和上传,这一次是如何进行圆形图像制作,经常看我写的笔记的人会知道,我很懒.那么我就懒的自定义了,目前需求就用原生的就好了,大神的轮子,我会在后面进行 ...

  3. Android手写签批功能实现(适配Android6.0及以上)

     Android手写签批功能的实现在于三个点,mupdf,偏移量的计算,droidText0.5.jar 实际步骤: 使用muPdf将PDF加载出来 弹出透明的popwindow,popWindow使 ...

  4. Android无法安装apk,8.0未知来源应用安装权限

    Android 新版本的出现 ,适配Android8.0未知来源应用安装权限处理 1.在清单文件中增加请求安装权限 <uses-permission android:name="and ...

  5. Android App内部更新(最新) 各安卓版本适配

    Android 内部更新 各安卓版本适配 一:前言 在国内,app在线更新是一个必须要求.新版本发布时.用户进入我们的app,就会弹出更新提示框: 二:开发 在线更新分为以下几个步骤: 1:通过接口获 ...

  6. android申请权限一次性申请多个,android 6.0以上动态一次申请多个权限-最美解决方案...

    目录 背景 危险权限 申请权限思路 申请权限流程 干货 后续 一.背景 android23 API新增危险权限校验,需要手动获取: 二.危险权限: 日历数据 android.permission-gr ...

  7. android申请权限一次性申请多个,Android 批量申请权限

    Android开发时,到6.0系统上之后,有的权限就得申请才能用了. Android将权限分为正常权限 和 危险权限 详细可参考: (https://www.cnblogs.com/liuzhipen ...

  8. Android 6.0动态权限申请

    Android 6.0动态权限申请 特别感谢: https://www.jianshu.com/p/2fe4fb3e8ce0 本文是在该文的基础上添加了类似自己的读后感才完成的. 我并不希望成为白求恩 ...

  9. Android 6.0 动态权限申请

    1. 概述 Android 6.0 (API 23) 之前应用的权限在安装时全部授予,运行时应用不再需要询问用户.在 Android 6.0 或更高版本对权限进行了分类,对某些涉及到用户隐私的权限可在 ...

最新文章

  1. 沃森世界研讨会前瞻:AI服务 了解客户情绪
  2. h5网页水印SDK的实现代码示例
  3. 未来科学家数学与计算机奖,未来科学大奖“对话未来科学家”
  4. Java设计模式(二十二):原型设计模式
  5. suse linux 安装oracle,SUSE Linux下安装Oracle 11g服务器
  6. 第三次学JAVA再学不好就吃翔(part75)--集合概述
  7. 【转载保存】Java丨jsoup网络爬虫登录得到cookie并带上cookie访问
  8. 为什么自己编写的页面总是在那里抖动_SEO排名,为什么旧页面比新内容排名高?...
  9. 上传RNA-seq数据到NCBI GEO数据库
  10. SAP License:2021年最新FICO面试答案
  11. .net的数据类型说明
  12. HTML网页设计基础——二维码名片
  13. 薄膜单点压力传感器的制作
  14. win10系统C盘根目录里文件夹都是干什么的
  15. python提速网站资源_三分钟学会Django缓存,让你的网站提速十倍以上
  16. 小工具:输出Houdini里节点间参数的差别
  17. python爬虫概述及简单实践
  18. 首次申请测绘资质需要提交哪些材料?
  19. 几种分布式存储系统的分析
  20. Pond Cascade Gym - 101670B 解题报告

热门文章

  1. 年仅34岁!211高校一副教授因心源性问题猝然而逝...
  2. 基于wireshark的HTTP请求报文分析
  3. c语言实验报告9 四川师范大学,四川师范大学数学与软件科学学院程序设计实验报告实验十...
  4. 《Nmap渗透测试指南》目录—导读
  5. java获取浏览器window对象,Window 浏览器窗口对象
  6. 3个月计算机考研,【图片】(重开)三个月考研成功的心路历程 -南邮计算机【南京邮电大学研究生院吧】_百度贴吧...
  7. Educoder————空瓶换酒
  8. Linux安装谷歌浏览器
  9. 2017年计算机组成原理1254,2017年1月(试卷号1254)《计算机组成原理A》电大试题答案(最新).pdf...
  10. 基于Python实现电影售票系统