Android aab的打包、调试、安装

一、前言

Google Play在今年3月发出了一个 Google Play新政策通知,即在今年8月后新应用必须以 API 级别 30 (Android 11) 为目标平台,并使用 Android App Bundle(aab)发布格式,对于现有应用是不受强制影响的。

首先声明一点:
	aab是开发者上传至应用市场的应用包格式,不是手机解析安装的格式
	目的是为了用户用更少流量下载到机型匹配的apk包,同时开发者也能更放心的使用多abi架构的so库,
	不用担心so兼容对apk大小的影响
	
	很多媒体带节奏发新闻说aab是代替apk格式,目的是针对华为或者国内手机厂商,纯属扯淡,简直离离原上谱
	如果我没记错的话,早在18年Google就已经提出了aab这个东西

Android aab的打包、调试、安装_第1张图片
那么对于这次提到的Android APP Bundle直接带来的好处也是清晰明了的,我直接给撸过来了:

Android App Bundle:
  1. Google Play 使用 app bundle 生成和优化 APK,以便针对不同的设备配置和语言进行分发。这使您的应用程序更小(平均比通用 APK 小 15%)且下载速度更快,从而导致更多安装和更少卸载。
Play App Signing:
  1. Play App Signing 是应用程序包所必需的,它通过使用 Google 的安全基础架构来保护您的应用签名密钥免遭丢失,并提供升级到新的、加密强度更高的应用签名密钥的选项。
Play Feature Delivery:
  1. 超过 10% 的顶级应用使用 app bundle,Play Feature Delivery 使您能够自定义将哪些功能模块交付到哪个设备以及何时交付,以及安装时、有条件和按需交付模式。
Play Assets交付:
  1. 通过动态交付大型资产,同时降低交付成本,减少用户等待时间。使用 Play Asset Delivery 的游戏可以使用纹理压缩格式定位,因此您的用户只会获得适合其设备的资产,而不会浪费空间或带宽。
未来计划:
  1. 很快,Play App Signing 将开始推出APK Signature Scheme v4以选择应用程序,使他们可以选择访问新设备上即将推出的性能功能。收看7 月 12 日举行的Google for Games 开发者峰会,了解更多信息。

Google官方说平均减少包体积15%,对于使用很多so库的应用这个数字还是太过保守,据我实际测试下来so库占用apk总体积的53.8%情况下,aab格式比apk格式的分发下载直接减小了25%,别的不说就光从这一点上面就已经很有吸引力了。


二、.aab的本质

.aab实际上和.apk一样是个压缩包,你可以直接改后缀为.zip然后解压,解压后有如下目录:
Android aab的打包、调试、安装_第2张图片
其中base里是一些主要资源,.pb的文件是一些描述,如下:
Android aab的打包、调试、安装_第3张图片

aab文件将语言、分辨率、CPU架构、图片尺寸等拆分成N个.apk,例如下,可以看到有87个apk文件

Android aab的打包、调试、安装_第4张图片

再根据设备软硬件情况组合成一个size小很多的apk进行安装。比如在google play上,aab会被打成N个apk再组合分发到对应的设备上。
具体描述,推荐看下这位老哥的相关博客

三、.aab如何安装到手机上

.aab不能直接安装到设备上,需要通过工具命令把它转成.apks,再使用工具命令组合多个apk部署到设备(这个过程是工具内部根据adb连接的设备自动组合的)。操作.aab格式的文件,需要下载官方工具bundletool

  1. 转aab为apks命令: build-apks
// --bundle为输入文件的全路径(当前目录直接使用文件名) --output为输出文件全路径
bundletool build-apks --bundle=my.aab --output=my.apks

直接使用如上命令应该是会报错找不到命令的command not found: bundletool,正确执行jar文件方式是到bundletool.jar的文件夹下或者使用全路径

java -jar bundletool-xxx.jar build-apks --bundle=my.aab --output=my.apks

以上方式仅适合在项目目录下运行,因为这个过程其实是需要签名文件和相关参数的,默认情况下会按照未二次签名的debug版本处理,下面会介绍到带参数转aab

  1. 安装命令: install-apks
java -jar bundletool-xxx.jar install-apks --apks=myapp.apks
  1. 带参数转aab为apks: build-apks
java -jar bundletool-xxx.jar build-apks --bundle=my.aab --output=my.apks --ks=/path/xxx.jks --ks-pass=pass:xxx --ks-key-alias=xxx --key-pass=pass:xxx

常规的一次.aab转.apks大概需要指定如下参数

// 请注意:以下命令因带换行格式无法直接使用
bundletool build-apks --bundle=my_app.aab --output=my_app.apks
–ks=/MyApp/keystore.jks
–ks-pass=file:/MyApp/keystore.pwd
–ks-key-alias=MyKeyAlias
–key-pass=file:/MyApp/key.pwd

–ks                         签名文件的全路径
–ks-pass               签名文件密码,可以使用pass:xxx指定明文密码,也可以使用file:xxx指定文件密码
–ks-key-alias        签名别名
–key-pass             签名密码,可以使用pass:xxx指定明文密码,也可以使用file:xxx指定文件密码

  1. 从现有的 APK 集中提取设备专用 APK: extract-apks
java -jar bundletool-xxx.jar extract-apks --apks=my.apks --output-dir=my.aab --device-spec=xxx.json

// 请注意:以下命令因带换行格式无法直接使用
bundletool extract-apks
–apks=/MyApp/my_existing_APK_set.apks
–output-dir=/MyApp/my_pixel2_APK_set.apks
–device-spec=/MyApp/bundletool/pixel2.json

其中json文件可以手动创建,也可以根据已连接的adb设备自动创建,这里展示一下手动创建的参数格式

{
  "supportedAbis": ["arm64-v8a", "armeabi-v7a"],
  "supportedLocales": ["en", "fr"],
  "screenDensity": 640,
  "sdkVersion": 27
}
  1. 预估打包成aab格式后下载文件的大小: get-size
java -jar bundletool-xxx.jar get-size total --apks=my.apks
更多命令的用法可查看 bundletool官方文档。

四、打包发布流程

  1. 工具栏中选择进行应用签名
    Android aab的打包、调试、安装_第5张图片
  2. 选择Android APP Bundle --> NextAndroid aab的打包、调试、安装_第6张图片
  3. 填写签名信息 --> Next
    Export encrypted key for enrolling published apps in google play app signing,不需要的可以取消勾选
    Android aab的打包、调试、安装_第7张图片
  4. 选择想要的版本和文件输出路径 --> Finish
    Android aab的打包、调试、安装_第8张图片
    至此,整个aab打包就完成了,产出后的.aab文件可以直接上传到google play控制台的版本发布,发布后再次从play store下载到的就是新组合的apk,下载大小会有明显变化。上架play store还在使用apk的同学赶紧动起来吧!

你可能感兴趣的:(Android技术,Android问题解决,Android,aab,google,play)