假如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 的值。如果兩者設置的值不一樣就會出現以下的異常
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命令可以一次性打包出所有的簽名渠道包
打包成功后會提示BUILD SUCCESSRUL並在app>build>outputs>apk目錄生成簽名的apk
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以及修改為了我們自定義的名稱
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支付的二次封裝,對外提供一個相對簡單的接口以及支付結果的回調
極速開發微信公眾號是對微信公眾平台接口的二次封裝。包括開發者模式、事件回調監聽、微信模板消息、微信客服消息、自定義菜單、微信支付、素材管理等
如遇到問題歡迎留言交流