android l打开app ops,Android AppOpsManager权限判断

本文探讨了Android系统中安全中心对权限管理的影响,介绍了如何通过AppOpsManager检测App权限状态,并针对微博等产品滥用权限的行为进行了批判。重点讲解了在6.0及以上版本中检查权限的方法,对开发者提出了应对策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

整整大约一年没有更新文章了,最近有点忙,简书去中心化后看不到IT专栏了,就很少上来了。偶尔打开一次,却依然不断有新关注的朋友,和新点赞的消息提示,很受鼓舞。

Android 本身权限控制做的不太理想,6.0也出了一套新的运行时权限系统,而在此之前,小米的miui系统就已经领先一步出了类似的安全管理机制,就是安全中心,可以针对单个app的某个权限做相应的设置,禁止某项权限,这对用户是好事,不再像以前那样,要安装app就必须要接受那一连串的不相干的权限。

说到这里,再鄙视一下微博,最新版的微博禁掉某些权限,app会无休止的提示,非常讨厌,简直就是流氓,可以简单地推测微博的产品经理和程序员都是没有立场,没有品质的一伙人。

有了安全中心这种简单的权限管理设置对用户是好事,但对程序员来说就是个头疼的事了,处理不好,app会因为某项权限的缺失而莫名其妙的失灵,出bug,因而很容易受到不明所以的领导的批评。

到底有没有某项权限,怎么检测呢,基于以往 Android 在这方面的不精细,很多人都不会太在意这方面的逻辑判断,新出的6.0系统也只是基于targetSdkVersion 23以上的app的判断,包括6.0以下的版本,怎样判断是不是被安全中心这种禁掉了呢,这就需要 AppOpsManager 这个类了,废话不能再多说了,下面直接上判断方法:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

appOpsManager = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE);

int checkResult = appOpsManager.checkOpNoThrow(

AppOpsManager.OPSTR_FINE_LOCATION, Binder.getCallingUid(), context.getPackageName());

if(checkResult == AppOpsManager.MODE_ALLOWED){

Toast.makeText(context,"有权限",Toast.LENGTH_LONG).show();

Log.e("jijiaxin","有权限");

}else if(checkResult == AppOpsManager.MODE_IGNORED){

// TODO: 只需要依此方法判断退出就可以了,这时是没有权限的。

Toast.makeText(context,"被禁止了",Toast.LENGTH_LONG).show();

Log.e("jijiaxin","被禁止了");

}else if(checkResult == AppOpsManager.MODE_ERRORED){

Toast.makeText(context,"出错了",Toast.LENGTH_LONG).show();

Log.e("jijiaxin","出错了");

}else if(checkResult == 4){

Toast.makeText(context,"权限需要询问",Toast.LENGTH_LONG).show();

Log.e("jijiaxin","权限需要询问");

}

}

比较简单清楚了,值得一提的是这个api是在19新加入的,所以要注意加个判断,其实 Android 官方一直有这个设置权限的入口,Setting---Security---AppOps 只是一直被google隐藏了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值