android检测SD卡读写权限方法

一、解析

做项目遇到了一个棘手的问题,SD卡的读写权限问题。

1.android版本在6.0以上版本时,以下代码才有用:

if (Build.VERSION.SDK_INT >= 23) {
   UiUtils.getInstance().showToast("1");
   //减少是否拥有权限checkCallPhonePermission != PackageManager.PERMISSION_GRANTED
   int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
   if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
    UiUtils.getInstance().showToast("2");
    //弹出对话框接收权限
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
    return;
   } else {
    UiUtils.getInstance().showToast("3");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  }

因为在android版本5.0以上才把SD卡的读写权限分离开,以前的老版本是没有进行分离的。故找不到SD卡的读写权限,而在测试的过程中,华为的手机出现SD卡读写权限分离在两个地方,有的时候可能不好找,本人就出现这个问题。

二、代码介绍

调用第一个方法:

使用之前先定义两个变量:

 private Map<Integer, Runnable> allowablePermissionRunnables = new HashMap<>();
 private Map<Integer, Runnable> disallowablePermissionRunnables = new HashMap<>();

1.”android.permission.WRITE_EXTERNAL_STORAGE”这个是SD卡的写入权限,这里检测一个权限就可以了,不用检测读的权限了。

(1)以下第一个Runnable()中是权限提示框允许之后处理的业务。

(2)第二个Runnable()中是权限提示框拒绝之后执行的业务逻辑。

requestPermission(HDCivilizationConstants.SD_CARD_REQUEST_CODE, "android.permission.WRITE_EXTERNAL_STORAGE", new Runnable() {
   @Override
   public void run() {
   //第一个Runnable
    if (type==1){
     FileUtils.saveBitmapPng(rectBitmap, pathList, 80);
    }else{
     try {
      FileUtils.saveBitmapJPG(rectBitmap, pathList, 70);
     } catch (ContentException e) {
      e.printStackTrace();
     }
    }
   }
  }, new Runnable() {
   @Override
   public void run() {
   //第二个Runnable
//    UiUtils.getInstance().showToast("请查看SD卡的读写权限");
    OKPopup.getInstance().showPopup(TakeCameraActivity.this, new OKPopup.BtnClickListener() {
     @Override
     public void btnOk() {
      OKPopup.getInstance().dismissDialog();
     }
    }, false, HDCivilizationConstants.SDCARD_PERMISSION);
   }
  });

2.调用上面的那个方法之后会跳转至这个方法(代码如下):

 /**
  * 请求权限
  * @param id 请求授权的id 唯一标识即可
  * @param permission 请求的权限
  * @param allowableRunnable 同意授权后的操作
  * @param disallowableRunnable 禁止权限后的操作
  */
 protected void requestPermission(int id, String permission, Runnable allowableRunnable, Runnable disallowableRunnable) {
  if(allowableRunnable!=null){
   allowablePermissionRunnables.put(id, allowableRunnable);
  }

  if (disallowableRunnable != null) {
   disallowablePermissionRunnables.put(id, disallowableRunnable);
  }

  //api版本判断
  if (Build.VERSION.SDK_INT >= 23) {
   UiUtils.getInstance().showToast("1");
   //减少是否拥有权限checkCallPhonePermission != PackageManager.PERMISSION_GRANTED
   int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
   if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
    UiUtils.getInstance().showToast("2");
    //弹出对话框接收权限
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
    return;
   } else {
    UiUtils.getInstance().showToast("3");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  } else {
   boolean result = PermissionChecker.checkSelfPermission(this, permission)
     == PermissionChecker.PERMISSION_GRANTED;
   if(!result){
    UiUtils.getInstance().showToast("4");
    //如果未授权
    ActivityCompat.requestPermissions(TakeCameraActivity.this, new String[]{permission}, id);
   }else{
    UiUtils.getInstance().showToast("5");
    if(allowableRunnable!=null){
     allowableRunnable.run();
    }
   }
  }
 }

3.onRequestPermissionsResult方法是响应2中的方法之后执行。执行代码之后,开始执行Runnable中的代码程序。

 @Override
 public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
  super.onRequestPermissionsResult(requestCode, permissions, grantResults);

  if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
   Runnable allowRun = allowablePermissionRunnables.get(requestCode);
   if(allowRun!=null){
    allowRun.run();
   }

  } else {
   Runnable disallowRun = disallowablePermissionRunnables.get(requestCode);
   if(disallowRun!=null){
    disallowRun.run();
   }
  }
 }

以上这篇android检测SD卡读写权限方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

时间: 2018-08-01

快速解决安卓7.0系统写入SD卡权限失败的问题

如图所示,在mainfest文件中声明了SD卡的读和写权限,仍旧报错: <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"></uses-permi

Android权限管理之Permission权限机制及使用详解

前言: 最近突然喜欢上一句诗:"宠辱不惊,看庭前花开花落:去留无意,望天空云卷云舒." 哈哈~,这个和今天的主题无关,最近只要不学习总觉得生活中少了点什么,所以想着围绕着最近面试过程中讨论比较多的一个知识点Android 6.0 权限适配问题来进行学习,不过我不想直接进入这个主题,所以选择先去了解一下Android的Permission权限机制及使用 Android权限机制: 权限是一种安全机制.Android权限主要用于限制应用程序内部某些具有限制性特性的功能使用以及应用程序之间的组

谈谈Android6.0运行时的权限处理

运行时权限介绍 Android 6.0在我们原有的AndroidManifest.xml声明权限的基础上, 又新增了运行时权限动态检测,以下权限都需要在运行时判断: 1.身体传感器 2.日历    3.摄像头 4.通讯录 5.地理位置 6.麦克风 7.电话 8.短信 9.存储空间 在 Android 6.0 中,app 如果想要获得某些权限,会在应用中弹出一个对话框,让用户确认是否授予该权限. 具体的截图如下: 这要做的好处就是运行一个 app 时可以拒绝其中的某些权限,防止 app 触及到你的

解决Android 5.1限制外置SD卡写入权限的问题

在Android开发者网站的 "外部存储技术信息"文档中描述道 : WRITE_EXTERNAL_STORAGE只为设备上的主要外部存储授予写权限,应用程序无法将数据写入二级外部存储设备,除非综合权限指定了应用程序的包目录.这目前只影响双存储设备,如果你的设备有内部存储空间,即通常所说的机身存储,那么你的SD卡就是一个二级外部存储设备. 在Android 4.4中,如果你同时使用了机身存储和SD卡, 那么应用程序将无法在SD卡中创建.修改.删除数据.比如,你无法使用酷我音乐盒下载保存M

详解Android权限管理之Android 6.0运行时权限及解决办法

前言: 今天还是围绕着最近面试的一个热门话题Android 6.0权限适配来总结学习,其实Android 6.0权限适配我们公司是在今年5月份才开始做,算是比较晚的吧,不过现在Android 6.0以上设备越来越多了,所以Android 6.0 权限适配是必不可少的工作,这里主要介绍一下我们公司是如何做Android 6.0权限适配的. Android 6.0以下非运行时权限: 根据上面博客我们很清楚的知道,Android的权限其实就是为了程序之间更加的安全的访问,所以权限有等级之分,比如:No

Android 7.0 运行时权限弹窗问题的解决

Android 7.0系统在运行应用的时候,对权限做了诸多限制,normal, dangerous, signature, signatureOrSystem ,取决于保护级别,在确定是否授予权限时,系统可能采取不同的操作. normal 表示权限是低风险的,不会对系统.用户或其他应用程序造成危害: dangerous 表示权限是高风险的,系统将可能要求用户输入相关信息,才会授予此权限: signature 表示只有当应用程序所用数字签名与声明引权限的应用程序所用数字签名相同时,才能将权限授给它

详解VScode自动补全CSS3前缀插件以及配置无效的解决办法

1.在vscode中搜索Autoprofixer 2.在安装完成之后要配置 在需要添加前缀的css文件上,右键点击命令面板,输入Autoprefixer CSS就好啦 ps: 如果想要兼容性最好的话,需要在设置配置文件setting.json里加上 (打开设置->搜索autoprefixer->点击在setting.json里编辑) //这是比较完整的兼容配置,可以根据自己的情况有选择的复制![在这里插入图片描述](https://img-blog.csdnimg.cn/20200322110

详解DB2 sqlstate 57016 SQLCODE=-668 原因码 "7"错误的快速解决办法

以上所述是小编给大家介绍的详解DB2 sqlstate 57016 SQLCODE=-668 原因码 "7"错误的快速解决办法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的.在此也非常感谢大家对我们网站的支持!

android6.0运行时权限完美封装方法

前几天看了郭大神的运行时权限的专讲,深受启发,由于现在基于目前项目中的运行时权限封装的还不是那么完美,趁着郭神建议的还是历历在目.于是把它完整的敲了下来.并在此基础上添加上自己的一些见解,封装成一个完整的demo,希望与大家进行交流与. 在这里我进行了简单的在activity中简单进行获取权限和工具类封: 某一个权限被禁止或者是所有的权限被禁止,这里我做了去到烯烃界面去设置的处理: 如果要开启多个权限的话,则可能不同的手机显示的效果不同,有些手机在权限Dialog上显示需要获取权限的个数,但有些

详解Android数据存储之Android 6.0运行时权限下文件存储的思考

前言: 在我们做App开发的过程中基本上都会用到文件存储,所以文件存储对于我们来说是相当熟悉了,不过自从Android 6.0发布之后,基于运行时权限机制访问外置sdcard是需要动态申请权限,所以以往直接sdcard根目录上直接新建了一个xxx/cache/目录来做文件存储就会不是那么容易控制了,所以有必要重新认识一下Android文件存储的相关知识了. 背景: 有关外置sdcard的读写权限 <uses-permission android:name="android.permissi

详解Android6.0运行时权限管理

自从Android6.0发布以来,在权限上做出了很大的变动,不再是之前的只要在manifest设置就可以任意获取权限,而是更加的注重用户的隐私和体验,不会再强迫用户因拒绝不该拥有的权限而导致的无法安装的事情,也不会再不征求用户授权的情况下,就可以任意的访问用户隐私,而且即使在授权之后也可以及时的更改权限.这就是6.0版本做出的更拥护和注重用户的一大体现. 一.认知 今天我们就来学习下Android6.0的权限管理. Android6.0系统把权限分为两个级别: 一个是Normal Permiss

详解vuex数据传输的两种方式及this.$store undefined的解决办法

这个问题很乌龙,但也很值得记录一下, 原因是main.js中import store时将store的首字母写成了大写. 问题版本的如下所示: import Store from './store' 我大概看了一下, vue似乎不支持在import部分包含带首字母大写的变量,所有import进来的对象必须要小写,我试过把router改成Router, 发现路由部分也会受影响. 这种方式是典型的将vuex值及其中的方法暴露给所有的组件使用, 即将vuex视作一个"全局变量", 但vuex也

详解vue-cli 快速搭建单页应用之遇到的问题及解决办法

一.报错内容类似:Expected indentation of 0 spaces but found 4 将 build 文件下的 webpack.base.conf.js 文件里面的下面一段代码注释掉(eslint-loader内容),重新运行. 二.报错内容: Newline required at end of file but not found 只需要在 js css 等后面再加一行(空行)就可以了 或者将 build 文件下的 webpack.base.conf.js 文件里面的下

详解Android运行时权限及APP适配方法

Android 6.0起,Android加强了权限管理,引入运行时权限概念.对于: 1. Android 5.1(API 22)及以前版本,应用权限必须声明在AndroidManifest.xml中,应用在安装时,Android会列出其所需的所有权限供用户确认安装. 2. Android 6.0(API 23)及以后版本,应用权限必须声明在AndroidManifest.xml中,但权限分为普通权限(Normal Permissions)和危险权限(Dangerous Permissions),