Walle多渠道打包

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/peixiaopao/article/details/77723009
Walle多渠道打包
介绍
Android 7.0 引入一项新的应用签名方案 APK Signature Scheme v2,它能提供更快的应用安装时间和更多针对未授权 APK 文件更改的保护。在默认情况下,android Studio 2.2 和 Android Plugin for Gradle 2.2 会使用 APK Signature Scheme v2 和传统签名方案来签署您的应用。
注意:如果您使用 APK Signature Scheme v2 签署您的应用,并对应用进行了进一步更改,则应用的签名将无效。Walle并不是为了解决打包速度而产生的一个工具,而是为了适应V2签名而研究的因一代打包工具


瓦力通过在Apk中的APK Signature Block区块添加自定义的渠道信息来生成渠道包,从而提高了渠道包生成效率,可以作为单机工具来使用,也可以部署在HTTP服务器上来实时处理渠道包Apk的升级网络请求。
使用
使用Walle生成多渠道的速度是非常快的,比如原来的项目打一个包需要两分钟多,每次发布打7个包需要十几分钟。用了Walle后,7个包只要两分钟左右就可以完成。
添加依赖&配置渠道android {
//签名 引用位置
 signingConfigs {
        sankuai {
            storeFile file("keystore/123keyStore.jks")
            storePassword "123456"
            keyAlias "key"
            keyPassword "123456"
        }
    }
//调用签名设置
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            signingConfig signingConfigs.sankuai
        }
        debug {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            signingConfig signingConfigs.sankuai
        }
    }

    //个性化设置
    productFlavors {
        honry {
            manifestPlaceholders = [UMENG_CHANNEL_VALUE: "honry"]
        }
    }
}
在项目的build.gradle文件中添加依赖
buildscript {
    dependencies {
        classpath 'com.meituan.android.walle:plugin:1.1.3'
    }
}
在当前app的build.gradle 文件中添加依赖,以及配置插件
apply plugin: 'walle'

...

dependencies {
    ...
    compile 'com.meituan.android.walle:library:1.1.3'
}

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")
}
对应的属性:
  • apkOutputFolder:指定渠道包的输出路径, 默认值为new File("${project.buildDir}/outputs/apk")。这里指定为build/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 名
  • channelFile:包含渠道配置信息的文件路径
  • channelFile:包含渠道配置信息的文件路径。
在app目录下创建channel文件,用于配置渠道信息(文件类型:Text)

渠道配置

下面是配置表
Qh360 #360
Yyb #应用宝
Wdj #豌豆荚
Lenovo #联想
Xiaomi #小米
Huawei #华为
Meizhu #魅族
获取渠道信息
通过以下代码,可以取渠道信息
String channel = WalleChannelReader.getChannel(this.getApplicationContext());
生成渠道包
到这里,基本的配置都已完成。接下来可以直接打包了。
在Terminal中输入对应的指令,即可完成打包。看到BUILD SUCCESSFUL后说明已经完成打包了

打包
  • 所有渠道
./gradlew clean assembleReleaseChannels
渠道包的生成目录默认存放在 build/outputs/apk/,也可以通过Walle闭包中的apkOutputFolder参数来指定输出目录
  • 指定渠道
生成单个渠道包(huawei渠道):
./gradlew clean assembleReleaseChannels -PchannelList=huawei
生成多个渠道包(huawei、xiaomi渠道):
./gradlew clean assembleReleaseChannels -PchannelList=huawei,xiaomi
结果
运行./gradlew clean assembleReleaseChannels后,可以在build/outputs/channels看到对应的渠道包。


—— —— 以上就是Walle打包的基本流程,想要了解更多可以参考源码




阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页