安卓权限管理

一、权限请求和回调
1:权限请求
if (ContextCompat.checkSelfPermission(content, Manifest.permission.CALL_PHONE)!= PackageManager.PERMISSION_GRANTED) {
// 最后的100是请求码对应回调方法的请求码,该码对应的时该权限
ActivityCompat.requestPermissions(content,new String[]{Manifest.permission.READ_CONTACTS}, 100);
} else {
Toast.makeText(content, “你已经有该权限了”, Toast.LENGTH_LONG).show();
}

2:权限回调
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode) {
case 100:
// 100的请求码对应的是上面读取通讯录的权限
// 判断是否同意授权,PERMISSION_GRANTED 这个值代表的是已经获取了权限
if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Toast.makeText(content, “你同意授权”, Toast.LENGTH_LONG).show();
} else {
Toast.makeText(content, “你拒绝了授权,请在设置中打开”, Toast.LENGTH_LONG).show();
}
break;
}
}

二、权限组的申请和回调(参考郭神的《第一行代码》)
1; 多个权限像上面那样就比较麻烦了,可以放在数组中一起遍历申请

private List unPermissionList = new ArrayList(); //先定义一个数组,申请未得到授权的权限列表

//然后权限判断和申请
public void checkPermission0() {
unPermissionList.clear();//清空申请的没有通过的权限
//逐个判断是否还有未通过的权限
for (int i = 0; i < permissionList.length; i++) {
if (ContextCompat.checkSelfPermission(content, permissionList[i]) !=
PackageManager.PERMISSION_GRANTED) {
unPermissionList.add(permissionList[i]);//添加还未授予的权限到unPermissionList中
}
}

    //未授予权限的size()如果大于0则说明有权限没有通过,需要申请
    if (unPermissionList.size() > 0) {
        ActivityCompat.requestPermissions( this,permissionList, 100);
        //有权限未通过,可以关闭应用或者其他操作
    } else {
        //权限已经都通过了,可以将程序继续打开了
    }
}

2:遍历回调
//grantResults[i] ==0 表示允许权限,-1表示禁止了
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,
int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
Log.i(TAG,“申请结果反馈”);
boolean hasPermissionDismiss = false;
if (100 == requestCode) {
for (int i = 0; i < grantResults.length; i++) {
if (grantResults[i] == -1) {
hasPermissionDismiss = true; //有权限没有通过
Log.i(TAG,“有权限没有被通过”);
break;
}
}
}
if (hasPermissionDismiss) {
//如果有没有被允许的权限,被禁止了
//引导跳转该应用的设置界面
settingPermission();
} else {
//权限已经都通过了,可以将程序继续打开了
Log.i(TAG, “onRequestPermissionsResult 权限都已经申请通过”);
}
}

public void settingPermission(){
Log.i(TAG,"mPackName: " + AddressActivity.this.getPackageName());
if (mPermissionDialog == null) {
mPermissionDialog = new AlertDialog.Builder(this)
.setMessage(“已禁用权限,请手动授予”)
.setPositiveButton(“设置”, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {

                 //对于一个app,若用户已经手动拒绝权限多次或者禁用不在提示。此时可以加入以下代码跳转到该app设置界面引导重新打开该app权限.     
                      Intent intent = new Intent();
                        intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
                        Uri uri1 = Uri.fromParts("package", context.getPackageName(), null);
                        intent.setData(uri1);
                        startActivity(intent);
                        
                    }
                })
                .setNegativeButton("取消", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        //关闭页面或者做其他操作
                        mPermissionDialog.cancel();
                    }
                })
                .create();
    }
    mPermissionDialog.show();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值