博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android6.0运行时权限详解
阅读量:4286 次
发布时间:2019-05-27

本文共 4689 字,大约阅读时间需要 15 分钟。

1. 运行时获得权限:

  Android 5.0之前是注册即可获取权限,Android 5.0之后安装时可以关闭某些权限,Android 6.0开始,一些隐私权限总在第一次运行时提示是否授权。

2. 检查是否获得权限:

ContextCompat.checkSelfPermission(context,permission)方法,返回值有两种:

PackageManager.PERMISSION_GRANTED
PackageManager.PERMISSION_DENIED

int permissionCheck = ContextCompat.checkSelfPermission(this,        Manifest.permission.WRITE_CALENDAR);   if (permissionCheck == PackageManager.PERMISSION_GRANTED) {     Toast.makeText(PermissionActivity.this, "hava this permission", Toast.LENGTH_SHORT).show();   }else {     Toast.makeText(PermissionActivity.this, "no this permission", Toast.LENGTH_SHORT).show();   }

3. 请求权限:

ActivityCompat.requestPermissions(activity,permissions,requestCode)

第二个参数是一个String数组;
第三个参数是请求码便于在onRequestPermissionsResult 方法中根据requestCode进行判断。

4. 请求权限后的回调:

请求权限后会回调onRequestPermissionsResult方法,在activity中重写onRequestPermissionsResult(requestCode,permissions,grantResults)方法 ;

grantResults 是 int 类型的数组每个值为
PackageManager.PERMISSION_DENIED 分别对应permissions的每个请求

@Override    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {        switch (requestCode) {            case MY_PERMISSIONS_REQUEST_READ_CONTACTS: {                // If request is cancelled, the result arrays are empty.                if (grantResults.length > 0                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {                } else {                }            }        }    }

5. 告诉用户为何需要权限:

ActivityCompat.shouldShowRequestPermissionRationale(activity,permission) 这个方法是在用户拒绝权限后返回true. 也就是说:用户第一次点击一个需要权限的地方,该方法返回false(因为用户没拒绝~),当用户拒绝掉该权限,下次点击此权限处,该方法会返回true.可在里面进行对该权限的说明,然后弹出权限让用户选择,并且对话框有don’t ask again选项

@OnClick(R.id.btn_check)    public void onClick() {        //判断是否有权限        if (ContextCompat.checkSelfPermission(PermissionActivity.this,                Manifest.permission.READ_CONTACTS)                != PackageManager.PERMISSION_GRANTED) {            //当用户拒绝掉权限时.            if (ActivityCompat.shouldShowRequestPermissionRationale(PermissionActivity.this,                    Manifest.permission.READ_CONTACTS)) {                Toast.makeText(PermissionActivity.this, "true", Toast.LENGTH_SHORT).show();                AlertDialog dialog = new AlertDialog.Builder(this).setTitle("该权限保证手机不会爆炸^ ^").setPositiveButton("我需要此权限!", new DialogInterface.OnClickListener() {                    @Override                    public void onClick(DialogInterface dialog, int which) {                        ActivityCompat.requestPermissions(PermissionActivity.this,                                new String[]{Manifest.permission.READ_CONTACTS},                                MY_PERMISSIONS_REQUEST_READ_CONTACTS);                    }                }).setNegativeButton("炸吧炸吧~", new DialogInterface.OnClickListener() {                    @Override                    public void onClick(DialogInterface dialog, int which) {                        Toast.makeText(PermissionActivity.this, "准备爆炸了", Toast.LENGTH_SHORT).show();                    }                }).show();            } else {                Toast.makeText(PermissionActivity.this, "false", Toast.LENGTH_SHORT).show();                ActivityCompat.requestPermissions(PermissionActivity.this,                        new String[]{Manifest.permission.READ_CONTACTS},                        MY_PERMISSIONS_REQUEST_READ_CONTACTS);            }        }    }

6.用户选择do’t ask again 后

ActivityCompat.shouldShowRequestPermissionRationale(activity,permission) 方法一直返回false,并且ActivityCompat.requestPermissions不会弹出对话框,系统直接deny,并回调onRequestPermissionsResult方法

@Override    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {        switch (requestCode) {            case MY_PERMISSIONS_REQUEST_READ_CONTACTS: {                // If request is cancelled, the result arrays are empty.                if (grantResults.length > 0                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {                } else {                    showDialog();                   // Toast.makeText(PermissionActivity.this, "request false", Toast.LENGTH_SHORT).show();                }            }        }    }    private void showDialog() {        AlertDialog dialog = new AlertDialog.Builder(this).setTitle("还可以手动开启哦~").setMessage("可以前往设置->app->myapp->permission打开").setPositiveButton("确定!", new DialogInterface.OnClickListener() {            @Override            public void onClick(DialogInterface dialog, int which) {            }        }).show();    }

这里写图片描述

7. 用户接受权限

这里写图片描述

8.补充

android权限有normal和dangerous两种 normal系统会自动给予权限,dangerous需要用户选择.Normal and Dangerous Permissions

用户手动开启权限:
这里写图片描述

转载地址:http://mtpgi.baihongyu.com/

你可能感兴趣的文章
iOS之coreData的原理和使用以及coreData中的多线程问题(二)
查看>>
iOS之支付宝集成(二)
查看>>
java基础(一)Java学习路线
查看>>
iOS之苹果自带的json解析NSJSONSerialization(序列化)
查看>>
iOS中坐标转换
查看>>
java 基础二
查看>>
java基础(三)方法/数组/堆栈/
查看>>
java基础(四)二维数组/
查看>>
java基础(五)面向对象/类/对象/形式参数/局部和成员变量
查看>>
java基础(六)关键字/private/this/static/构造方法/
查看>>
java基础(七)/面向对像
查看>>
java基础(八)Math/代码块/继承成员方法指南的关系/继承中成员变量之间的关系/方法的重写/继承中构造方法之间的关系/this和super的区别
查看>>
iOS之AFNetWorking基本用法(一)上传、下载
查看>>
java基础(九)关键字final/多态/抽象类/关键字abstract/接口
查看>>
java中的错误集合
查看>>
java基础(十)形式参数和返回值/链式编程/包/权限修饰符/内部类
查看>>
java集成开发环境eclipse/MyEclipse
查看>>
C语言char *p 和 cha'r p[10]的区别/sizeof和strlen的区别
查看>>
iOS发布新应用/更新新版本的流程
查看>>
java的API/Object
查看>>