申请权限SDK>=23

本文详细介绍了在Android系统中如何检查和请求应用所需的各种权限,包括定位、相机、读写外部存储和读取电话状态等。通过代码示例,展示了如何使用Android的权限API来动态请求权限,并处理权限请求的结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

getPersimmions();
@TargetApi(23)
    private void getPersimmions() {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            ArrayList<String> permissions = new ArrayList<String>();
            /***
             * 定位权限为必须权限,用户如果禁止,则每次进入都会申请
             */
            // 定位精确位置
            if (checkSelfPermission(android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
                permissions.add(android.Manifest.permission.ACCESS_FINE_LOCATION);
            }
            if (checkSelfPermission(android.Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
                permissions.add(android.Manifest.permission.ACCESS_COARSE_LOCATION);
            }
            if (checkSelfPermission(Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {
                permissions.add(Manifest.permission.CAMERA);
            }
            /*
             * 读写权限和电话状态权限非必要权限(建议授予)只会申请一次,用户同意或者禁止,只会弹一次
             */
            // 读写权限
            if (addPermission(permissions, android.Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
                permissionInfo += "Manifest.permission.WRITE_EXTERNAL_STORAGE Deny \n";
            }
            // 读取电话状态权限
            if (addPermission(permissions, Manifest.permission.READ_PHONE_STATE)) {
                permissionInfo += "Manifest.permission.READ_PHONE_STATE Deny \n";
            }

            if (permissions.size() > 0) {
                requestPermissions(permissions.toArray(new String[permissions.size()]), SDK_PERMISSION_REQUEST);
            } else {
//                    getAddrLocation();
            }
        } else {
//                getAddrLocation();
        }
    }
@TargetApi(23)
private boolean addPermission(ArrayList<String> permissionsList, String permission) {
    if (checkSelfPermission(permission) != PackageManager.PERMISSION_GRANTED) { // 如果应用没有获得对应权限,则添加到列表中,准备批量申请
        if (shouldShowRequestPermissionRationale(permission)) {
            return true;
        } else {
            permissionsList.add(permission);
            return false;
        }

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

                    // permission was granted, yay! Do the
                    // contacts-related task you need to do.
//                    getAddrLocation();
                } else {

                    // permission denied, boo! Disable the
                    // functionality that depends on this permission.
//                    RxCenter.INSTANCE.removeCompositeSubscription(TaskIds.addrTaskId);

                }
                return;
            }
        }
    }

 

 

Android SDK版本大于等于31 (Android 11) 的应用开发中,权限管理变得更加严格,以保护用户的隐私。如果你需要申请权限,比如读取联系人信息,你需要在运行时请求权限,而不是像以前那样在AndroidManifest.xml文件中直接声明。 以下是步骤: 1. **动态权限检查**: 使用`ContextCompat.checkSelfPermission()`方法检查应用是否已经获得了某项权限。如果尚未获得,你需要用户授权。 ```java if (ActivityCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS) != PackageManager.PERMISSION_GRANTED) { // 请求权限 } ``` 2. **请求权限**: 如果权限缺失,通过`ActivityCompat.requestPermissions()`方法发起请求。记得在用户同意后更新权限状态,可以使用`onRequestPermissionsResult()`回调。 ```java ActivityCompat.requestPermissions( this, new String[]{Manifest.permission.READ_CONTACTS}, MY_PERMISSIONS_REQUEST_READ_CONTACTS); ``` 3. **处理结果**: 用户接受或拒绝请求后,你需要处理`onRequestPermissionsResult()`方法中的结果,根据用户的选择决定如何继续操作。 ```java @Override public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) { switch (requestCode) { case MY_PERMISSIONS_REQUEST_READ_CONTACTS: { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 权限已授予,可以访问联系人了 } else { // 拒绝或权限未授予,这里可以显示错误消息或采取其他备用方案 } return; } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值