多渠道打包

红橙Darren 等级 556 0 0
标签: https

Android 多渠道打包看这一篇就够了

本文三个流程

一、多渠道配置

1、多渠道配置
2、不同渠道不同签名配置
3、不同渠道不同资源文件配置
4、不同渠道不同依赖配置

二、注意事项

三、打包

1、命令行打包

2、IDE 打包

多渠道配置(2 种方式)

1、可写在主模块(app)的 build.gradle 下

android {  
  compileSdkVersion 29  
  buildToolsVersion "29.0.3"  

  defaultConfig {  
      applicationId "com.test.moduledemo"  
      minSdkVersion 21  
      targetSdkVersion 29  
      versionCode 1  
      versionName "1.0"  
  }  

  flavorDimensions "versionCode"  

  productFlavors {  
      xiaomi{  
          applicationId  = “com.test.xiaomi"  
          //不同渠道配置不同参数  
          buildConfigField "int", "TEST_VALUE", "1"  
          buildConfigField "String", "TEST_NAME", "\"xiaomi\""  
      }  
      huawei{  
          applicationId = "com.test.huawei"  
          //不同渠道配置不同参数  
          buildConfigField "int", "TEST_VALUE", "2"  
          buildConfigField "String", "TEST_NAME", "\"huawei\""  
      }     
      productFlavors.all {//遍历productFlavors多渠道,设置渠道号(xiaomi 、huawei)  
          flavor -> flavor.manifestPlaceholders.put("CHANNEL", name)  
      }
  }
  applicationVariants.all { variant ->  
      // 打包完成后输出路径
      def name = ((project.name != "app") ? project.name : rootProject.name.replace(" ", "")) + 
      "_" + variant.flavorName + 
      "_" + variant.buildType.name + 
      "_" + variant.versionName + 
      "_" + new Date().format('yyyyMMddhhmm') + ".apk"  
      //相对路径app/build/outputs/apk/huawei/release/
      def path = "../../../../../apk/" //相当于路径 app/apk/
      variant.outputs.each { output ->
          def outputFile = output.outputFile
          if (outputFile != null && outputFile.name.endsWith('.apk')) {
               //指定路径输出
               output.outputFileName = new File(path, name)
          }
      } 
      // 在打包完成后还可以做一些别的操作,可以复制到指定目录,或者移动文件到指定目录
      variant.assemble.doLast {  
          File out = new File(“${project.rootDir}/apk”)  
          variant.outputs.forEach { file ->  
            //复制apk到指定文件夹
            //copy {  
            //  from file.outputFile  
            //  into out  
            //}
         //把文件移动到指定文件夹  
          ant.move file: file.outputFile,  
                 todir: "${project.rootDir}/apk"
        }  
      } 
  }
//多渠道签名的配置
  signingConfigs {
     test {
        storeFile file("../test.keystore")
        storePassword 'test'
        keyAlias 'test'
        keyPassword 'test'
        v1SigningEnabled true
        v2SigningEnabled true
     }
     xiaomi {
        storeFile file("../xiaomi.keystore")
        storePassword 'xiaomi'
        keyAlias 'xiaomi'
        keyPassword 'xiaomi'
        v1SigningEnabled true
        v2SigningEnabled true
     }
     huawei {
        storeFile file("../huawei.keystore")
        storePassword 'huawei'
        keyAlias 'huawei'
        keyPassword 'huawei'
        v1SigningEnabled true
        v2SigningEnabled true
     }
  }
  buildTypes {
       debug {
//        debug这里设置不起作用,可能是编译器的问题?
//         productFlavors.xiaomi.signingConfig signingConfigs.test
//         productFlavors.huawei.signingConfig signingConfigs.test
       }
       release {
           productFlavors.xiaomi.signingConfig signingConfigs.xiaomi
           productFlavors.huawei.signingConfig signingConfigs.huawei
       }
  }
//不同渠道不同资源文件配置
  sourceSets{
      xiaomi.res.srcDirs 'src/main/res-xiaomi'
      huawei.res.srcDirs 'src/main/res-huawei'
  }
//不同渠道不同的依赖文件
  dependencies {
      xiaomiApi('xxxxxxx')
      huaweiImplementation('xxxxxxxx')
  }    
}

2、在项目根目录下(与settings.gradle同目录)新建 flavors.gradle 文件

android {  
 flavorDimensions "versionCode"  

 productFlavors {  
     xiaomi{ 
     applicationId = "com.test.xiaomi"   
         //不同渠道配置不同参数  
         buildConfigField "int", "TEST_VALUE", "1"  
         buildConfigField "String", "TEST_NAME", "\"xiaomi\""  
     }  
     huawei{  
      applicationId = "com.test.huawei"  
         //不同渠道配置不同参数  
         buildConfigField "int", "TEST_VALUE", "2"  
         buildConfigField "String", "TEST_NAME", "\"huawei\""  
     } 
     productFlavors.all {//遍历productFlavors多渠道,设置渠道号(xiaomi 、huawei)  
         flavor -> flavor.manifestPlaceholders.put("CHANNEL", name)  
     } 
 }
// ............ 更多配置
}

在主模块(app)的 build.gradle 下引用该 flavors.gradle 文件即可
apply from: rootProject.file('flavors.gradle')

注意

如果项目较为复杂,有可能通过 buildConfigField 设置不同的渠道包,不同的信息字段有可能失效,则把
buildConfigField "int", "TEST_VALUE", "1"
换成
manifestPlaceholders.put("TEST_VALUE", 1)
然后再 AndroidManifest.xml 里添加

<application>
    <meta-data  
      android:name="TEST_VALUE"  
      android:value="${TEST_VALUE}" />
</application> 

在 代码通过一下操作获取其值:

ApplicationInfo applicationInfo = getPackageManager().getApplicationInfo(getPackageName(),  
  PackageManager.GET_META_DATA);
  int testValue = applicationInfo.metaData.getInt("TEST_VALUE");

打包

命令行打包:

Windows下: gradlew assembleRelease
Mac 下:./gradlew assembleRelease
assembleRelease 是打所有渠道的 Release 包
assembleDebug 是打所有渠道的 Debug 包
还可以打指定渠道的包:
gradlew assembleXiaoMiRelease assembleHuaWeiRelease
(空格隔开要打的渠道包的任务名称即可,任务名称可以通过点击 android studio 右边的 Gradle 根据图中目录查看)

多渠道打包

多渠道打包

多渠道打包

image

编译器打包

多渠道打包

image

多渠道打包

image

多渠道打包

image

当渠道很多的时候,不同渠道不同配置就会变得相当繁琐了,欢迎查看我的下一篇推文多渠道打包-进阶

收藏
评论区

相关推荐

HTTPS
### 最近网站更新为https,于是做个笔记 ### 将域名 [www.domain.com](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Fwww.domain.com) 的证书文件1\_www.domain.com\_bundle.crt 、 ### 私钥文件2\_www.doma
HTTPS
楔子 谣言粉碎机前些日子发布的《[用公共WiFi上网会危害银行账户安全吗?](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Fwww.guokr.com%2Farticle%2F100110%2F)》,文中介绍了在使用HTTPS进行网络加密传输的一些情况,从回复来看,争议还是有的。随着网络越
HTTPS加密原理
http(超文本传输协议) ------------- > 一种属于应用层的协议 缺点: 1. 通信使用明文(不加密),内容可能会被窃听 2. 不验证通信方的身份,因此有可能遭遇伪装 3. 无法证明报文的完整性,所以有可能已遭篡改 优点: 1. 传输速度快 https ----- > HTTPS 并非是应用层的一种新协议。只是 HTTP
HTTPS学习笔记
笔记详细地址:[http://note.youdao.com/yws/public/redirect/share?id=4882fca3838541908c75c92c92d28b74&type=false](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Fnote.youdao.com%2F
HTTPS请求
##HTTPS请求## > **HttpsUtils代码** package com.ices.utils.httpsHelp; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader;
Golang代码实现HTTPs(HTTPS证书生成和部署)
在win7下试试: 1.**实现一个最简单的HTTPS Web Server** // gohttps/2-https/server.go package main import ( "fmt" "net/http" ) func handler(w http.R
Https详细分析
#### 目录介绍 * 01.为何会有Https * 02.解决方案分析 * 03.SSL是什么 * 04.RSA验证的隐患 * 05.CA证书身份验证 * 06.Https工作原理 * 07.Https代理作用 * 08.Https真安全吗 * 09.Https性能优化 ### 01.为何会有Https * H
Nginx配置https
一、开启nginx的ssl模块 1.未安装过nginx,编译安装配置参数如下: ./configure \--prefix=/usr/local/nginx \--with-pcre \--with-http\_ssl\_module #ssl模块 \--with-http\_stub\_status\_module \--wit
SpringBoot Web Https 配置
不管是游戏服务器开发,还是其它服务开发,越来越多的平台都要求服务端必须支持https的访问。以增加安全性。比如目前火热的小程序,要求服务端必须支持https,苹果商店也有说http请求要修改为https。所以https将会是游戏服务器的普遍需求。 一,证书生成 ======    证书可以自己使用jdk生成进行测试。但是在正常使用的时候,需要去第三方机构
SpringBoot2.x配置Https
准备工作 ==== 需要自签,或者权威机构颁发的证书一张 springboot配置Https访问 =================== #ssl #https访问的端口 server.port=8085 #证书,可以存放在resoucrs目录下 server.ssl.key-store=classpath:to
SpringBoot2.x配置Https
准备工作 ==== 需要自签,或者权威机构颁发的证书一张 springboot配置Https访问 =================== #ssl #https访问的端口 server.port=8085 #证书,可以存放在resoucrs目录下 server.ssl.key-store=classpath:to
springboot2 配置 https
package cn.xiaojf.aibus.configure; import org.apache.catalina.Context; import org.apache.catalina.connector.Connector; import org.apache.coyote.http11.Http11Ni
HTTPS 原理详解
摘要:本文尝试一步步还原HTTPS的设计过程,以理解为什么HTTPS最终会是这副模样。但是这并不代表HTTPS的真实设计过程。在阅读本文时,你可以尝试放下已有的对HTTPS的理解,这样更利于“还原”过程。我们先不了聊HTTP,HTTPS,我们先从一个聊天软件说起,我们要实现A能发一个hello消息给B:如果我们要实现这个聊天软件,本文只考虑安全性问题,要实现