Android 权限机制与及运行时权限申请示例

一、Android 权限机制

安装时权限声明

权限机制说明

安装软件时弹出软件所需要申请的全部权限,如果用户认可软件申请的权限,就会继续安装软件;如果用户不认可所申请的权限,就可以拒绝安装。

实现方式

在 AndroidManifest.mxl 文件中添加权限声明。例如:

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

存在的问题

软件安装前为所有需要的权限都作了申请,如果有个别权限用户不想允许,那就没办法安装这个软件。有可能这个权限对应的功能,用户完全就用不到。

运行时权限声明

权限机制说明

用户不需要在安装软件的时候一次性授权所有申请的权限,而是可以在软件的使用过程中再对某一项权限申请进行授权。

新版系统必须进行运行时权限处理

Android 6.0及以上系统在使用危险权限时必须进行运行时权限处理

二、权限分类

并不是所有权限都需要在运行时申请,对用户来讲,不停地授权也很繁琐。Android 现在将常用的权限大致归为两大类:

普通权限

普通权限指的是那些不会直接威胁到用户的安全和隐私的权限,对于这部分权限申请,系统会自动帮我们进行授权,不需要用户手动操作。

危险权限

危险权限表示那些可能会触及用户隐私或者对设备安全性造成影响的权限,如获取设备联系人信息、定位设备的地理位置等,对于这部分权限申请,必须由用户手动授权才可以,否则程序就无法使用相应的功能。

到Android 10 系统为止所有的危险权限

权限组名权限名
CALENDARREAD_CALENDAR
WRITE_CALENDAR
CALL_LOGREAD_CALL_LOG
WRITE_CALL_LOG
PROCESS_OUTGOING_CALLS
CAMERACAMERA
CONTACTSREAD_CONTACTS
WRITE_CONTACTS
GET_ACCOUNTS
LOCATIONACCESS_FINE_LOCATION
ACCESS_COARSE_LOCATION
ACCESS_BACKGROUND_LOCATION
MICROPHONERECORD_AUDIO
PHONEREAD_PHONE_STATE
READ_PHONE_NUMBERS
CALL_PHONE
ANSWER_PHONE_CALLS
ADD_VOICEMAIL
USE_SIP
ACCEPT_HANDOVER
SENSORSBODY_SENSORS
ACTIVITY_RECOGNITIONACTIVITY_RECOGNITION
SMSSEND_SMS
RECEIVE_SMS
READ_SMS
RECEIVE_WAP_PUSH
RECEIVE_MMS
STORAGEREAD_EXTERNAL_STORAGE
WRITE_EXTERNAL_STORAGE
ACCESS_MEDIA_LOCATION

同组权限自动授权

我们在进行运行时权限处理时使用的是权限名。原则上,用户一旦同意了某个权限申请之后,同组的其他权限也会被系统自动授权。

三、在程序运行时申请权限

要实现的功能

app 界面有一个按键,点击这个按键,拨打电话10086。

实现步骤

在 AndroidManifest.xml 文件声明权限

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

封装拨打电话的功能

private void call()
{
    try {
        Intent intent = new Intent(Intent.ACTION_CALL);
        intent.setData(Uri.parse("tel:10086"));
        startActivity(intent);
    }catch (SecurityException e){
            e.printStackTrace();
    }
}

注册按键点击事件

btnCall.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) ==
            PackageManager.PERMISSION_GRANTED)
        {
            call();
        }
        else
        {
            ActivityCompat.requestPermissions(MainActivity.this,new String[]{Manifest.permission.CALL_PHONE},1);
        }
    }
});
  • ContextCompat.checkSelfPermission 查询app 是否被授权 CALL_PHONE 功能。
  • ActivityCompat.requestPermissions 用于请求指定的权限。

关键函数介绍

ContextCompat.checkSelfPermission

函数功能

用于查询app 是否被授权某个权限.

函数原型
public static int checkSelfPermission(@NonNull Context context, @NonNull String permission)

函数参数

第一个参数 Context context ,上下文环境

这里传入的是activity.this 。

第二参数,是字符串类型的权限变量。

由于每一个权限变量都是 Manifest 类的内部类的静态成员变量,所以我们要先导入Manifest.

import android.Manifest;

函数返回值
  1. PackageManager.PERMISSION_GRANTED 权限被授权;
  2. PackageManager.PERMISSION_DENIED 权限未被授权

ActivityCompat.requestPermissions

函数功能

申请权限(可以申请多个)

函数原型
public static void requestPermissions(final @NonNull Activity activity,
                                      final @NonNull String[] permissions, final @IntRange(from = 0) int requestCode)

函数参数
  • 参数1:activity 对象
  • 参数2: 需要申请的权限列表;字符串数组类型
  • 参数3:requestCode ,这里填入1.

四、异常记录

提示 Cannot resolve symbol ‘CALL_PHONE’

问题描述

输入 Manifest.permission 时IDE 没自动补全 CALL_PHONE,手动补全 Manifest.permission.CALL_PHONE 后,IDE 提示 Cannot resolve symbol ‘CALL_PHONE’

解决办法

引入包:

import android.Manifest;
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Android应用开发中,动态权限管理是一个非常重要的部分,它允许应用在运行时向用户请求所需的权限。以下是一个动态权限管理的示例: 假设我们有一个需要访问相机的应用,我们首先需要在AndroidManifest.xml文件中声明相机权限: ``` <uses-permission android:name="android.permission.CAMERA"/> ``` 然后,在应用中,我们需要检查是否已经获取了相机权限,如果没有,则向用户请求相机权限: ``` private static final int REQUEST_CAMERA_PERMISSION = 1; // 检查相机权限 private boolean checkCameraPermission() { if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { // 没有相机权限,向用户请求权限 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, REQUEST_CAMERA_PERMISSION); return false; } else { // 已经有相机权限 return true; } } // 处理权限请求结果 @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { if (requestCode == REQUEST_CAMERA_PERMISSION) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 用户同意了相机权限 // 在这里处理相机相关操作 } else { // 用户拒绝了相机权限 // 在这里处理没有相机权限的情况 } } } ``` 在上面的示例中,我们首先检查是否已经获取了相机权限,如果没有,则通过requestPermissions方法来请求权限。当用户做出了权限选择后,系统会调用onRequestPermissionsResult方法来处理权限请求的结果,我们可以在这里处理用户的选择并进行相应的操作。 总之,动态权限管理可以让应用在运行时向用户请求所需的权限,保障了用户数据的安全性和隐私保护。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

gdut_llkkyy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值