Android应用权限请求步骤

该文章介绍了如何在Android应用中处理外部存储读写权限。首先在AndroidManifest.xml文件中声明所需的权限,然后在onCreate方法中检查并请求权限。如果用户未授予权限,应用会提示用户。onRequestPermissionsResult方法处理权限请求的结果,显示授权是否成功。

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

1.在AndroidManifest.xml中配置请求权限

 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

2.在onCreate(Bundle savedInstanceState)方法中请求权限

//授权请求
        if (Build.VERSION.SDK_INT >= 24) {
            System.out.println("版本正确");
            checkPermission();
        }else {
            System.out.println("版本过低");
        }

权限检测实现代码

private static final int REQUEST_CODE = 1;
    private static String[] PERMISSIONS_STORAGE = {
            "android.permission.READ_EXTERNAL_STORAGE",
            "android.permission.WRITE_EXTERNAL_STORAGE"};
    //授权检测
    private void checkPermission() {
        //权限是否已经赋予
        if (m_activity.checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE)
                != PackageManager.PERMISSION_GRANTED) {
            //未赋予权限,申请权限
            if (m_activity.shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
                //选择不开启权限的时候,提示用户
                Toast.makeText(m_activity.getApplicationContext() , "请开通相关权限,否则无法正常使用本应用!", Toast.LENGTH_SHORT).show();
            }
            //申请权限
            m_activity.requestPermissions( PERMISSIONS_STORAGE, REQUEST_CODE);

        } else {
            //权限已赋予
            Toast.makeText(m_activity.getApplicationContext(), "已授权成功!", Toast.LENGTH_SHORT).show();
        }
    }

权限请求结果代码

 public void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
        switch (requestCode) {
            //权限的申请结果返回
            case REQUEST_CODE: {
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    //已授权
                    Toast.makeText(m_activity.getApplicationContext(), "授权成功!", Toast.LENGTH_SHORT).show();
                } else {
                    //未授权
                    Toast.makeText(m_activity.getApplicationContext(), "授权被拒绝!", Toast.LENGTH_SHORT).show();
                }
            }
        }
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

自由软件开发者

有你的鼓励,我会更加努力。

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

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

打赏作者

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

抵扣说明:

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

余额充值