Android AppOpsManager权限判断

整整大约一年没有更新文章了,最近有点忙。生活不能一直苟且,还要继续读诗和追追远方。
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隐藏了。

你可能感兴趣的:(读书笔记)