Android 6.0敏感权限新特性及使用方法

Android 6.0引入了运行时权限管理,当`targetSdkVersion`设置为23及以上时,敏感权限如读取电话状态、写联系人等在安装后默认不授予。调用相关API会导致应用崩溃。解决方案包括:1. 检测权限并动态请求;2. 降低`targetSdkVersion`;3. 使用`requestPermissions`实时请求。此外,6.0下获取WiFi MAC地址将返回默认值。了解更多详情可参考相关资料。
摘要由CSDN通过智能技术生成


       最近android studio下使用blank activity创建一个demo工程,调用某个sdk,发现之前测试都正常的sdk发生了crash,经过排查发现6.0的权限使用问题

       在android 22 之前,如果在权限列表里申请了权限,只要用户安装,就具有了这些权限,到6.0下面就不一样了,如果把targetSdkVersion设为23,会出现如下现象:

       如果在权限列表里申请了类似这样的敏感权限:

        android.permission.READ_PHONE_STATE

        android.permission.WRITE_CONTACTS

        安装后是默认没有此权限的,如果用户代码里还使用了如下调用:

       String  Imei = ((TelephonyManager) getSystemService(TELEPHONY_SERVICE)).getDeviceId();

        app就直接crash掉了

        另外发现, 在6.0下,获取wifi mac地址,获取到的结果是02:00:00:00:00:00,系统默认不再返回正确的mac地址了

        6.0系统需要在系统设置里开启对应的权限才能直接使用

       怎么解决这个问题呢,我看到三个方法

       一、在需要权限的代码加个权限检测判断

        Context context = getAppli
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值