Android6.0系统动态获取权限<一>

       Android6.0系统开始有了动态权限申请的问题。系统不会在安装应用的时候获取所有权限,而是在用到的地方需要获得用户的同意后才开启,也就是说开发者在需要用到一些权限危险权限的时候,需要动态的去获取权限,如果不动态获取,只是在AndroidManifest.xml文件中申请了权限,在程序运行的时候会报java.lang.SecurityException:Permission Denial:reading com.android.providers.media.MediaProvider的

错误。

    所以开发者在需要用到一些危险权限的时候,首先要判断该权限是否开启,如果未开启,则动态申请权限。具体实现过程是:

1.判断权限是否开启:

//表示权限已授权
ContextCompat.checkSelfPermission(activity, permission) == PackageManager.PERMISSION_GRANTED
//表示权限未授权
ContextCompat.checkSelfPermission(activity, permission) == PackageManager.PERMISSION_DENIED)


2.如果该权限还未开启,动态申请权限:

//动态申请权限(requestCode主要是为了后边onRequestPermissionResult方法中使用)
ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.CALL_PHONE}, requestCode);

3.如果要开启多个权限,可以通过一个字符串数组:

ActivityCompat.requestPermissions(context,new String[]{
        Manifest.permission.CALL_PHONE,
        Manifest.permission.CALL_PHONE,
        Manifest.permission.READ_CONTACTS},
        requestCode);

4.获取权限后,会有一个回调,在onRequestPermissionResult方法中可以判断权限是否获取成功

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    switch (requestCode) {
        case CODE_SINGLE://获取单个权限
            if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {//权限被打开
                Log.i("ruxing", "获取" + permissions[0] + "的权限打开了");
            } else {
                Log.i("ruxing", "获取" + permissions[0] + "的权限被拒了");
            }
            break;
        case CODE_MULTI://获取多个权限
            if (grantResults.length > 0) {
                for (int i = 0; i < grantResults.length; i++) {
                    int grantResult = grantResults[i];
                    if (grantResult == PackageManager.PERMISSION_DENIED) {//权限被拒绝
                        Log.i("ruxing", "获取" + permissions[i] + "的权限被拒了");
                    } else {
                        Log.i("ruxing", "获取" + permissions[i] + "的权限打开了");
                    }
                }
            }
            break;
    }
}


完整代码:https://github.com/ruxing1102/GetPermission

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值