Android动态权限申请

Google官方链接地址:

https://developer.android.google.cn/training/permissions/requesting.html#perm-request

样例简要代码:

//要检查您是否具有某项权限,请调用 ContextCompat.checkSelfPermission() 方法
//如果应用具有此权限,方法将返回 PackageManager.PERMISSION_GRANTED,并且应用可以继续操作。
//如果应用不具有此权限,方法将返回 PERMISSION_DENIED,且应用必须明确向用户要求权限。
if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED
        || ContextCompat.checkSelfPermission(this, Manifest.permission.MOUNT_UNMOUNT_FILESYSTEMS) != PackageManager.PERMISSION_GRANTED) {

    //为了帮助查找用户可能需要解释的情形,Android 提供了一个实用程序方法,即 shouldShowRequestPermissionRationale()。
    //如果应用之前请求过此权限但用户拒绝了请求,此方法将返回 true。
    //注:如果用户在过去拒绝了权限请求,并在权限请求系统对话框中选择了 Don't ask again 选项,此方法将返回 false。
    //如果设备规范禁止应用具有该权限,此方法也会返回 false。
    if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)
            || ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.MOUNT_UNMOUNT_FILESYSTEMS)) {

        //

    } else {

        //如果应用尚无所需的权限,则应用必须调用一个 requestPermissions() 方法,以请求适当的权限。
        //应用将传递其所需的权限,以及您指定用于识别此权限请求的整型请求代码。
        //此方法异步运行:它会立即返回,并且在用户响应对话框之后,系统会使用结果调用应用的回调方法,将应用传递的相同请求代码传递到 requestPermissions()。
        //注:当您的应用调用 requestPermissions() 时,系统将向用户显示一个标准对话框。
        //您的应用无法配置或更改此对话框。
        //如果您需要为用户提供任何信息或解释,您应在调用 requestPermissions() 之前进行,如解释应用为什么需要权限中所述。
        ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.MOUNT_UNMOUNT_FILESYSTEMS}, 2001);

    }
} else {
    readFile();
}
@Override
public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
    switch (requestCode) {
        case 2001: {
            // 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.
                readFile();
            } else {

                // permission denied, boo! Disable the
                // functionality that depends on this permission.
            }
            return;
        }

        // other 'case' lines to check for other
        // permissions this app might request
    }
}



Android动态权限申请Android 6.0引入,不同版本权限机制有所不同,以下是相关的实现方法和使用指南: ### 权限声明 在`AndroidManifest.xml`中声明所有需要的权限,这是权限申请的前提。例如: ```xml <manifest xmlns:android="http://schemas.android.com/apk/res/android"> <uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.RECORD_AUDIO" /> <!-- 其他权限 --> <application ...> ... </application> </manifest> ``` 此步骤确保应用向系统表明需要使用的权限,是任何权限申请方式的基础 [^3]。 ### 不同版本权限适配 - **Android 6.0及以上**:引入动态权限机制,对于危险权限,除了在`AndroidManifest.xml`中声明,还需要在运行时请求。 - **Android 10**:引入分区存储,对存储权限管理有较大改变。 - **Android 13**:将存储权限细分为媒体文件权限。 - **Android 14**:进一步优化权限管理,新增了如`USE_FULL_SCREEN_INTENT`等权限配置,完整权限声明示例可参考`app/src/main/AndroidManifest.xml` [^1][^2]。 ### 核心权限申请实现 以XXPermissions库为例,可用于处理Android 14数据访问权限、存储权限申请。对于健康数据权限请求等场景有相应的实现方式 [^1]。 ### 单个权限请求示例 以相机权限为例,可通过以下方式请求: ```java // 检查权限是否已经授予 if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { // 如果没有授予,则请求权限 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, MY_PERMISSIONS_REQUEST_CAMERA); } ``` ### 权限解释策略 当用户拒绝权限请求后,再次请求时可以向用户解释为什么需要该权限。示例代码如下: ```java fun showPermissionRationale() { if (ActivityCompat.shouldShowRequestPermissionRationale( this, Manifest.permission.ACCESS_FINE_LOCATION )) { CarToast.makeText( this, "需要位置权限提供实时导航服务", CarToast.LENGTH_LONG ).show() } } ``` 此代码检查是否需要向用户解释请求位置权限的原因,并给出相应提示 [^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值