Android(Q/P版本)扫描非SDK接口(google veridex工具)

本文介绍OPPO针对安卓Q适配过程中对非SDK接口的限制,及如何使用veridex工具扫描并修复相关问题,避免APP被下架。


1 前言

最近提审oppo的apk被打回,收到如下邮件

尊敬的开发者:
近期OPPO研发组正在进行OPPO Reno(型号PCAM00)的安卓Q适配
(适配指南:https://open.oppomobile.com/wiki/doc#id=10325),经测试,
发现您名下产品存在BUG(见下表),请您先自查,并在9月10日前完成相关修复。
若长时间没处理,默认您的产品无人维护,我们将对您的产品采取下架/屏蔽处理!在这里插入图片描述

2 限制非SDK接口背景

从Android P开始,谷歌就开始限制开发者,禁止反射调用系统的一些方法,特别是谷歌给出的黑名单里面的方法。当然,这是为了提升开发者体验和增强APP稳定,更是为了安卓的生态发展。
那些官方限制的都是一些非SDK接口,就是一些private的或者是hide的方法或字段,这些因为是没有公开的,可能会在某个版本就消失了。所以不应该访问这些SDK中未列出的方法或字段。

非SDK接口的三种分类:浅灰名单深灰名单黑名单

3 扫描工具下载

如何知道自己的app使用了非标准SDK的接口?google已经为我们制造了这样的一个工具:veridex
官方下载地址
https://android.googlesource.com/platform/prebuilts/runtime/+/master/appcompat
百度网盘下载链接1
https://pan.baidu.com/s/1MnpHXoSSdfNYwgBTDRrmTg
提取码:ynyy
百度网盘下载链接2
https://pan.baidu.com/s/1NojiqPjvJMzJ_AuHd5jukQ

4 如何使用

veridex工具支持linux,windows和macOS三种操作系统,解压缩之后,你会在README.txt中看到具体的操作指南,这里以mac环境为例做个示范
在这里插入图片描述
命令

./appcompat.sh --dex-file=my_game.apk

扫描结果
在这里插入图片描述
由上图可知,一共扫描出
1个非SDK接口在深灰名单
5个非SDK接口在浅会名单
并没有使用黑名单里面的非SDK接口

注意输出的前面三行
NOTE: appcompat.sh is still under development. It can report
API uses that do not execute at runtime, and reflection uses
that do not exist. It can also miss on reflection uses.
就是说这个工具可能会误判,所以需要开发者自己复查一次

5 补充

我们使用下面的命令行将其扫描内容输出到文件中

./appcompat.sh --dex-file=my_game.apk.apk >> out_put.txt

当然也可以加一个--imprecise参数,加这个参数是为了让输出内容更加详细

./appcompat.sh --dex-file=my_game.apk --imprecise >>  out_put.txt
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林新发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值