谷歌于近期发布了最新的android系统P的预览版,作为一个android开放者提前了解新系统的特性和功能能够为我们后续基于新系统的APP开发和移植旧的APP做好准备。
Android P发布的各个时间节点及其主要里程碑
目前的预览版本为Preview 1发布于2018年的3月7号。整个预览版本的发布周期将持续到2018年的第三季度,直到android P的release 版本被发布到 AOSP(android开源项目)和OEMs(生态系统)时截止。
以下是谷歌公布的Android P发布的各个时间节点及其主要的里程碑
- Preview 1 (初始发布, alpha)
- Preview 2 (增量更新, beta)
- Preview 3 (最终的APIs和官方SDK,从此版本开始开发者可发布自己的APP到google play的beta渠道)
- Preview 4 (针对测试的候选版本)
- Preview 5 (针对最终测试的候选版本)
- 最终发布版本 (发布到 AOSP(android开源项目) 和 ecosystem(生态系统)的版本)
对于开发者来说关注早期部分的预览版,能够让你确保你当前的app能够兼容新的android平台并向谷歌提供反馈。在晚期部分的预览版中你可以在你的APP中采用新平台的特性进行开发。
Preview 1和Preview 2这两个里程碑版本主要提供一个早期的开发和测试环境,目的是帮助你找到你当前APP的兼容性问题以便你提前做好针对新平台的迁移计划。同时在这个阶段你可以向开发团队提供关于API及平台兼容性问题的一些反馈。
Preview 3版本发布的时候你可以使用最终的API和SDK进行开发。你可以下载此版本的beta版系统镜像来测试系统的行为和特性。此时android P将提供标准的API,你可以开始对你之前的APP作最终的兼容性测。从此版本开始你可以将你的APP发布到谷歌商店的Beta渠道。使用该系统镜像的用户可以在谷歌商店的Beta渠道进行下载和安装。
Preview4和Preview5包含了最终的API和临近最终的系统镜像。
迁移你的APP到Android P
android P引入了新的API和特性,以及行为的一些改变。这可能导致你之前的APP无法在新系统上正常运行。接下来主要向你介绍迁移旧APP的两个关键阶段。
-
确保与Android P的兼容性
验证你的APP在新平台下所有的功能都是完整且正常的。在该阶段你不需要使用新的API和改变APP的targetSdkVersion,但是一些细小的改动可能是无法避免的。
以下是在android P平台上会影响所有APP的一些关键变化
- 限制non-SDK(非SDK)接口
访问指定的non-SDK接口现在是被禁止的。无论是直接访问、还是通过反射、或者通过JNI访问都是被制止的。如果你尝试访问这些被限制的non-SDK接口将导致 NoSuchFieldException 或NoSuchMethodException等异常。
注:SDK接口是指在android官方发布的android 框架包索引的文档中能够查到,反之no-SDK就是指在android 框架包索引的文档中不能查到的,他们存在于android的源码中,他们的实现细节是被抽象的。即使他们发生变化后谷歌也不会发布通知。
移除Crypto provider
从android P开始,Crypto JCA provider已经被移除,调用SecureRandom.getInstance("SHA1PRNG", "Crypto") 将抛出NoSuchProviderException异常严格的UTF-8解码器
在android P平台上,针对Java语言的UTF-8解码器,将严格遵循Unicode标准。阻止空闲的APP访问相机、麦克风、传感器
处于空闲状态的APP,不再能够访问相机、麦克风、传感器。
- 更新你的targetSdkVersion和使用android P的特性
当你打算使用新平台的特性时,你需要更新APP的targetSdkVersion到 P,重新验证APP的功能,确保如你的预期那样正常工作。然后开始使用新的APIs。
以下是将targetSdkVersion设置到P后会影响APP的一些关键变化
- 前台服务权限
现在所有的APP想要使用前台服务,必须首先申请FOREGROUND_SERVICE服务权限。这是一个普通的权限,当应用申请该权限的时候,系统将自动授权给APP。在没有请求FOREGROUND_SERVICE服务权限的情况下启动一个前台服务系统将抛出一个SecurityException异常。 - 废弃Bouncy Castle 供应商提供的加密算法
android P废弃了若干个 Bouncy Castle provider提供的加密算法,调用getInstance()请求 Bouncy Castle provider提供的加密算法将产生 NoSuchAlgorithmException 错误。为了解决这个错误,在调用getInstance()时不要指定provider - 移除直接访问Build.serial
现在所有的APP想要访问Build.serial标识符必须先请求READ_PHONE_STATE权限,然后使用在android P中新添加的Build.getSerial()方法来获取 - 不允许共享WebView的数据目录
所有的APP不在能够跨进程的访问同一个WebView的数据目录,假如在你的APP中有超过一个以上的进程使用WebView,CookieManager,或任何在android.webkit包中的API,当第二个进程调用WebView的方法的时候,你的APP将会crash。 - 直接访问其他APP的数据目录将会被SELinux阻塞
现在不允许直接通过路径访问其他应用的数据目录,你可以继续使用IPC机制来访问其他应用的数据,包括通过FDs。