先说当前遇到的问题
近期我们很多甲方反馈在适配Android 14 的过程中,某些14机型在应用启动时弹出读取您的应用列表权限申请弹框?但我们明明是没有申请QUERY_ALL_PACKAGES权限的,怎么回事呢?
但对于小贷或者其他金融应用,Applist数据对于风控来说是至为重要的,难道Google对于这部分数据要求这么严格了?对于无QUERY_ALL_PACKAGES权限获取Applist数据的文章及Applist数据重要性的分析,大家可以先打卡下这篇文章:QUERY_ALL_PACKAGES权限不给了!!!我们如何获取用户应用安装列表
问题定位
作为一个程序猿,遇事儿不要慌,Google or 百度 == result。 在经历了很长时间搜索以后,没有发现什么结果。还是先人说的对,纸上得来终觉浅,绝知此事要躬行。既然我们没有申请权限,那必然是代码被检测出问题了。项目在启动时初始化了很多的三方库和自研库,项目中肯定是某些代码触发了Google安全机制,导致了此问题。那个就一个库一个库的在项目中移除,以此来定位具体原因。
最终发现,有两个底层库会触发应用列表权限申请弹框。而这两个库都调用了getInstalledPackages方法来获取某些app信息。
分析弹权限弹窗可能原因是:在Android 14手机版本中,对于未在应用中声明QUERY_ALL_PACKAGES权限却执行相关操作的应用,系统会预防性的介入,显示权限请求对话框,提示用户该应用正在尝试进行可能侵犯隐私的操作。这有可能是系统对未授权的行为的一种保护措施。
知道原因了,那就开始动手解决,先确定解决方案。
尝试方案
方案一: 通过 api 直接调用不行,那通过反射拿到目标类和方法直接调试试,具体实践步骤及核心代码如下:
- 拿到PackageManager类对象,通过目标类的class属性,调用getClass()方法,获取class 对象
- 通过class 对象获取目标方法
- 传参调用
PackageManager mPm = Util.getContext().getPackageManager();
Class<? extends PackageManager> mPClass = mPm.getClass();
Method method = mPClass.getMethod("getInstalledPackages", int.class);
method.setAccessible(true);
List<PackageInfo> packages = (List<PackageInfo>) method.invoke(mPm, 0);
未能解决问题,依旧会有应用列表权限申请弹框
方案二: 通过反射拿到类,动态拼接方法名的方式试试,因为确实有的检测会扫描我们的某些关键词,方法名分开以后,在字节码层代码会发生响应的变化。核心代码如下
public String getA() {
return "get";
}
public String getB() {
return "Installed";
}
public String getC() {
return "Packages";
}
PackageManager mPm = Util.getContext().getPackageManager();
Class<? extends PackageManager> mPClass = mPm.getClass();
Method method = mPClass.getMethod(getA() + getB() + getC()), int.class);
method.setAccessible(true);
List<PackageInfo> packages = (List<PackageInfo>) method.invoke(mPm, 0);
未能解决问题,依旧会有应用列表权限申请弹框
最终确定方案
其实不管我们之前有没有声明QUERY_ALL_PACKAGES权限,我们在隐私协议和权限声明中肯定是有披露Applist收集的。我们只要不让这个弹框在一开始弹出,而是在Google审核人员看到披露信息以后,随着我们申请的其他权限弹出,尽可能满足合规要求,就不会有太大问题。实际效果视频如下:
抱歉,csdn无法直接传视频在文章中,烦请大家移步公众号链接查看视频,造成不便,烦请担待:
Android 14 没有申请QUERY_ALL_PACKAGES权限,为何依旧弹出读取您的应用列表权限申请弹框?
App出海交流群,寻找志同道合的你
经常分享Google Play,App Store市场政策解决方案,大家共同深入了解应用市场App上架、下架背后的原因,如政策违规、安全漏洞、版权问题、市场策略调整等,确保海外App合规、安全并提升我们的用户体验。也不限于分享其他App出海快讯,一起见证行业的蓬勃发展。
欢迎您来到App出海交流群讨论出海的任何问题!想进群的可以点击这里,或者或者关注公众号趣浪出海,我拉您进来。
这是一个高质量的属于App出海浪潮儿的技术交流中心!
在这里,都是一群热衷于在海外发展的人群:
1、你的各种谷歌&苹果应用上架问题都能得到解决。
2、你可以了解到各种最新的谷歌&苹果政策更新。
3、你可以获得每日的应用上架数据,了解谷歌&苹果审核严松状态。
4、你可以获得各种资源信息,助力企业出海。