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

一套代码达到以下效果:

  • 打包不同applicationId能同时安装在同一手机上
  • 不同logo,app名称,
  • 不同第三方SDK接入配置(例如微信分享appid,激光推送appkey)
  • 能区分debug和release配置
  • 使用到的功能:productFlavor和buildTypes

原理:优先级buildTypes大于productFlavor

示例:一套代码为两家银行打包apk

1. 修改build.gradle。buildTypes保持默认debug和release两种设置即可,android节点内添加两个productFlavor。

flavorDimensions 'bank'
productFlavors {
 icbc {
 dimension = 'bank'
 applicationId='com.icbc.mobilebank
 manifestPlaceholders = [bankName: '工商银行']
 }
 ccb {
 dimension = 'bank'
 applicationId = 'com.cbc. mobilebank
 manifestPlaceholders = [bankName: '建设银行']
 }
}

2. 修改src\main\AndroidManifest.xml,使用"${bankName}"和${applicationId}替换相应位置

  2.1 设置app名称,android:label="${bankName}",切记tools:replace要加上android:label。(App logoandroid:icon也可以利用这个方法来区分,但更推荐后面的方法)

<application
android:name="com.dhcc.app.application.MyApplication"
android:allowClearUserData="true"
android:icon="@drawable/logo"
android:label="${bankName}"
android:largeHeap="true"
android:networkSecurityConfig="@xml/network_security_config"
tools:replace="android:name,android:label"
tools:targetApi="n">

2.2 设置所有android:authorities,例如

<provider
android:name="android.support.v4.content.FileProvider"
android:authorities="${applicationId}. FileProvider "
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths" />
</provider>

<provider android:name="cn.jpush.android.service.DataProvider"
android:process=":pushcore"
android:authorities="${applicationId}.DataProvider" android:exported="false" />

  2.3引用了第三方sdk,例如极光推送需要修改

<permission android:name="${applicationId}.permission.JPUSH_MESSAGE"
android:protectionLevel="signature" />
<permission android:name="${applicationId}.permission.MIPUSH_RECEIVE"
android:protectionLevel="signature" />

3.在src\main同级目录添加三个文件夹"icbc ",""icbcRelease,"release "。选择icbcRelease编译时,编译器会按照" icbcRelease > release>icbc>main"这样的优先级合并同名文件编译。

4. 根据上面的优先级,设置图片资源。参照main\res\drawable\logo.png文件层级一样,给文件夹添加自定义app logo,如果你icbc在debug和release用同一个logo,那就只在icbc文件夹添加即可。

5. 设置字符串xml资源。

  5.1 新建src\main\res\values\configs.xml,放置一些各银行不一样的参数。也可以不增加configs.xml文件,直接追加在strings.xml内。

<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="WXAPPId">XXXXXXXXXXXXXXX</string>
<string name="JPUSH_APPKEY">XXXXXXXXXXXXXXXXXX</string>
</resources>

  5.2 根据实际情况为"icbc ",""icbcRelease,"release "增加对应configs.xml。可以只增加JPUSH_APPKEY,那么WXAPPId会使用main的值。

  5.3 AndroidManifest.xml等xml文件中按"@string/JPUSH_APPKEY "使用

  5.4activity代码中使用方法:"this.getString(R.string.resource_name);"或者"this.getString(R.string.resource_name);"

  5.5在其他java文件使用方法(必须有Context或pplication):"context.getString(R.string.resource_name);"或"application.getString(R.string.resource_name);"

其它建议:

1. 其它任何文件包括java也可以用这样的优先级,达到不同包打出不同逻辑的效果。

2. Logo,configs.xml内的参数也可以在manifestPlaceholders各自定义达到不同flavor不同效果,但无法产生"icbc ","icbcRelease","icbcDebug","release ","debug"这样的多种组合各不相同的效果。同时java代码中取manifestPlaceholders中的值比取configs.xml的值麻烦。所以推荐各自建立不同文件夹,以后如果要删除一个银行的配置也容易。

总结

到此这篇关于Android Studio中一套代码多渠道打包的文章就介绍到这了,更多相关Android Studio多渠道打包内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Android 多渠道(友盟)打包教程分享

    我们在 app 正式发布的时候一定会使用正式签名的方式来打包,这种方式只能生成唯一的一个包,但是如今的应用商店非常多,如:小米.OPPO.360.百度.豌豆荚.应用宝等等.而我们只有一个 apk 文件要投入到这么多的应用商店中去,如果你的公司不需要统计每个应用商店的实际下载使用量的话,那倒是不会有这样的问题. 但是,如果你的公司就是需要统计每个商店的实际下载使用情况,那么你将如何去识别当前用户是从哪一个商店下载来的呢?出现问题原因是:我们使用的 apk 安装包当前仅有一个. 假设,我们可以向 a

  • Android Studio多渠道打包的配置方法

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

  • Android Gradle多渠道打包的实现方法

    一.前言 什么是多渠道打包以及多渠道打包可以做什么,这里就不做介绍了,相信看到这篇文章的你已经了解了,多渠道打包的方式比较多,这里我们用Gradle多渠道打包方式. 和其他文章有什么不同 网上看到的大多数文章都只讲解了 1.如何修改包名 2.如何修改变量的值 3.如何替换string中的资源 4.如何替换AndroidManifest中的资源 本篇文章会在上述知识点上增加 5.不同渠道如何使用不同的java文件 6.Base模块化中如何使用多渠道 新建项目,在app下build.gradle中a

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

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

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

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

  • Android使用Walle实现多渠道打包功能的实现示例

    目录 介绍 使用 对应的属性: 可使用以下变量: 介绍 Walle(瓦力)是Android Signature V2 Scheme签名下的新一代渠道包打包神器. 瓦力通过在Apk中的APK Signature Block区块添加自定义的渠道信息来生成渠道包,从而提高了渠道包生成效率,可以作为单机工具来使用,也可以部署在HTTP服务器上来实时处理渠道包Apk的升级网络请求. 使用 使用Walle生成多渠道的速度是很快的,原来的项目打一个包就需要两分钟多,每次发布打7个包需要十几分钟.用了Walle

  • Android Studio多渠道打包套路

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

  • Android几种多渠道打包的步骤详解

    1.什么是多渠道打包 在不同的应用市场可能有不同的统计需求,需要为每个应用市场发布一个安装包,这里就引出了Android的多渠道打包.在安装包中添加不同的标识,以此区分各个渠道,方便统计app在市场的各种. 2.几种打包方式 友盟 UMeng Android Studio自带 美团 Walle 3.开始使用 3.1 友盟UMeng 第一步:在AndroidManifest中添加 <meta-data android:name="UMENG_CHANNEL" android:val

  • Android使用美团多渠道打包方案详解

    Andorid渠道市场有多分散呢?分散到比Android碎片化还严重,你还在为多渠道打包而头疼吗?美团提供了速度快到白驹过隙的多渠道打包方案.说的有点夸张,对,虽然夸张,但是确实很快,不夸张不足以形容其快.废话不多说,先讲原理,再讲实践方法. 新旧打包方法原理对比讲解 传统方式 在AndroidManifest定义渠道的年代,多渠道打包无非以下两种方案: 方案一:完全的重新编译,即在代码重新编译打包之前,在AndroidManifest中修改渠道标示: 方案二:通过ApkTool进行解包,然后修

  • 使用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

随机推荐