Amdroid6.0权限带来的那些坑

    今天就给大家讲讲Android6.0带来的那些坑,谷歌在API23上为了保用用户的权限和隐私,不在随随便便和23以下权限随便调用。当用户使用23也就是所谓的6.0的时候,想操作打电话、读写、照相、获取手机信息、录音等等权限的时候。假如你要是不提示用户去开起这些权限,你的手机会莫名奇妙的抛一些异常、甚至有可能APP闪退。


   讲完了这些之后,肯定就会有相应的解决办法,谷歌推出了权限检测器 (PermissionsChecker) ,当用户使用6.0 的时候我们就需要来检测这些敏感的权限,告诉用户是否开启,这些权限。由于最近做的是个商城的应用需要使用上面很多权限,也就偷个懒,在APP启动页面直接检测这些所谓的权限。当用户允许使用这些权限才进入APP。下面直接上代码啊

private static final int REQUEST_CODE = 0; // 请求码

// 所需的全部权限
static final String[] PERMISSIONS = new String[]{
        Manifest.permission.READ_PHONE_STATE,
        Manifest.permission.CAMERA,
        Manifest.permission.CALL_PHONE,
        Manifest.permission.WRITE_EXTERNAL_STORAGE,


};


private PermissionsChecker mPermissionsChecker; // 权限检测器


//检测你手机的版本
if (Build.VERSION.SDK_INT >= 23) {

    // 缺少权限时, 进入权限配置页面
    if (mPermissionsChecker.lacksPermissions(PERMISSIONS)) {
        startPermissionsActivity();
  }


private void startPermissionsActivity() {
    PermissionsActivity.startActivityForResult(this, REQUEST_CODE, PERMISSIONS);
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    // 拒绝时, 关闭页面, 缺少主要权限, 无法运行
    if (requestCode == REQUEST_CODE && resultCode == PermissionsActivity.PERMISSIONS_DENIED) {
        finish();
    }
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值