美文网首页
Android Pie限制非 SDK 接口的调用

Android Pie限制非 SDK 接口的调用

作者: None_Ling | 来源:发表于2020-09-17 19:04 被阅读0次

    Android Pie的限制

    从 Android 9(API 级别 28)开始,Android对应用能使用的非 SDK 接口实施了限制。

    只要应用引用非 SDK 接口或尝试使用反射JNI来获取其(包括Method、Class、Field)句柄,这些限制就适用。

    目的在于帮助提升用户体验和开发者体验,为用户降低应用发生崩溃的风险,同时为开发者降低紧急发布的风险

    对于插件的影响

    目前插件的加载都是通过反射调用PathClassLoaderDexClassLoadermakeDexElements生成Dex对应的Elements对象 , 再将Elements添加到主ClassLoader的dexElements数组中.

    而再9.0后 , ClassLoader的函数等级处于greylist , 所以目前还可以继续使用.

    非SDK接口等级

    在Android9.0后 , Android 10、11都陆续更新了非SDK提供接口全集. 而Android官方为这些非公开的API接口分了等级 , 并且在ART虚拟机中对API接口进行处理.

    等级 策略
    屏蔽名单 (blacklist) 无论应用TargetVersion是什么,都无法使用的非 SDK 接口。 如果您的应用尝试访问其中任何一个接口,系统就会抛出错误
    有条件屏蔽 (greylist-max-x) 从 Android 9(API 级别 28)开始,当有应用以该 API 级别为TargetVersion时,我们会在每个 API 级别分别限制某些非 SDK 接口。
    不支持 (greylist) 当前不受限制且您的应用可以使用的非 SDK 接口。 但请注意,这些接口不受支持,可能会在不另行通知的情况下随时发生更改。预计这些接口在未来的 Android 版本中会被有条件地屏蔽,并列在 max-target-x 名单中。
    SDK (whitelist) 已在 Android 框架中正式记录、受支持并且可以自由使用的接口

    简单描述则为以下情况 :

    • black List : 不管在哪个平台上 , 都会抛出错误
    • greylist-max-x : 当APP的TargetVersion与运行时Android版本相同时 , 则会抛出错误
    • greylist : 目前可以继续调用 , 其实系统是不建议这样使用 , 可能在未来的版本会加入到greylist-max-x
    • whitelist : 不管怎么调都可以正常使用

    扫描检测

    在官网中找到对应的Excel , 会有各个接口对应的级别.

    image.png

    接口访问

    black-list中接口通过反射、JNI接口去获取相应的MethodField的引用时 , 就会报错.

    greylist中接口通过反射、JNI接口去获取相应的MethodField的引用时 , 目前可以正常使用.

    image.png

    举例说明

    image.png

    参考资料

    针对非 SDK 接口的限制
    Android P 调用隐藏API限制原理
    谈谈 Android P 行为变更与内联优化

    相关文章

      网友评论

          本文标题:Android Pie限制非 SDK 接口的调用

          本文链接:https://www.haomeiwen.com/subject/wsbfyktx.html