Android使用walle多渠道打包_android walle打包原理-程序员宅基地

转载:https://github.com/Meituan-Dianping/walle

Walle

瓦力,Android Signature V2 Scheme签名下的新一代渠道包打包神器

瓦力通过在Apk中的APK Signature Block区块添加自定义的渠道信息来生成渠道包,从而提高了渠道包生成效率,可以作为单机工具来使用,也可以部署在HTTP服务器上来实时处理渠道包Apk的升级网络请求。

Quick Start

为了方便大家的使用,我们提供了2种使用方式:

  • Gradle插件方式,方便快速集成
  • 命令行方式,最大化满足各种自定义需求

Gradle插件使用方式

配置build.gradle

在位于项目的根目录 build.gradle 文件中添加Walle Gradle插件的依赖, 如下:

buildscript {
    dependencies {
        classpath 'com.meituan.android.walle:plugin:1.1.3'
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5

并在当前App的 build.gradle 文件中apply这个插件,并添加上用于读取渠道号的AAR

apply plugin: 'walle'

dependencies {
    compile 'com.meituan.android.walle:library:1.1.3'
}
  • 1
  • 2
  • 3
  • 4
  • 5
配置插件
walle {
    // 指定渠道包的输出路径
    apkOutputFolder = new File("${project.buildDir}/outputs/channels");
    // 定制渠道包的APK的文件名称
    apkFileNameFormat = '${appName}-${packageName}-${channel}-${buildType}-v${versionName}-${versionCode}-${buildTime}.apk';
    // 渠道配置文件
    channelFile = new File("${project.getProjectDir()}/channel")
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

配置项具体解释:

  • apkOutputFolder:指定渠道包的输出路径, 默认值为new File("${project.buildDir}/outputs/apk")
  • apkFileNameFormat:定制渠道包的APK的文件名称, 默认值为'${appName}-${buildType}-${channel}.apk'
    可使用以下变量:

        projectName - 项目名字
        appName - App模块名字
        packageName - applicationId (App包名packageName)
        buildType - buildType (release/debug等)
        channel - channel名称 (对应渠道打包中的渠道名字)
        versionName - versionName (显示用的版本号)
        versionCode - versionCode (内部版本号)
        buildTime - buildTime (编译构建日期时间)
        fileSHA1 - fileSHA1 (最终APK文件的SHA1哈希值)
        flavorName - 编译构建 productFlavors 名
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
  • channelFile:包含渠道配置信息的文件路径。 具体内容格式如下:

    meituan  #美团
    samsungapps  #三星
    hiapk
    anzhi
    xiaomi  #小米
    91com
    gfan
    appchina
    nduoa
    3gcn
    mumayi
    10086com
    wostore
    189store
    lenovomm
    hicloud
    meizu
    wandou
    googleplay  #Google Play
    baidu  #百度
    360cn  #360
    myapp
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    支持使用#号添加注释。

如何获取渠道信息

在需要渠道等信息时可以通过下面代码进行获取

String channel = WalleChannelReader.getChannel(this.getApplicationContext());
  • 1
如何生成渠道包

生成渠道包的方式是和assemble${variantName}Channels指令结合,渠道包的生成目录默认存放在 build/outputs/apk/,也可以通过walle闭包中的apkOutputFolder参数来指定输出目录

用法示例:

  • 生成渠道包 ./gradlew clean assembleReleaseChannels
  • 支持 productFlavors ./gradlew clean assembleMeituanReleaseChannels
更多用法
插入额外信息

channelFile只支持渠道写入,如果想插入除渠道以外的其他信息,请在walle配置中使用configFile

walle {
    // 渠道&额外信息配置文件,与channelFile互斥
    configFile = new File("${project.getProjectDir()}/config.json")
}
  • 1
  • 2
  • 3
  • 4

configFile是包含渠道信息和额外信息的配置文件路径。
配置文件采用json格式,支持为每个channel单独配置额外的写入信息。具体内容格式如下:

{
  //extraInfo 不要出现以`channel`为key的情况
  /*
  不声明extraInfo的channel默认使用的extraInfo
  如果没有此项则没有默认extraInfo
  */
  "defaultExtraInfo": {
    "key2": "20161213",
    "key": "20161212"
  },

  /*
    strategy:
     1. ifNone (默认适用此策略) : 仅当对应channel没有extraInfo时生效
     2. always : 所有channel都生效,channel中extraInfo的key与defaultExtraInfo重复时,覆盖defaultExtraInfo中的内容。
   */

  //"defaultExtraInfoStrategy": "always",

  "channelInfoList": [
    {
      "channel": "meituan",
      // 此channel将使用自己声明的extraInfo
      /*
      此alias可以做到写入apk的channel是meituan,而打包时输出的文件名是美团
      注意:alias不声明时,walle配置apkFileNameFormat中channel就是channel,否则为alias
      */
      "alias": "美团",
      "extraInfo": {
        "buildtime": "20161212",
        "hash": "123"
      }
    },
    {
      "channel": "360cn",
      // 此channel将使用自己声明的extraInfo
      "extraInfo": {
        "key": "20161213"
      }
    },
    {
      "channel": "googleplay"
      // 此channel将使用defaultExtraInfo
    },
    {
      "channel": "xiaomi"
      // 此channel将使用defaultExtraInfo
    },
    {
      "channel": "meizu"
      // 此channel将使用defaultExtraInfo
    },
    {
      "channel": "wandoujia",
      "excludeDefaultExtraInfo": true
      //强制声明不使用defaultExtraInfo,默认false
    },
    {
      "channel": "myapp",
      "excludeDefaultExtraInfo": true,
      //强制声明不使用defaultExtraInfo,默认false
      "extraInfo": {
        // 尽管exclude default,但也可以继续写入自己的。
        "key": "20161212"
      }
    }
  ]
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68

注意:

  • 此配置项与channelFile功能互斥,开发者在使用时选择其一即可,两者都存在时configFile优先执行。
  • extraInfo 不要出现以channel为key的情况

而对应的渠道信息获取方式如下:

ChannelInfo channelInfo= WalleChannelReader.getChannelInfo(this.getApplicationContext());
if (channelInfo != null) {
   String channel = channelInfo.getChannel();
   Map<String, String> extraInfo = channelInfo.getExtraInfo();
}
// 或者也可以直接根据key获取
String value = WalleChannelReader.get(context, "buildtime");
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
临时生成某渠道包

我们推荐使用channelFile/configFile配置来生成渠道包,但有时也可能有临时生成渠道包需求,这时可以使用:

  • 生成单个渠道包: ./gradlew clean assembleReleaseChannels -PchannelList=meituan
  • 生成多个渠道包: ./gradlew clean assembleReleaseChannels -PchannelList=meituan,dianping
  • 生成渠道包&写入额外信息:

    ./gradlew clean assembleReleaseChannels -PchannelList=meituan -PextraInfo=buildtime:20161212,hash:xxxxxxx

    注意: 这里的extraInfo以key:value形式提供,多个以,分隔。

  • 使用临时channelFile生成渠道包: ./gradlew clean assembleReleaseChannels -PchannelFile=/Users/xx/Documents/channel
  • 使用临时configFile生成渠道包: ./gradlew clean assembleReleaseChannels -PconfigFile=/Users/xx/Documents/config.json

使用上述-P参数后,本次打包channelFile/configFile配置将会失效,其他配置仍然有效。
-PchannelList,-PchannelFile, -PconfigFile三者不可同时使用。

命令行工具使用方式

walle-cli是walle提供的命令行程序,可以使用该工具来支持各类自定义的需求,具体使用方式如下:

获取信息

显示当前apk中的渠道和额外信息:

java -jar walle-cli-all.jar show /Users/Meituan/app/build/outputs/apk/app.apk
  • 1
写入信息

写入渠道

java -jar walle-cli-all.jar put -c meituan /Users/Meituan/Downloads/app.apk
  • 1

写入额外信息,不提供渠道时不写入渠道

java -jar walle-cli-all.jar put -c meituan -e buildtime=20161212,hash=xxxxxxx /Users/xxx/Downloads/app.apk
  • 1

指定输出文件,自定义名称。 不指定时默认与原apk包同目录。

java -jar walle-cli-all.jar put -c meituan /Users/Meituan/Downloads/app.apk /Users/xxx/Downloads/app-new-hahha.apk
  • 1
批量写入
命令行指定渠道列表
java -jar walle-cli-all.jar batch -c meituan,meituan2,meituan3 /Users/walle/app/build/outputs/apk/app.apk
  • 1
指定渠道配置文件
java -jar walle-cli-all.jar batch -f /Users/Meituan/walle/app/channel  /Users/Meituan/walle/app/build/outputs/apk/app.apk
  • 1

输出目录可指定,不指定时默认在原apk包同目录下。

指定渠道&额外信息配置文件
java -jar walle-cli-all.jar batch2 -f /Users/Meituan/walle/app/config.json  /Users/Meituan/walle/app/build/outputs/apk/app.apk
  • 1

输出目录可指定,不指定时默认在原apk包同目录下。

更多用法

获取cli所有功能

java -jar walle-cli-all.jar -h
  • 1

其他使用方式

为了更好的满足大家的各类自定义需求,我们把对APK Signing Block区块进行读写操作的模块进行了封装。

读写模块的使用说明如下:

  • APK Signing Block读取模块:

    payload_reader

    dependencies {
       compile 'com.meituan.android.walle:payload_reader:1.1.6'
    }
    • 1
    • 2
    • 3

    本库对外提供两个读取类:

    • ChannelReader:读取Walle内置id对应的信息,一般用来存放渠道和额外信息。
    • PayloadReader: 读取自定义id对应的信息。
    注意

    非Android系统使用此jar包时需要添加org.json依赖

    compile 'org.json:json:20080701'
    • 1

    备注:这么做主要是为了减少android方法数,利用系统自带的org.json

  • APK Signing Block写入模块:

    payload_writer

    dependencies {
       compile 'com.meituan.android.walle:payload_writer:1.1.6'
    }
    • 1
    • 2
    • 3

    本库对外提供两个写入类:

    • ChannelWriter:向Walle内置id对应区域写入/移除信息,一般存放渠道和额外信息。额外信息key相同时覆盖写入。
    • PayloadWriter: 自定义id写入,id相同时覆盖。
      注意:请确保Android未使用此id
    注意

    非Android系统使用此jar包时需要添加org.json依赖

    compile 'org.json:json:20080701'
    • 1

    备注:这么做主要是为了减少android方法数,利用系统自带的org.json

原理介绍

对该工具的原理感兴趣的同学,可以移步美团Android新一代渠道包生成工具进行了解。

注意事项

使用apksigner重新对Apk签名会导致渠道信息丢失,需要再次写入渠道信息。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/SXS120730/article/details/79384300

智能推荐

tensorflow GPU安装及测试_测试tensorflowgpu csdn-程序员宅基地

文章浏览阅读1.8w次。# 一、TensorFLow-Gpu环境的搭建## 查看nvidia的型号以便安装相应的驱动lspci | grep -i nvidia#这一步非常的重要,一定要看清楚自己的驱动型号,以便能够找到正确的cuda和cudnn的型号 ## 禁用nouveau#在安装cuda的时候,由于涉及到NVIDIA驱动的安装,使得nouveau驱动与NVIDIA驱动冲突,为了能够继续安装,必须禁..._测试tensorflowgpu csdn

【Web API系列教程】2.1 — ASP.NET Web API中的路由机制_apicontroller 路由定义-程序员宅基地

文章浏览阅读5.5k次,点赞2次,收藏7次。这篇文章描述了ASP.NET Web API如何将HTTP请求发送(路由)到控制器。备注:如果你对ASP.NET MVC很熟悉,你会发现Web API路由和MVC路由非常相似。主要区别是Web API使用HTTP方法来选择动作(action),而不是URI路径。你也可以在Web API中使用MVC风格的路由。这篇文章不需要ASP.NET MVC的任何知识。路由表在ASP.NET Web API中,控_apicontroller 路由定义

Qslider样式_qslider 样式-程序员宅基地

文章浏览阅读1.3k次。QSlider::groove:horizontal {border: 1px solid #bbb;background: white;height: 10px;border-radius: 4px;}QSlider::sub-page:horizontal {background: qlineargradient(x1: 0, y1: 0, x2: 0, y2: 1,stop:..._qslider 样式

TensorFlow2.0 学习笔记(五):循环神经网络(RNN)_tensorflow2.0 rnn-程序员宅基地

文章浏览阅读4.5k次,点赞9次,收藏50次。专栏——TensorFlow学习笔记文章目录专栏——TensorFlow学习笔记一、什么是RNN二、文本生成1_读取文本2_模型实现3_超参数4_模型训练5_模型预测6_完整代码推荐阅读参考文章一、什么是RNN循环神经网络(Recurrent Neural Network, RNN) 是一种适宜于处理 序列数据 的神经网络,被广泛用于语言模型、文本生成、机器翻译等。基础知识可以看一下这个英文..._tensorflow2.0 rnn

C语言 三向字符串快速排序_三个字符串排序c语言-程序员宅基地

文章浏览阅读692次。三向字符串快速排序 在将字符串数组排序时,根据首字母进行三向切分,然后(递归地)将得到的三个子数组排序:一个含有所有首字母小于切分字符的字符串子数组,一个含有所有首字母等于切分字符的字符串的子数组(排序时忽略它们的首字母),一个含有所有首字母大于切分字符的字符串的子数组。代码实现#include &amp;amp;amp;amp;amp;lt;stdio.h&amp;amp;amp;amp;amp;gt;#include &amp;amp;amp;amp;am_三个字符串排序c语言

wince 移植_wince移植-程序员宅基地

文章浏览阅读1.9k次。近期,公司让我负责一个嵌入式消费产品的开发项目。此产品原来的操作系统是WinCE 5.0,现在因应市场需求不但要增加功能更加强大的硬件,而且公司也要求把操作系统升级为WinCE 6.0。在接手此项目后,我立即开始进行操作系统的定制开发,但结果却是欲速则不达。 后来,我在时_wince移植

随便推点

文本-----wangEditor的使用,设置和获取内容,展示HTML无样式怎么办????console同步展示怎样写,Vue的配置在Vue3配置文件中的配置,是editor中的v-model绑定的值_wangeditor sethtml-程序员宅基地

文章浏览阅读405次,点赞8次,收藏5次。【代码】文本-----wangEditor的使用,设置和获取内容,展示HTML无样式怎么办????console同步展示怎样写,在onChange事件中配置,编辑器配置,Vue的配置在Vue3配置文件中的配置。_wangeditor sethtml

京东科技全链路故障诊断智能运维实践-程序员宅基地

文章浏览阅读161次。本文根据张静老师在〖2023 中国数据智能管理峰会-上海站〗现场演讲内容整理而成。讲师介绍张静,京东科技智能运维算法高级经理。硕士毕业于东北大学,持续深耕智能运维领域多年,带领团队致力于京东智能运维算法迭代,把智能算法能力落地京东线上横向业务场景,算法在监控、数据库、网络、资源调度等多个纵向场景取得突破,提升了产品和运维的技术竞争力。善于将实践中沉淀的技术与日常算法工作中积累的技术与创新总结成专利..._京东 全链路跟踪

kernel 2.6.34 配置文件 (thinkpad sl400)_kernel_version or cpu_arch: ' 5.15 x86_64 ' not me-程序员宅基地

文章浏览阅读3.7k次。## Automatically generated make config: don't edit# Linux kernel version: 2.6.34-gentoo# Wed Jun 2 21:12:35 2010#CONFIG_64BIT=y# CONFIG_X86_32 is not setCONFIG_X86_64=yCONFIG_X86=y

LaTex的Beamer中的数学公式与论文中的数学公式不一样的解决办法_latex beamer 公式-程序员宅基地

文章浏览阅读2.2k次。同样的 latex 数学公式,在论文 (Article)模板中显示格式与在幻灯片( Beamer) 中的显示风格是不一样的,Beamer中的数学公式是如此丑陋不堪。\begin{equation}\mathcal{L}_{D}=\mathbb{E}_{x\sim P_{data}}[-\log D(x)]+\mathbb{E}_{z\sim P_{z}}[-\log (1-D(G(z)))]\label{equ-1}\end{equation}论文中的公式为:Beamer中的公式为:风格_latex beamer 公式

sap事务代码如何收藏_SAP GUI里的收藏夹事务码管理工具-程序员宅基地

文章浏览阅读254次。本文是2020年第13篇原创文章,也是汪子熙公众号总共第196篇原创文章。今天是2020年1月20日,农历大年二十六,年味渐浓。Jerry的老家,从成都乘坐高铁只要十五分钟就能到达,所以从来不会遭受春运长途跋涉之苦。这里我提前祝愿广大SAP从业者在除夕之前,都能够平安顺利到家,和自己的亲人团聚。最近Jerry的业余时间,忙着分析成都市成华,青羊,武侯,金牛,高新,龙泉驿,锦江这七个区的小学二年级语..._sap如何收藏指令

基于MATLAB的图像识别-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏8次。接下来,我们将图像尺寸调整为模型所需的输入尺寸,并加载预训练的模型。MATLAB提供了多种强大的机器学习和深度学习工具箱,其中包含了许多经典的图像识别算法和预训练模型。MATLAB是一种功能强大的计算机软件,具备丰富的图像处理和分析工具,因此非常适用于图像识别任务。通过适当的预处理和选择合适的识别算法,我们可以实现准确和高效的图像识别应用。通过加载图像数据、预处理图像、选择适当的识别算法和模型,我们可以实现准确和高效的图像识别应用。读取图像后,我们可以对其进行预处理,以提高识别的准确性。_基于matlab的图像识别