Android6.0运行时权限(一)

一.运行时权限特点

   对于安卓6.0以下的版本(targetSdkVersion小于23),在安装的时候,根据权限声明产生一个权限列表,用户只有在同意之后才能完成app的安装,造成了我们想要使用某个app,就要默默忍受其一些不必要的权限。

   而在安卓6.0以后targetSdkVersion大于等于23,我们可以直接安装APP,当APP需要我们授予权限的时候,我们可以自行选择授权与否。

二.权限分类

    Google将权限分为两类,一类是Normal permission,这类权限一般不涉及用户隐私,是由系统自动授权的。另一类是Dangerous permission,一般是涉及到用户隐私的,需要用户进行授权。如下图所示,是危险权限。这里需要注意的是,安卓对危险权限的授权是按组进行的,比如用户同意授权了READ_CALENDER权限,那么也默认授权了WRITE_CALENDER。


三.运行时授权开发流程

1.在Manifest.xml文件中声明使用的权限

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>

2.检查系统版本

 if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
            //不需要授权
        }

Build类主要用于从 系统 属性中提取设备硬件和版本信息。它包含2个内部类

1、Build.VERSION 各种版本代号字符串

2、Build.VERSION_CODES 目前已知的版本代码的枚举类


3.检查权限是否被授权

ContextCompat.checkSelfPermission(this,Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED

这里,checkSelfPermission主要用于检测某个权限是否已经被授予,方法返回值为PackageManager.PERMISSION_GRANTED或者PackageManager.PERMISSION_DENIED,当返回DENIED就需要进行申请授权了。其中第一个参数是activity,第二个参数是权限名。

4.申请权限

ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, REQUESTCODE);

第一个参数是activity第二个参数是申请授权的权限组,第三个参数是请求码。

5.处理回调函数
 @Override
    public void onRequestPermissionsResult(int requestCode,String[] permissions, int[] grantResults) {
        switch (requestCode) {
            case REQUESTCODE:
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    //所需权限的操作
                } else {
                    Toast.makeText(this, "你拒绝了这个权限", Toast.LENGTH_SHORT).show();
                }
                break;
            default:
        }
    }

重写activity类的onRequestPermissionsResult()函数,处理授权结果。参数中的requestCode就是请求权限中的请求码。授权结果存储在grantResults中。

四.举个例子

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
                ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CALL_PHONE}, 1);
            }
            else
            call();
        }
        else {
            call();

        }
       

    }

    private void call() {
        try {
            Intent intent = new Intent(Intent.ACTION_CALL);
            intent.setData(Uri.parse("tel:10086"));
            startActivity(intent);
        } catch (SecurityException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode,String[] permissions, int[] grantResults) {
        switch (requestCode) {
            case 1:
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    call();
                } else {
                    Toast.makeText(this, "你拒绝了这个权限", Toast.LENGTH_SHORT).show();
                }
                break;
            default:
        }
    }




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值