android6.0权限申请学习笔记

从android6.0开始,访问危险权限需要用户明确授予。关于6.0的权限讲解可以查看官网的介绍,本文主要记录具体的使用步骤。

1、首先需要在manifest.xml文件中列出所需权限,如下所示:

    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.CAMERA"/>
    <uses-permission android:name="android.permission.INTERNET"/><!-- 访问网络是正常权限,只需要在manifest文件中声明即可-->
2、在Activity中,首先检查权限,使用
ContextCompat.checkSelfPermission(context,permission)
该方法用于判断是否已授权,返回值为

PackageManager.PERMISSION_GRANTED(同意)或PackageManager.PERMISSION_DENIED(拒绝),若权限未授予,则申请权限。
3、申请授权,使用ActivityCompat.requestPermissions方法申请权限,如下所示:
ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},PERMISSION_REQUEST_CODE);
第一个参数为Context,第二个参数为所需的权限数组,第三个参数是请求码,用于回调时使用。

权限检查与申请完整代码如下:
private void checkPermissions(){
        String[] permissionArray=new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE,
        Manifest.permission.READ_EXTERNAL_STORAGE,
        Manifest.permission.CAMERA,
        Manifest.permission.ACCESS_FINE_LOCATION};//所需要的危险权限数组
        List<String> needRequestPermission=new ArrayList<>();//需要申请的权限列表
        List<String> noGrantedPermission=new ArrayList<>();//已拒绝权限列表
        for(String permission:permissionArray){
        int checkPermission=ContextCompat.checkSelfPermission(this,permission);//检查权限,返回值为PackageManager.PERMISSION_GRANTED(同意)或PackageManager.PERMISSION_DENIED(拒绝)
            if(checkPermission!= PackageManager.PERMISSION_GRANTED){//若未同意
                if(ActivityCompat.shouldShowRequestPermissionRationale(this,permission)){//shouldShowRequestPermissionRationale用于用户已经拒绝过,再次申请时需要向用户解释为什么需要这些权限
                    noGrantedPermission.add(permission);//将用户拒绝的权限加入拒绝列表中
                }else {
                    needRequestPermission.add(permission);//将需要申请的权限加入申请列表中
                }
            }
        }
        if(needRequestPermission.size()>0){
            ActivityCompat.requestPermissions(this,needRequestPermission.toArray(new String[needRequestPermission.size()]),PERMISSION_REQUEST_CODE);
        }
        if(noGrantedPermission.size()>0){
            final List<String> permissions=noGrantedPermission;
            showRationaleDialog("应用所必需权限未打开,请打开权限", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    ActivityCompat.requestPermissions(MainActivity.this,permissions.toArray(new String[permissions.size()]),PERMISSION_REQUEST_CODE);
                }
            });
        }
    }

4、申请权限的回调
@Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        if(requestCode==PERMISSION_REQUEST_CODE){
		//TODO
		}else{
		//TODO
		}
	}
具体实现如下:
@Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
//        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if(requestCode==PERMISSION_REQUEST_CODE){
            if(allPermissionGranted(grantResults)){
                Toast.makeText(MainActivity.this,"授权成功!",Toast.LENGTH_SHORT).show();
            }else{
                showRationaleDialog("请打开应用所需权限", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        Intent intent=new Intent();//打开应用管理界面,修改权限
                        intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
                        intent.setData(Uri.parse("package:"+getPackageName()));
                        startActivity(intent);
                    }
                });
            }
        }
    }
    private boolean allPermissionGranted(int[] grantResults){
        for(int i=0;i<grantResults.length;i++){
            if(grantResults[i]!=PackageManager.PERMISSION_GRANTED){
                return false;
            }
        }
        return true;
    }
自定义dialog,用于用户拒绝之后,弹框提醒用户打开权限:
private void showRationaleDialog(String message,DialogInterface.OnClickListener onClickListener){
        new AlertDialog.Builder(MainActivity.this)
                .setMessage(message)
                .setPositiveButton("OK", onClickListener)
                .setNegativeButton("Cancel",null)
                .create()
                .show();
    }

以上是权限申请的整个流程,需要注意的是,targetSDK>=23时是必须动态申请权限的,若targetSDK<23,则只需要在manifest.xml文件中配置即可,不过对于targetSDK<23,使用
checkSelfPermission可能会导致应用崩溃,可以在代码中判断Build.VERSION.SDK_INT是否小于23。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Anroid6.0权限问题 apk22之后Android把一些涉及用户个人信息的权限都做了默认没有权限处理,需要用户确认才可以: 用户不需要在安装软件的时候一次性授权所有申请权限,而是可以在软件的使用过程中再对某一项权限申请进行授权。举例说明:一款相机应用在运行时申请了地理位置定位权限,就算我拒绝了这个权限,我仍然可以使用这款应用的其他功能,不用像6.0之前无法安装它。 解决办法: ● 投机取巧 如果我们不想使用6.0或者7.0的新特性,那么我们把targetSdkVersion设置22,就可以很好的避开动态配置运行时权限。而targetSdkVersion设置为22,并不影响其在Android 6.0或7.机制上使用,因为高版本兼容低版本。 解决办法:(简单到没朋友) AndroidAcp ● Acp 为 Android check permission 缩写,此库简化Android 6.0 系统复杂的权限操作而编写。 特点 ● 支持批量权限申请,不需要重写 onRequestPermissionsResult 方法,Activity 与 Fragment 中用法一致,一句话搞定。 ● 处理权限拒绝,或勾选不再询问,导致不能正常使用功能的提示框,支持跳转设置权限界面开启权限,所有提示框文字可自定义。 ● #使用Gradle构建时添加一下依赖即可: compile 'com.mylhyl:acp:1.1.7' 怎麽用? Acp.getInstance(this).request(new AcpOptions.Builder() .setPermissions(Manifest.permission.WRITE_EXTERNAL_STORAGE , Manifest.permission.READ_PHONE_STATE , Manifest.permission.SEND_SMS) /*以下为自定义提示语、按钮文字 .setDeniedMessage() .setDeniedCloseBtn() .setDeniedSettingBtn() .setRationalMessage() .setRationalBtn()*/ .build(), new AcpListener() { @Override public void onGranted() { writeSD(); getIMEI(); } @Override public void onDenied(List permissions) { makeText(permissions.toString() + "权限拒绝"); } }); ***************************** 二維碼的使用: ZXING ● 可打开默认二维码扫描页面 ● 支持对图片Bitmap的扫描功能 ● 支持对UI的定制化操作 ● 支持对条形码的扫描功能 ● 支持生成二维码操作 ● 支持控制闪光灯开关 ● 集成默认的二维码扫描页面 在具体介绍该扫描库之前我们先看一下其具体的使用方式,看看是不是几行代码就可以集成二维码扫描的功能。 ● 在module的build.gradle中执行compile操作 compile 'cn.yipianfengye.android:zxing-library:2.1' ● 1 ● 1 ● 在Application中执行初始化操作 @Override public void onCreate() { super.onCreate(); ZXingLibrary.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值