android studio 百度多渠道打包,AndroidStudio多渠道打包

假如AndroidManifest.xml的 meta-data>CHANNEL 是渠道的標准

1、在AndroidManifest.xml里設置動態渠道變量

android:name="CHANNEL"

android:value="${CHANNEL_VALUE}" />

上面的value值CHANNEL_VALUE就是渠道標識。我們的期望的就是在編譯時候這個值能夠自動變化以滿足區分多渠道的需求。

2、在build.gradle設置productFlavors

這里假定我們需要打包的渠道為小米、百度

android {

productFlavors {

xiaomi {

manifestPlaceholders = [CHANNEL_VALUE: "xiaomi"]

}

baidu {

manifestPlaceholders = [CHANNEL_VALUE: "baidu"]

}

}

}

如果打包的渠道比較多我們還可以批量修改

//多渠道打包

productFlavors {

xiaomi {}

baidu {}

}

productFlavors.all {

flavor ->flavor.manifestPlaceholders = [CHANNEL_VALUE: name]}

所謂ProductFlavors其實就是可定義的產品特性,配合 manifest 使用的時候就可以達成在一次編譯過程中產生多個具有自己特性配置的版本。上面這個配置的作用就是,為每個渠道包產生不同的 CHANNEL_VALUE 的值。如果兩者設置的值不一樣就會出現以下的異常

d12b47b1761935f5bf56a70592a33099.png

3、在build.gradle文件中配置簽名信息

signingConfigs {

release {

storeFile file("wxkey")

storePassword '123456'

keyAlias '1'

keyPassword '123456'

}

debugConfig {

storeFile file("wxkey")

storePassword "123456"

keyAlias "1"

keyPassword "123456"

}

}

4、執行打包命令 ./gradlew assembleRelease

在AndroidStudio窗口左下角打開Terminal面板,widnow輸入gradlew assembleRelease Mac或者Linux輸入./gradlew assembleRelease命令可以一次性打包出所有的簽名渠道包

98c6da247bb81105a6dc05515508a84b.png

打包成功后會提示BUILD SUCCESSRUL並在app>build>outputs>apk目錄生成簽名的apk

169af1509b8c19efd86926b0eaa23315.png

5、單獨分別打bug或者release渠道包

1、如果我們想打xiaomi渠道的release版本,執行如下命令:

./gradlew assemblexiaomiRelease

2、如果我們想打xiaomi渠道的bug版本,執行如下命令:

./gradlew assemblexiaomiDebug

3、如果我們想打xiaomi渠道的release版以及bug版,則執行如下命名:

./gradlew assemblexiaomi

4、打全部Release版本:

./gradlew assembleRelease

5、打全部Debug版本:

./gradlew assembleDebug

6、自定義所打APK包名稱

當我們的渠道包版本比較多時,可以自定義所打APK包名稱,用以區分

// 自定義輸出配置

applicationVariants.all { variant ->variant.outputs.each { output ->def outputFile = output.outputFile

if (outputFile != null && outputFile.name.endsWith('.apk')) {

// 輸出apk名稱為JPay_0.0.1_xiaomi.apk

def fileName = "JPay_${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"

output.outputFile = new File(outputFile.parent, fileName)

}

}

}

執行打包命令./gradlew assemblexiaomiRelease 我們發現輸出的apk以及修改為了我們自定義的名稱

6b8ea21c94682f2ec6cd630e63ad6101.png

7、完整示例的配置

apply plugin: 'com.android.application'

android {

compileSdkVersion 24

buildToolsVersion "24.0.3"

defaultConfig {

applicationId "mayihuijia.com"

minSdkVersion 15

targetSdkVersion 24

versionCode 1

versionName "0.0.1"

testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"

}

signingConfigs {

release {

storeFile file("wxkey")

storePassword '123456'

keyAlias '1'

keyPassword '123456'

}

debugConfig {

storeFile file("wxkey")

storePassword "123456"

keyAlias "1"

keyPassword "123456"

}

}

buildTypes {

release {

minifyEnabled false

proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'

signingConfig signingConfigs.release

// 自定義輸出配置

applicationVariants.all { variant ->

variant.outputs.each { output ->

def outputFile = output.outputFile

if (outputFile != null && outputFile.name.endsWith('.apk')) {

// 輸出apk名稱為JPay_0.0.1_xiaomi.apk

def fileName = "JPay_${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk"

output.outputFile = new File(outputFile.parent, fileName)

}

}

}

}

debug {

signingConfig signingConfigs.debugConfig

}

}

lintOptions {

abortOnError false

}

//多渠道打包

productFlavors {

xiaomi {}

baidu {}

}

productFlavors.all {

flavor -> flavor.manifestPlaceholders = [CHANNEL_VALUE: name]

}

}

dependencies {

compile fileTree(include: ['*.jar'], dir: 'libs')

androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {

exclude group: 'com.android.support', module: 'support-annotations'

})

compile 'com.android.support:appcompat-v7:24.2.1'

testCompile 'junit:junit:4.12'

compile 'com.javen205.jpay:jpaysdk:0.0.1'

}

安利時間:

JPay是對微信App支付、支付寶App支付的二次封裝,對外提供一個相對簡單的接口以及支付結果的回調

極速開發微信公眾號是對微信公眾平台接口的二次封裝。包括開發者模式、事件回調監聽、微信模板消息、微信客服消息、自定義菜單、微信支付、素材管理等

如遇到問題歡迎留言交流

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值