Android多渠道打包总结(推荐)

多渠道打包一般应用于向不同应用市场提交app后用来统计不同渠道下载量等一些信息。一般集成友盟sdk(同类型的sdk还有 诸葛io,量江湖等sdk),不同sdk集成方式大同小异,可去各自官网查看详细文档。本文以友盟sdk为例。
渠道:各种应用市场比如 华为应用市场,小米应用市场, 积分墙(花钱的推广渠道)等。

一,android自带gradle打包

首先集成友盟sdk,集成方式参照友盟sdk集成,在项目的build.gradle文件中加入以下代码

  productFlavors {
    yingyongbao {}
    oppo {}
  }
  productFlavors.all {
    flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
  }

修改生成的apk名字

  applicationVariants.all{ variant->
    variant.outputs.each { output->
      def oldFile = output.outputFile
      if(variant.buildType.name.equals('release')){
        def releaseApkName = ''+variant.productFlavors[0].name +"-"+defaultConfig.versionName+ '.apk'
        output.outputFile = new File(oldFile.parent, releaseApkName)
      }

    }

  }

在AndroidManifest.xml中加入友盟的集成代码以及权限

  <meta-data
      android:name="UMENG_APPKEY"
      android:value="Your key" />
    <!-- <meta-data android:value="faqiao" android:name="UMENG_CHANNEL"/> -->
    <meta-data
      android:name="UMENG_CHANNEL"
      android:value="${UMENG_CHANNEL_VALUE}" /> //这里改成对应build.gradle中的 productFlavors.all 对应的字符串

然后选择你要打包的渠道就 可以了

->

缺点:如果渠道过多这种打包方式很费时间20个渠道包差不多要40分钟的时间。

二 美团walle(瓦力)打包

一些大厂的渠道会多到惊人,美团会有900+的渠道要是按上面的打包方式2*900肯定是不行的。美团技术大牛们也在一直研究快速多渠道打包方法。

在这介绍美团最新的walle打包,之前美团还有一个打包方式是通过python脚本修改apk(apk也是一个压缩包)中的一个配置文件的名称,配置文件名称也就是渠道名称从而打不不同的包,这种速度很快,但是从android7.0以后android加入了APK Signature Scheme v2打包方式,因为这种打包方式改变的包里面的内容所以apk在7.0以后的系统中安装会提示安装失败。

在此推荐美团walle打包,此种方式是不通过外部修改配置文件的方式打包具体打包细节可参考美团walle打包

集成方式

首先build.gradle中

apply plugin: 'walle'

  walle {
    // 指定渠道包的输出路径
//    apkOutputFolder = new File("${project.buildDir}/outputs/channels");
    apkOutputFolder = new File("D:/Android/outputs/user/channels");
    // 定制渠道包的APK的文件名称
//    apkFileNameFormat = '${appName}-${packageName}-${channel}-${buildType}-v${versionName}-${versionCode}-${buildTime}.apk';
    apkFileNameFormat = 'app-${channel}-v${versionName}.apk';
    // 渠道配置文件
    channelFile = new File("${project.getProjectDir()}/channel")
  }

dependencies {
 compile 'com.meituan.android.walle:library:1.1.6'//美团多渠道打包
}

这里的 channelFile是一个channel(渠道的一个配置文件)放在该工程的对应的目录下

apkOutputFolder 是apk包生成的位置,可更改

该文件用editplus文件编辑器打开格式如下:

然后在 工程的 build.gradle中加入

 dependencies {
    classpath 'com.meituan.android.walle:plugin:1.1.6'
  }

这种打包方式不是更改AndroidManifest的方式,所以先把AndroidManifest中的配置友盟渠道的代码注释掉:

 <!--<meta-data-->
      <!--android:name="UMENG_APPKEY"-->
      <!--android:value="your key" />-->
    <!--<!– <meta-data android:value="faqiao" android:name="UMENG_CHANNEL"/> –>-->
    <!--<meta-data-->
      <!--android:name="UMENG_CHANNEL"-->
      <!--android:value="channel" />-->

通过调用walle的方法获取到的channel的名称,所以需要在app初始化的 BaseApplication中初始化友盟的channel配置信息。

 private void initUmeng(){
    String appkey = "your appkey";
    String channelId = WalleChannelReader.getChannel(this.getApplicationContext());
    //初始化友盟配置信息 通过代码方式配置友盟的渠道信息
     MobclickAgent.UMAnalyticsConfig config =
        new MobclickAgent.UMAnalyticsConfig(this, appkey, channelId);
  }

配置好了那么就开始打包了,在as自带的命令输入框输入打包命令,等两分钟左右所有的渠道包就打完了!

出现BUILD SUCCESSFUL 就说明打包成功了


常用的walle打包命令

//生成所有渠道包
gradlew clean assembleReleaseChannels
// 生成单个渠道包:
gradlew clean assembleReleaseChannels -PchannelList=meituan

//生成多个渠道包:
gradlew clean assembleReleaseChannels -PchannelList=meituan,dianping

总结

如果没有渠道的限制一般用as自带的gradle打包就可以,如果渠道过多推荐使用walle打包。文中介绍的美团的python打包方式现在还有一些开发者在用,因为那种方法在构建基础apk包的时候 不选用v2打包方式是没有问题的,但是我认为v2的签名打包方式更符合现在的趋势吧,所以推荐是用美团的walle打包方式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android studio 3.0上进行多渠道打包遇到的问题小结(超简洁版)

    Error:All flavors must now belong to a named flavor dimension. The flavor 'xiaomi' is not assigned to a flavor dimension. Learn more at https://d.android.com/r/tools/flavorDimensions-missing-error-message.html Android studio 3.0上进行多渠道打包时编译时出现这个错误 多渠道

  • android 二次打包完成apk多渠道打包的方法

    本文介绍将渠道号写入assets文件里面,通过解压apk修改assets里的文件,用Java代码生成jarsigner脚本并运行脚本二次打包的方式来获取新的渠道包 此打包方式一个渠道包只需要5秒左右,可实现快速打渠道包 对于为了在assets获取渠道号来打渠道包的方法,其实很简单,你只要知道apk里面装的什么东西,就会了 将apk用压缩方式解压,你会得到像 这样的文件列表,其中就有assets文件夹:当然前提条件是你在项目中必须创建assets文件夹.既然有了这个文件夹,安卓里面又能通过代码获取

  • Android Studio多渠道打包、自定义打包APK名称

    现在为了推广产品,会在多个渠道应用市场发布应用,为了统计不同渠道的数据,需要在应用中表明渠道,如果一个一个去修改打包效率会很低.AS为我们提供了简便的方法,可以多渠道打包,一次打包所有的渠道包. 1. AS 2.x多渠道打包 (1) AndroidManifest中增加节点 <!-- 多渠道打包 --> ... <meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VAL

  • Android Studio多渠道批量打包及代码混淆

    一.批量打包 1.集成了友盟统计,并在AndroidManifest.xml中添加了如下代码 <meta-data android:name="UMENG_CHANNEL" android:value="${CHANNEL_VALUE}"/> 2.在app的build.gradle的android标签下添加如下代码: productFlavors { myapp {} _360 {} appchina {} hiapk {} } productFlavo

  • Android 7.0中新签名对多渠道打包的影响详解

    老签名多渠道打包原理 前言 由于Android7.0发布了新的签名机制,加强了签名的加固,导致在新的签名机制下无法通过美团式的方式再继续打多渠道包了.不过在说新的签名机制对打包方案的 影响和为什么会影响我们原有的打包机制之前,需要先简单理解下打包原理和签名在整个打包过程中的作用. Android打包流程 Android打包过程大致如图所示,整个流程就是将Java代码,资源文件以及第三方库整合成一个Apk文件,并对整合后的文件进行签名和优化对齐.整个过程可以简 单分为以下几个步骤: 资源预编译 为

  • Android多渠道打包的方法步骤

    本文介绍了Android多渠道打包的方法步骤,分享给大家,具体如下: 1.生成签名文件 点击 Build -> Generate Signed APK: 2.创建一个签名 红色填写部分需要认真填写,并牢记,其余部分随意填写 有了签名,单个app打包我就不详细说了,具体说下多渠道打包的步骤 2.多渠道打包 作用:就是根据不同的渠道值,去具体分析每个渠道的用户情况 步骤一: 在AndroidManifest.xml的application标签里添加一个meta-data标签定义 <meta-dat

  • Android Studio多渠道打包套路

    说到多渠道,这里不得不提一下友盟统计,友盟统计是大家日常开发中常用的渠道统计工具,而我们的打包方法就是基于友盟统计实施的.按照友盟官方文档说明,渠道信息通常需要在AndroidManifest.xml中配置如下值: <meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/> 上面的value值Channel_ID就是渠道标识.我们的期望的就是在编译时候这个值能够自动变化以满足区

  • 使用Android Studio Gradle实现友盟多渠道打包

    最新项目中要求在友盟后台看到不同渠道的统计,Android大大小小的应用市场要几百个,要一个一个手工打包那一天也干不完,还好是有大牛的,弄出了好多解决方法,就Gradle做一下记录和分享,首先看一些理论知识: 1.应用的打包签名 什么是打包? 打包就是根据签名和其他标识生成安装包. 签名是什么? 1.在android应用文件(apk)中保存的一个特别字符串 2.用来标识不同的应用开发者:开发者A,开发者B 3.一个应用开发者开发的多款应用使用同一个签名 就好比是一个人写文章,签名就相当于作者的署

  • Android多渠道打包总结(推荐)

    多渠道打包一般应用于向不同应用市场提交app后用来统计不同渠道下载量等一些信息.一般集成友盟sdk(同类型的sdk还有 诸葛io,量江湖等sdk),不同sdk集成方式大同小异,可去各自官网查看详细文档.本文以友盟sdk为例. 渠道:各种应用市场比如 华为应用市场,小米应用市场, 积分墙(花钱的推广渠道)等. 一,android自带gradle打包 首先集成友盟sdk,集成方式参照友盟sdk集成,在项目的build.gradle文件中加入以下代码 productFlavors { yingyong

  • 关于Android多渠道打包的进阶知识

    多渠道打包进阶知识 文章开始前,先看一下下面这种情况: android { productFlavors { //100 个多渠道配置 } //多渠道签名的配置 signingConfigs { xiaomi { storeFile file("../xiaomi.keystore") storePassword 'xiaomi' keyAlias 'xiaomi' keyPassword 'xiaomi' v1SigningEnabled true v2SigningEnabled

  • Android 多渠道打包进阶版

    目录 Android 多渠道打包进阶版 1.资源文件配置 2.依赖配置 3.签名配置 上一篇文章链接//www.jb51.net/article/221446.htm Android 多渠道打包进阶版 文章开始前,先看一下下面这种情况: android { productFlavors { //100 个多渠道配置 } //多渠道签名的配置 signingConfigs { xiaomi { storeFile file("../xiaomi.keystore") storePassw

  • Android 多渠道打包详细

    目录 Android 多渠道打包 一.多渠道配置 二.打包 1.多渠道配置 2.命令行打包 2.编译器打包 Android 多渠道打包 一.多渠道配置 多渠道配置: 不同渠道不同签名配置 不同渠道不同资源文件配置 不同渠道不同依赖配置 二.打包 打包可分为:编译器打包.命令行打包.IDE 打包 1.多渠道配置 (1)可写在主模块(app)的 build.gradle 下 android { compileSdkVersion 29 buildToolsVersion "29.0.3"

  • 关于Android多渠道打包问题看这一篇就够了

    目录 一.多渠道配置 二.注意事项 Android 多渠道打包看这一篇就够了 本文三个流程 一.多渠道配置 1.多渠道配置 2.不同渠道不同签名配置 3.不同渠道不同资源文件配置 4.不同渠道不同依赖配置 二.注意事项 三.打包 1.命令行打包 2.IDE 打包 多渠道配置(2 种方式) 1.可写在主模块(app)的 build.gradle 下 android { compileSdkVersion 29 buildToolsVersion "29.0.3" defaultConfi

  • Android多渠道打包神器ProductFlavor详解

    目录 一.什么是多渠道打包 1.多版本 2.多环境 3.多渠道 二.多渠道打包的方式(ProductFlavor&&多渠道打包插件) 1.ProductFlavor 1.1 如何是使用ProductFlavor 1.2 如何是使用ProductFlavor加载apk包 1.3 该如何获取不同渠道包的信息 1.4 使用ProductFlavor加载apk包的优缺点 2.多渠道打包插件 一.什么是多渠道打包 在不同的应用市场可能有不同的统计需求,需要为每个应用市场发布一个安装包,这里就引出了A

  • Android多渠道打包时获取当前渠道的方法

    作为Android app,发布多个分发平台是常规操作.然后,有时由于个渠道面对的用户不同,或平台审核标准不同,需要在各渠道使用不同的业务逻辑,这就需要根据渠道使用选择差异化代码. 这里把简单的代码记一下. 首先,分渠道打包很简单. 在项目的build.gradle里设置 android { ... productFlavors { home_site { dimension "money" manifestPlaceholders = [UMENG_CHANNEL_VALUE: &q

  • Android Studio中一套代码多渠道打包的实现方法

    一套代码达到以下效果: 打包不同applicationId能同时安装在同一手机上 不同logo,app名称, 不同第三方SDK接入配置(例如微信分享appid,激光推送appkey) 能区分debug和release配置 使用到的功能:productFlavor和buildTypes 原理:优先级buildTypes大于productFlavor 示例:一套代码为两家银行打包apk 1. 修改build.gradle.buildTypes保持默认debug和release两种设置即可,andro

随机推荐