安卓知识点-动态权限(A6,A13)

本文介绍了在Android13之前与之后,针对存储权限的不同声明方式,如READ_EXTERNAL_STORAGE和新的READ_MEDIA_*权限。同时,详细阐述了在Android6.0及以上版本中如何进行危险权限的动态申请,包括检查权限、发起请求和处理回调的方法。
摘要由CSDN通过智能技术生成

1:清单文件AndroidManifest.xml声明:


    <!--Android13以前  -->
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"  
        android:maxSdkVersion="32"></uses-permission>

    <!--Android13  音乐和音频-->
    <uses-permission android:name="android.permission.READ_MEDIA_AUDIO">
    </uses-permission>
    <!--    照片和视频-->
    <uses-permission android:name="android.permission.READ_MEDIA_IMAGES">
    </uses-permission>
    <uses-permission android:name="android.permission.READ_MEDIA_VIDEO">
    </uses-permission>

2:代码实现:检查-请求-响应

安卓在6.0新增了危险权限动态申请,使用步骤如下:

checkSelfPermission():判断权限是否授权
requestPermissions():发起权限的申请
shouldShowRequestPermissionRationale():权限是否被永久拒绝
onRequestPermissionsResult():权限授权回调
在非Activity页面:可以通过ContextCompat或者ActivityCompat.checkSelfPermission检查

2.1检查:

    public Boolean checkPermission(Activity activity,String permissionName){
        int result = ContextCompat.checkSelfPermission(activity, permissionName);
        Log.d(TAG,"result:"+result);
        if(result!= PackageManager.PERMISSION_GRANTED)
            return true;//拒绝
        else
            return false;//同意
    }

2.2请求:

        //        2 :请求权限
        Log.d(TAG,"Build.VERSION.SDK_INT:"+Build.VERSION.SDK_INT);
        if (Build.VERSION.SDK_INT >= 23&&Build.VERSION.SDK_INT<33) {
            Log.d(TAG,"32-请求存储权限");
            if (checkPermission(MainActivity.this, Manifest.permission.READ_EXTERNAL_STORAGE)){
                ActivityCompat.requestPermissions(MainActivity.this, new String[]{
                        Manifest.permission.READ_EXTERNAL_STORAGE
                }, 1);
            }
        }else if(Build.VERSION.SDK_INT >= 33){
            Log.d(TAG,"33-请求新版权限");
            if (checkPermission(MainActivity.this, Manifest.permission.READ_MEDIA_IMAGES)){
                ActivityCompat.requestPermissions(MainActivity.this, new String[]{
                        Manifest.permission.READ_MEDIA_IMAGES
                }, 1);
            }
        } else {
            Toast.makeText(MainActivity.this, "直接进行逻辑", Toast.LENGTH_LONG).show();
        }

2.3响应

    //        3 :  响应请求权限
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
                                           @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        switch (requestCode){
            case 1:
                if(grantResults.length>0&&grantResults[0]==PackageManager.PERMISSION_GRANTED){
//权限被用户同意了,执行后面逻辑
                    Toast.makeText(MainActivity.this,"用户同意了这个权限",
                            Toast.LENGTH_LONG).show();
                }
                else
                    Toast.makeText(MainActivity.this,"用户否定了这个权限",
                            Toast.LENGTH_LONG).show();
                break;
            default:
        }
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sunbofiy23

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值