Android 6.0权限管理

安卓6.0之后出现了新的应用授权管理方式,允许app动态获取权限,针对一些危险权限,必须要动态授权,

危险权限如下:

    <!-- 危险权限 -->
    <!--联系人-->
    <uses-permission android:name="android.permission.READ_CONTACTS"/>
    <uses-permission android:name="android.permission.WRITE_CONTACTS"/>
    <uses-permission android:name="android.permission.GET_ACCOUNTS"/>
    <!--电话-->
    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
    <uses-permission android:name="android.permission.CALL_PHONE"/>
    <uses-permission android:name="android.permission.READ_CALL_LOG"/>
    <uses-permission android:name="android.permission.ADD_VOICEMAIL"/>
    <uses-permission android:name="android.permission.WRITE_CALL_LOG"/>
    <uses-permission android:name="android.permission.USE_SIP"/>
    <uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS"/>
    <!--存储-->
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <!--相机-->
    <uses-permission android:name="android.permission.CAMERA"/>
    <!--定位-->
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <!--录像-->
    <uses-permission android:name="android.permission.RECORD_AUDIO"/>
    <!--传感器-->
    <uses-permission android:name="android.permission.BODY_SENSORS"/>
    <!--短信-->
    <uses-permission android:name="android.permission.SEND_SMS"/>
    <uses-permission android:name="android.permission.RECEIVE_SMS"/>
    <uses-permission android:name="android.permission.READ_SMS"/>
    <uses-permission android:name="android.permission.RECEIVE_WAP_PUSH"/>
    <uses-permission android:name="android.permission.RECEIVE_MMS"/>
    <!--日历-->
    <uses-permission android:name="android.permission.READ_CALENDAR"/>
    <uses-permission android:name="android.permission.WRITE_CALENDAR"/>

危险权限都有属于自己的组,对于同一组内的权限,只要有一个被授予,其他的都会被授予。

下面以拨打电话权限为例,操作步骤:

1.在AndroidManifest.xml文件中声明权限

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

2.检查是否拥有某个权限,没有则申请

//系统会弹出对话框提示用户授予权限
//先检查是否有拨打电话权限
if(ContextCompat.checkSelfPermission(this,
        Manifest.permission.CALL_PHONE) !=PackageManager.PERMISSION_GRANTED){ //或者使用PermissionChecker
    //申请权限
    ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CALL_PHONE},REQUEST_CALL_PHONE);
}else{
    callPhone();
}

3.处理请求结果

//实现请求权限结果回调
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    switch (requestCode){
        case REQUEST_CALL_PHONE:
            //grantResults数组的大小跟申请权限时传入的的权限个数一致,表示申请的结果
            if (grantResults[0] == PackageManager.PERMISSION_GRANTED){//获得了权限
                callPhone();
            }else{
                Toast.makeText(this,"禁止了拨打电话权限",Toast.LENGTH_SHORT).show();
            }
            break;
    }
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序猫King

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

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

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

打赏作者

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

抵扣说明:

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

余额充值