前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >下一代Android渠道打包工具

下一代Android渠道打包工具

作者头像
非著名程序员
发布2018-02-02 19:38:33
1.5K1
发布2018-02-02 19:38:33
举报
文章被收录于专栏:非著名程序员非著名程序员

前面我们曾经讲过两种Android的渠道打包方式,包括其中的原理都有所涉及。今天给大家讲解的是packer-ng-plugin简称packer,号称是下一代的Android渠道打包工具。估计应该有人在使用了,会的同学可以略过今天的这篇推送,去学习其他内容吧,没有使用过的就往下看。

在讲这个号称:下一代Android渠道打包工具之前,我们先来回顾一下原来基础的打包原理和美团的多渠道打包原理。这里我就不过多介绍了,没看过之前文章的,点击下方链接进行复习即可。

Android Studio 使用Gradle多渠道打包 美团多渠道打包方案详解,速度快到白驹过隙

回顾完之前的打包方式原理的讲解,现在我们正式开始讲解这个packer-ng-plugin的讲解。

项目介绍

packer-ng-plugin 是下一代Android渠道打包工具Gradle插件,支持极速打包,100个渠道包只需要10秒钟,速度是 gradle-packer-plugin 的300倍以上,可方便的用于CI系统集成,支持自定义输出目录和最终APK文件名,依赖包: com.mcxiaoke.gradle:packer-ng:1.0.5 简短名:packer,可以在项目的 build.gradle 中指定使用,还提供了命令行独立使用的Java和Python脚本。

实现原理

Android应用使用的APK文件就是一个带签名信息的ZIP文件,根据 ZIP文件格式规范,每个ZIP文件的最后都必须有一个叫 Central Directory Record 的部分,这个CDR的最后部分叫”end of central directory record”,这一部分包含一些元数据,它的末尾是ZIP文件的注释。注释包含Comment Length和File Comment两个字段,前者表示注释内容的长度,后者是注释的内容,正确修改这一部分不会对ZIP文件造成破坏,利用这个字段,我们可以添加一些自定义的数据,PackerNg项目就是在这里添加和读取渠道信息。

优势和缺点

优点

  • 使用APK注释字段保存渠道信息和MAGIC字节,从文件末尾读取渠道信息,速度快
  • 实现为一个Gradle Plugin,支持定制输出APK的文件名等信息,方便CI集成
  • 提供Java版和Python的独立命令行脚本,不依赖Gradle插件,支持独立使用
  • 由于打包速度极快,单个包只需要5毫秒左右,可用于网站后台动态生成渠道包

缺点

  • 没有使用Android的productFlavors,无法利用flavors条件编译的功能

使用方式

配置项目根目录的 build.gradle
代码语言:javascript
复制
buildscript {
    ......
    dependencies{
    // add packer-ng
        classpath 'com.mcxiaoke.gradle:packer-ng:1.0.5'
    }
}
配置moudle级别gradle
代码语言:javascript
复制
apply plugin: 'packer' 

dependencies {
    // add packer-helper
    compile 'com.mcxiaoke.gradle:packer-helper:1.0.5'
}

特别注意:packer-ng 和 packer-helper 的版本号需要保持一致

动态设置渠道号
代码语言:javascript
复制
// 如果没有使用PackerNg打包添加渠道,默认返回的是""
// com.mcxiaoke.packer.helper.PackerNg
final String market = PackerNg.getMarket(Context)
// 或者使用 PackerNg.getMarket(Context,defaultValue)
// 之后就可以使用了,比如友盟可以这样设置
AnalyticsConfig.setChannel(market)

提示:PackerNg.getMarket(Context)内部缓存了结果,不会重复解析APK文件

打包方式

可以通过两种方式指定 market 属性,根据需要选用:

  • 打包时命令行使用 -Pmarket= yourMarketFilePath 指定属性
  • 在 gradle.properties 里加入 market=yourMarketFilePath

market是你的渠道名列表文件,market文件是基于项目根目录的 相对路径 ,假设你的项目位于 ~/github/myapp 你的market文件位于 ~/github/myapp/config/markets.txt 那么参数应该是 -Pmarket=config/markets.txt,一般建议直接放在项目根目录,如果market文件参数错误或者文件不存在会抛出异常。

关于渠道文本的配置,就是纯文本文件,每行一个渠道号,也可以添加注释,就是渠道号后面加#再加注释即可。 例如:

代码语言:javascript
复制
xiaomi#小米渠道
google#谷歌渠道
qq#应用宝渠道

命令行执行:

代码语言:javascript
复制
./gradlew -Pmarket=markets.txt clean apkRelease

打完包之后,就可以在${项目根目录}/build/archives/ 目录找到最终的渠道包了。

packer-ng-plugin也提供了一些自定义配置,比如输入的apk的命名方式,具体参考原文,同时提供了java和python的命令行脚本,供集成到持续集成环境中,具体参考命令行打包脚本。

详情使用方式的讲解和源码插件地址:https://github.com/mcxiaoke/packer-ng-plugin

就是这么简单。会了吧,赶紧去试试吧。

● ● ●

掘金是一个高质量的技术社区,从 RxJava 到 Android Studio,性能优化到优秀开源库,让你不错过 Android 开发的每一个技术干货。长按图片二维码识别或者各大应用市场搜索「掘金」,技术干货尽在掌握中。

点击阅读原文,了解详情。

本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2016-08-04,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 非著名程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 项目介绍
  • 实现原理
  • 优势和缺点
  • 使用方式
    • 配置项目根目录的 build.gradle
      • 配置moudle级别gradle
        • 动态设置渠道号
          • 打包方式
          相关产品与服务
          持续集成
          CODING 持续集成(CODING Continuous Integration,CODING-CI)全面兼容 Jenkins 的持续集成服务,支持 Java、Python、NodeJS 等所有主流语言,并且支持 Docker 镜像的构建。图形化编排,高配集群多 Job 并行构建全面提速您的构建任务。支持主流的 Git 代码仓库,包括 CODING 代码托管、GitHub、GitLab 等。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
          http://www.vxiaotou.com