【Android 应用开发】动态权限管理示例 ( 使用原生代码实现 | 申请权限 | 判定权限申请结果 | 判定 “ 不再询问 “ 情况 )(一)

简介: 【Android 应用开发】动态权限管理示例 ( 使用原生代码实现 | 申请权限 | 判定权限申请结果 | 判定 “ 不再询问 “ 情况 )(一)

章目录

一、申请权限

二、判定权限申请结果

三、判定 " 不再询问 " 情况

四、完整代码示例

1、权限管理代码

2、主界面代码

3、执行结果

五、博客资源





一、申请权限


首先 , 判定权限是否已经通过 , 如果没有通过再进行申请 ;

如果下面函数返回值为 PackageManager.PERMISSION_GRANTED , 说明权限申请通过 ;

如果返回值为 PackageManager.PERMISSION_DENIED , 说明权限没有被授予 ;


ContextCompat.checkSelfPermission(mActivity, mRequestPermissions[i]);



然后 , 申请没有通过的权限 ;

第 2 22 个参数是 String 数组 , 内容是权限字符串 ;


 

/**
     * 需要申请的权限
     */
    protected String[] mRequestPermissions = new String[]{
            Manifest.permission.READ_EXTERNAL_STORAGE,
            Manifest.permission.WRITE_EXTERNAL_STORAGE
    };
  ActivityCompat.requestPermissions(mActivity, mRequestPermissions, REQUEST_CODE);


完整过程 :

在 Build.VERSION_CODES.M , Android 6.0 ( API 23 ) 才启用动态权限申请 ;

只要有 1 11 个权限没有通过 , 就需要权限申请 ;


 

/**
     * 请求动态权限
     *
     * @return
     */
    public boolean requestPermission() {
        // Android 6.0 ( API 23 ) 才启用动态权限申请
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            // 用户是否不同意权限, 只要有 1 个不同意, 则为 true, 默认 false
            boolean isDisagree = false;
            // 判定是否有权限未获取
            for (int i = 0; i < mRequestPermissions.length; i++) {
                if (ContextCompat.checkSelfPermission(
                        mActivity,
                        mRequestPermissions[i]) != PackageManager.PERMISSION_GRANTED) {
                    isDisagree = true;
                }
            }
            if (isDisagree) {
                // 存在权限没有通过,需要申请
                ActivityCompat.requestPermissions(mActivity, mRequestPermissions, REQUEST_CODE);
                return false;
            } else {
                // 所有权限都已同意
                return true;
            }
        } else {
            // 6.0 以下默认有动态权限
            return true;
        }
    }





二、判定权限申请结果


在 Activity 的 onRequestPermissionsResult 回调方法中 , 可以获取到权限是否授予 ;


 

@Override
    public void onRequestPermissionsResult(
            int requestCode,
            @NonNull String[] permissions,
            @NonNull int[] grantResults) {
  }


遍历第 3 33 个参数 grantResults 数组 , 如果指定索引的元素为 − 1 -1−1 , 说明 permissions 数组中指定的权限没有授予通过 , 被用户拒绝了 ;


如果 grantResults 数组中所有的值都为 0 00 , 说明所有权限授予通过 , 可以继续执行后续操作 ;



代码示例 :


 

public void onRequestPermissionsResult(
            int requestCode,
            @NonNull String[] permissions,
            @NonNull int[] grantResults) {
        if (REQUEST_CODE != requestCode) {
            return;
        }
        // 权限是否赋予完毕, 如果有任意一个没有同意, 则判定权限申请失败
        boolean allAgree = true;
        // 遍历 grantResults 数组, 判定哪个权限被拒绝了
        for (int i = 0; i < grantResults.length; i++) {
            if (grantResults[i] == -1) {
                if (ActivityCompat.shouldShowRequestPermissionRationale(mActivity, permissions[i])) {
                    // 被用户拒绝了, 但是还可以申请, 说明没有设置 "不再询问" 选项
                } else {
                    // 被用户拒绝了, 不能弹出, 说明用户设置了 "不再询问" 选项
                    showDialog();
                }
                allAgree = false;
            }
        }
        // 如果都同意, 则执行相关操作
        if (allAgree) {
            Toast.makeText(mActivity, "权限设置完毕, 执行相关操作", Toast.LENGTH_LONG).show();
        }
    }



目录
相关文章
|
2月前
|
Ubuntu 网络协议 Java
【Android平板编程】远程Ubuntu服务器code-server编程写代码
【Android平板编程】远程Ubuntu服务器code-server编程写代码
|
1天前
|
存储 前端开发 Java
Android应用开发中的MVP架构模式实践
【5月更文挑战第5天】随着移动应用开发的复杂性增加,传统的MVC(Model-View-Controller)架构在应对大型项目时显得笨重且不灵活。本文将探讨一种更适应现代Android应用开发的架构模式——MVP(Model-View-Presenter),并展示如何在Android项目中实现该模式以提升代码的可维护性和可测试性。通过对比分析MVP与传统MVC的差异,以及提供一个实际案例,读者将能深入了解MVP的优势和实施步骤。
|
13天前
|
Shell Android开发 开发者
Android系统 自定义动态修改init.custom.rc
Android系统 自定义动态修改init.custom.rc
27 0
|
13天前
|
测试技术 Android开发 开发者
RK3568 Android系统客制化动态替换ro任意属性
RK3568 Android系统客制化动态替换ro任意属性
31 1
|
13天前
|
存储 Linux Android开发
RK3568 Android/Linux 系统动态更换 U-Boot/Kernel Logo
RK3568 Android/Linux 系统动态更换 U-Boot/Kernel Logo
36 0
|
14天前
|
Android开发
Android RIL 动态切换 4G 模块适配
Android RIL 动态切换 4G 模块适配
14 0
|
14天前
|
Android开发
Android 动态修改参数配置
Android 动态修改参数配置
12 0
|
22天前
|
安全 Android开发 数据安全/隐私保护
Android中的动态权限请求与最佳实践
【4月更文挑战第14天】 在现代安卓应用开发中,用户隐私和安全被赋予了前所未有的重要性。随着Android 6.0(API级别23)引入的运行时权限模型,开发者必须更加细致地处理权限请求,以确保应用功能的完整性同时不侵犯用户的隐私。本文将深入探讨如何在Android应用中实现动态权限请求,分析常见问题,并提供一系列最佳实践,以帮助开发者优雅地处理这一挑战。
27 5
|
1月前
|
存储 安全 Android开发
Android 动态权限请求的设计与实现
【4月更文挑战第6天】在现代安卓应用开发中,用户隐私和安全性日益受到重视。因此,操作系统引入了动态权限请求机制,要求应用在运行时请求特定权限而非安装时一次性获取所有权限。本文将详细探讨Android动态权限请求的关键概念、设计原则以及实现过程,旨在帮助开发者构建更加安全且用户体验友好的应用。通过深入分析Android系统权限模型及其演变,我们将展示如何在实际项目中有效地实施动态权限请求,并处理可能遇到的挑战。
27 0
|
1月前
|
安全 API Android开发
Android应用开发中实现动态权限请求的实践指南
【4月更文挑战第5天】 在现代安卓应用开发中,用户隐私和安全日益受到重视。自Android 6.0(API级别23)起,系统引入了动态权限模型,要求应用在运行时而非安装时请求特定权限。这一变化迫使开发者调整权限请求策略,以增强用户信任并确保应用的正常运行。本文将深入探讨如何在Android应用中有效实施动态权限请求,提供一套详细的实践流程,并通过代码示例阐释关键步骤。我们将讨论如何判断权限的必要性、向用户发起请求的最佳时机以及如何处理用户的授权结果。