Android多权限请求

android权限请求

本文不对android权限部分的过多细节进行描述,主要写自己认为需要注意的点和用法:

1. 权限分类

普通权限和需要申请的权限

1.1 普通权限

只需要在AndroidManifest.xml中声明即可,在安装应用时,会默认获得许可

1.2 需要申请的权限(dangerous permission)

需要在代码中进行权限的动态申请
该权限被分为 9 个权限组

同一组内的任意一个权限被授予,其他的权限也会被授予
例如: android.permission.READ_CONTACTS 权限被授予,那么
android.permission.WRITE_CONTACTS
android.permission.GET_ACCOUNTS
权限也别授予了

Permission GroupPermissions
android.permission-group.CALENDARandroid.permission.READ_CALENDAR
android.permission.WRITE_CALENDAR
android.permission-group.CAMERAandroid.permission.CAMERA
android.permission-group.CONTACTSandroid.permission.READ_CONTACTS
android.permission.WRITE_CONTACTS
android.permission.GET_ACCOUNTS
android.permission-group.LOCATIONandroid.permission.ACCESS_FINE_LOCATION
android.permission.ACCESS_COARSE_LOCATION
android.permission-group.MICROPHONEandroid.permission.RECORD_AUDIO
android.permission-group.PHONEandroid.permission.READ_PHONE_STATE
android.permission.CALL_PHONE
android.permission.READ_CALL_LOG
android.permission.WRITE_CALL_LOG
com.android.voicemail.permission.ADD_VOICEMAIL
android.permission.USE_SIP
android.permission.PROCESS_OUTGOING_CALLS
android.permission-group.SENSORSandroid.permission.BODY_SENSORS
android.permission-group.SMSandroid.permission.SEND_SMS
android.permission.RECEIVE_SMS
android.permission.READ_SMS
android.permission.RECEIVE_WAP_PUSH
android.permission.RECEIVE_MMS
android.permission.READ_CELL_BROADCASTS
android.permission-group.STORAGEandroid.permission.READ_EXTERNAL_STORAGE
android.permission.WRITE_EXTERNAL_STORAGE

2. 动态权限申请

2.1 在AndroidManifest.xml 文件中添加权限
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.CALL_PHONE"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
2.2 检查权限是否被赋予
    //所需要申请的权限数组
    private static final String[] permissionsArray = new String[]{
            Manifest.permission.WRITE_EXTERNAL_STORAGE,
            Manifest.permission.CALL_PHONE,
            Manifest.permission.SEND_SMS };
    //还需申请的权限列表
    private List<String> permissionsList = new ArrayList<String>();
    //申请权限后的返回码
    private static final int REQUEST_CODE_ASK_PERMISSIONS = 1;
    private void checkRequiredPermission(final Activity activity){
        for (String permission : permissionsArray) {
            if (ContextCompat.checkSelfPermission(activity, permission) != PackageManager.PERMISSION_GRANTED) {
                permissionsList.add(permission);
            }
        }
        if (permissionsList.size() > 0) {
            ActivityCompat.requestPermissions(activity, permissionsList.toArray(new String[permissionsList.size()]), REQUEST_CODE_ASK_PERMISSIONS);
        }
    }
2.4 处理请求权限的响应
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
            switch (requestCode) {
            case REQUEST_CODE_ASK_PERMISSIONS:
                for (int i=0; i<permissions.length; i++) {
                    if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
                        Toast.makeText(MainActivity.this, "做一些申请成功的权限对应的事!"+permissions[i], Toast.LENGTH_SHORT).show();
                    } else {
                        Toast.makeText(MainActivity.this, "权限被拒绝: "+permissions[i], Toast.LENGTH_SHORT).show();
                    }
                }
                break;
            default:
                super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        }
    }
2.5 解释为什么需要这种权限

当要申请一些必须权限需要向用户解释下申请该权限的必要性
为了判断用户可能需要解释的情形,可以使用该方法

shouldShowRequestPermissionRationale()

当应用安装后第一次访问,返回 false
如果app之前请求过该权限,被用户拒绝, 这个方法就会返回 true.
如果用户之前拒绝权限的时候勾选了对话框中”Don’t ask again”的选项,那么这个方法会返回 false.
如果设备策略禁止应用拥有这条权限, 这个方法也返回 false.

具体是否需要向用户解释,可以根据具体情况使用该方法;但是不用使用着一步,基本都可以满足需求了

2.6 使用该方法申请权限的截图

第一次进入安装后进入应用

同意第三个权限,将前两个权限拒绝后;第二次进入应用

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Android中,权限请求是指应用程序向用户请求访问敏感权限的过程。应用程序需要在AndroidManifest.xml文件中声明所需的权限,然后在运行时请求这些权限。引用\[1\]提到了一种修改PackageManagerService.java文件的方法来默认授权,但这种修改需要谨慎操作并且不推荐使用。通常,我们使用ActivityCompat.requestPermissions方法来请求权限,并且可以通过重写onRequestPermissionsResult方法来拦截权限请求的结果。\[2\]这种方式可以拦截权限请求并根据需要进行处理。在请求权限时,我们可以提供一个权限请求码,以便在回调方法中识别不同的权限请求。在配置文件中,我们可以定义每个权限的名称、描述和用途,以便向用户解释为什么需要这些权限。\[3\]这些配置可以帮助用户理解应用程序所需权限的目的。总之,Android中的权限请求是一种重要的安全机制,用于保护用户的隐私和数据安全。 #### 引用[.reference_title] - *1* [Android 去掉权限请求](https://blog.csdn.net/a546036242/article/details/119206853)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [hook Android 权限请求, 插入权限目的dialog显示](https://blog.csdn.net/qq_22706515/article/details/124212686)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值