判断是否授权CheckPermisionUtil工具类

2024-08-31 23:18

本文主要是介绍判断是否授权CheckPermisionUtil工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

因为AppOpsManager方法public int checkOp(int op, int uid, String packageName)是隐藏的,所以需要反射进行来调用该方法,然后传入相应权限参数,可以判断是否已经授权,比如源码中就是读写短信的2个例子

  /** @hide */public static final int OP_READ_SMS = 14;/** @hide */public static final int OP_WRITE_SMS = 15;


CheckPermisionUtil

package com.example.permission;import java.lang.reflect.Method;import android.annotation.SuppressLint;
import android.app.AppOpsManager;
import android.content.Context;
import android.content.Intent;
import android.os.Process;
import android.provider.Settings;
import android.util.Log;public class CheckPermisionUtil {private static final String[] type = { "int", "int", "string" };/*** 反射方法获取返回值结果 public int checkOp(int op, int uid, String packageName)*/@SuppressLint("InlinedApi")private static int getPermisionResult(Context context, int permValue,String methodName) {int check = 0;try {AppOpsManager aom = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE);Class<? extends AppOpsManager> c = aom.getClass();Class<?> paramsTypes[] = ReflectUtil.getMethodClass(type);Method method = c.getMethod(methodName, paramsTypes);String[] params = { "" + permValue, "" + Process.myUid(),context.getPackageName() };Object arglist[] = ReflectUtil.getMethodObject(type, params);check = (Integer) method.invoke(aom, arglist);} catch (Exception e) {e.printStackTrace();Log.i("TAG", "--->getPermisionResult exception");}return check;}/*** 判断某个权限是否被授权*/@SuppressLint("InlinedApi")public static boolean isPermisionGranted(Context context, int permValue) {boolean result = true;switch (getPermisionResult(context, permValue, "checkOp")) {case AppOpsManager.MODE_IGNORED:// 被禁止掉result = false;break;default:result = true;// 允许和需要确认不需要做什么操作,故都返回truebreak;}return result;}/*** 打开系统安全设置界面*/public static void openSecurityPager(Context context) {openSystemPager(context, Settings.ACTION_SECURITY_SETTINGS);}/*** 打开设置界面*/public static void openSettingPager(Context context) {openSystemPager(context, Settings.ACTION_SETTINGS);}/*** 打开系统界面*/public static void openSystemPager(Context context, String action) {Intent intent = new Intent();intent.setAction(action);context.startActivity(intent);}/*** 检测短信编写权限是否被许可*/public static boolean isSmsWritePermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_WRITE_SMS);}/*** 检测短信接收权限是否被许可*/public static boolean isSmsReceivePermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_RECEIVE_SMS);}/*** 检测短信读取权限是否被许可*/public static boolean isSmsReadPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_READ_SMS);}/*** 检测短信发送是否被许可*/public static boolean isSmsSendPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_SEND_SMS);}/*** 检测打开相机权限是否被许可*/public static boolean isCameraPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_CAMERA);}/*** 检测悬浮窗权限是否被许可*/public static boolean isFloatWindowPermisionGranted(Context context) {return isPermisionGranted(context,PermisionValue.OP_SYSTEM_ALERT_WINDOW);}/*** 检测读取联系人权限是否被许可*/public static boolean isReadContactPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_READ_CONTACTS);}/*** 检测添加联系人权限是否被许可*/public static boolean isWriteContactPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_WRITE_CONTACTS);}/*** 检测直接拨号权限是否被许可(无界面拨号)*/public static boolean isCallPhonePermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_CALL_PHONE);}/*** 检测录制音频权限是否被许可*/public static boolean isRecordAudioPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_RECORD_AUDIO);}/*** 检测读取通话记录权限是否被许可*/public static boolean isReadCallLogPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_READ_CALL_LOG);}/*** 检测编写通话记录权限是否被许可*/public static boolean isWriteCallLogPermisionGranted(Context context) {return isPermisionGranted(context, PermisionValue.OP_WRITE_CALL_LOG);}}

PermisionValue

package com.example.permission;import java.util.HashMap;
import java.util.Map;public class PermisionValue {public static final Map<Integer, String> permisionMap = new HashMap<Integer, String>();public static final int OP_GRANTED = 0X01;//许可public static final int OP_NO_GRANTED = 0X02;//禁止public static final int OP_UNSURE_GRANTED = 0X03;//需要确认public static final int OP_READ_CONTACTS = 4;public static final int OP_WRITE_CONTACTS = 5;public static final int OP_READ_CALL_LOG = 6;public static final int OP_WRITE_CALL_LOG = 7;public static final int OP_CALL_PHONE = 13;public static final int OP_READ_SMS = 14;public static final int OP_WRITE_SMS = 15;public static final int OP_RECEIVE_SMS = 16;public static final int OP_SEND_SMS = 20;public static final int OP_SYSTEM_ALERT_WINDOW = 24;public static final int OP_CAMERA = 26;public static final int OP_RECORD_AUDIO = 27;public static final int OP_PLAY_AUDIO = 28;static{permisionMap.put(OP_GRANTED, "");permisionMap.put(OP_WRITE_SMS, "编辑短信权限");permisionMap.put(OP_RECEIVE_SMS, "接收短信权限");permisionMap.put(OP_READ_SMS, "读取短信权限");permisionMap.put(OP_SEND_SMS, "发送短信权限");permisionMap.put(OP_CAMERA, "拍照权限");permisionMap.put(OP_SYSTEM_ALERT_WINDOW, "悬浮窗权限");permisionMap.put(OP_READ_CONTACTS, "读取联系人权限");permisionMap.put(OP_WRITE_CONTACTS, "添加联系人权限");permisionMap.put(OP_CALL_PHONE, "拨号权限");permisionMap.put(OP_RECORD_AUDIO, "录音权限");permisionMap.put(OP_READ_CALL_LOG, "读取通话记录权限");permisionMap.put(OP_WRITE_CALL_LOG, "修改通话记录权限");}}

以上只是列出了一部分,AppOpsManager中可以去查看有哪些权限


ReflectUtil

package com.example.permission;import android.annotation.SuppressLint;public class ReflectUtil {// 获取参数类型Class[]的方法@SuppressWarnings("rawtypes")public static Class[] getMethodClass(String[] type) {Class[] cs = new Class[type.length];for (int i = 0; i < cs.length; i++) {if (!type[i].trim().equals("") || type[i] != null) {if (type[i].equals("int") || type[i].equals("Integer")) {cs[i] = Integer.TYPE;} else if (type[i].equals("float") || type[i].equals("Float")) {cs[i] = Float.TYPE;} else if (type[i].equals("double") || type[i].equals("Double")) {cs[i] = Double.TYPE;} else if (type[i].equals("boolean") || type[i].equals("Boolean")) {cs[i] = Boolean.TYPE;} else {cs[i] = String.class;}}}return cs;}// 获取参数Object[]的方法@SuppressLint("UseValueOf")public static Object[] getMethodObject(String[] type, String[] param) {Object[] obj = new Object[param.length];for (int i = 0; i < obj.length; i++) {if (!param[i].trim().equals("") || param[i] != null) {if (type[i].equals("int") || type[i].equals("Integer")) {obj[i] = new Integer(param[i]);} else if (type[i].equals("float") || type[i].equals("Float")) {obj[i] = new Float(param[i]);} else if (type[i].equals("double") || type[i].equals("Double")) {obj[i] = new Double(param[i]);} else if (type[i].equals("boolean") || type[i].equals("Boolean")) {obj[i] = new Boolean(param[i]);} else {obj[i] = param[i];}}}return obj;}
}

MainActivity

package com.example.permission;import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);CheckPermisionUtil.openSecurityPager(this);CheckPermisionUtil.openSettingPager(this);boolean isSmsWritePermisionGranted = CheckPermisionUtil.isSmsWritePermisionGranted(this);boolean isSmsReceivePermisionGranted = CheckPermisionUtil.isSmsReceivePermisionGranted(this);boolean isSmsReadPermisionGranted = CheckPermisionUtil.isSmsReadPermisionGranted(this);boolean isSmsSendPermisionGranted = CheckPermisionUtil.isSmsSendPermisionGranted(this);boolean isCameraPermisionGranted = CheckPermisionUtil.isCameraPermisionGranted(this);boolean isFloatWindowPermisionGranted = CheckPermisionUtil.isFloatWindowPermisionGranted(this);boolean isReadContactPermisionGranted = CheckPermisionUtil.isReadContactPermisionGranted(this);boolean isWriteContactPermisionGranted = CheckPermisionUtil.isWriteContactPermisionGranted(this);boolean isCallPhonePermisionGranted = CheckPermisionUtil.isCallPhonePermisionGranted(this);boolean isRecordAudioPermisionGranted = CheckPermisionUtil.isRecordAudioPermisionGranted(this);boolean isReadCallLogPermisionGranted = CheckPermisionUtil.isReadCallLogPermisionGranted(this);boolean isWriteCallLogPermisionGranted = CheckPermisionUtil.isWriteCallLogPermisionGranted(this);Log.i("TAG", "isSmsWritePermisionGranted:"+isSmsWritePermisionGranted);Log.i("TAG", "isSmsReceivePermisionGranted:"+isSmsReceivePermisionGranted);Log.i("TAG", "isSmsReadPermisionGranted:"+isSmsReadPermisionGranted);Log.i("TAG", "isSmsSendPermisionGranted:"+isSmsSendPermisionGranted);Log.i("TAG", "isCameraPermisionGranted:"+isCameraPermisionGranted);Log.i("TAG", "isFloatWindowPermisionGranted:"+isFloatWindowPermisionGranted);Log.i("TAG", "isReadContactPermisionGranted:"+isReadContactPermisionGranted);Log.i("TAG", "isWriteContactPermisionGranted:"+isWriteContactPermisionGranted);Log.i("TAG", "isCallPhonePermisionGranted:"+isCallPhonePermisionGranted);Log.i("TAG", "isRecordAudioPermisionGranted:"+isRecordAudioPermisionGranted);Log.i("TAG", "isReadCallLogPermisionGranted:"+isReadCallLogPermisionGranted);Log.i("TAG", "isWriteCallLogPermisionGranted:"+isWriteCallLogPermisionGranted);}}


这篇关于判断是否授权CheckPermisionUtil工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125277

相关文章

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet