Bootstrap

Android 6.0动态申请权限实践及遇到的坑

Android 6.0已经出了一段时间了,最近在6.0上遇到一个权限问题,在博客上稍作总结

1.在6.0系统上权限被分为NormalPermission(普通权限)以及DangerousPermissions(危险权限)
2.普通权限只需要按照我们之前正常的申请方式即:在manifest文件中声明即可。而涉及到危险权限时,如果不做动态检测及申请,那么系统就会直接抛错,提示你没有这项权限,即使你在manifest文件中已经声明了这项权限的使用
3.那么如何动态检测,并且申请这些DangerousPermissions呢?在Android6.0中,检测相关权限可以使用:
if (ContextCompat.checkSelfPermission(activity, "权限名称")== PackageManager.PERMISSION_DENIED) {}
这种方法下,如果if中判断为true的话,就说明是危险权限,那么接下来就可以进行申请权限的操作:
    private static final int Permission_Request_Code = 1000;

    public void requestPermission(String[] permissions) {
        ActivityCompat.requestPermissions(this, permissions, Permission_Request_Code);
    }

这个数组类型的参数就是想要申请的权限,可以通过Manifest类下面的Permission类获取,都是静态常量,注意Manifest应该导Android下的包。至此Android6.0下面的DengeroutPermission的检测和申请就完成了,但是需要注意的是这个权限申请的操作是异步的,当申请权限后,会回调activity或者fragment的onRequestPermissionsResult方法,如下:
    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions, int[]
            grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }

三个参数的分别代表请求码,请求的权限,以及对应的请求结果,请求结果可以对应PackageManager中的PERMISSION_GRANTED及PERMISSION_DENIED分别代表授权通过与拒绝。

接下来记录我在使用时遇到的一个坑,当我在开发时实践时,随意申请了两个危险权限,分别为WRITE_EXTERNAL_STORAGE和READ_PHONE_STATE,但是在request权限时,并不是预想的显示两次弹窗要求用户授权,而是只弹了一次READ_PHONE_STATE这个权限的提示,调试过程比较抓狂,最终结论是,如果需要动态申请权限,那么在Manifest文件中必须先静态声明才行,即必须先静态注册后才能动态申请,否则是不会向用户申请权限的。

最后推荐下鸿阳大神封装的库:https://github.com/hongyangAndroid/MPermissions.

;