Android Studio多渠道打包套路
說到多渠道,這里不得不提一下友盟統(tǒng)計(jì),友盟統(tǒng)計(jì)是大家日常開發(fā)中常用的渠道統(tǒng)計(jì)工具,而我們的打包方法就是基于友盟統(tǒng)計(jì)實(shí)施的。按照友盟官方文檔說明,渠道信息通常需要在AndroidManifest.xml中配置如下值:
<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>
上面的value值Channel_ID就是渠道標(biāo)識。我們的期望的就是在編譯時(shí)候這個(gè)值能夠自動(dòng)變化以滿足區(qū)分多渠道的需求。
(一)在AndroidManifest.xml里設(shè)置動(dòng)態(tài)渠道變量
<meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" />
(二)在build.gradle設(shè)置productFlavors
這里假定我們需要打包的渠道為酷安市場、360、小米、百度、豌豆莢
android { productFlavors { kuan { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "kuan"] } xiaomi { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "xiaomi"] } qh360 { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "qh360"] } baidu { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "baidu"] } wandoujia { manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"] } } }
或者批量修改
android { productFlavors { kuan {} xiaomi {} qh360 {} baidu {} wandoujia {} } productFlavors.all { flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] } }
所謂ProductFlavors其實(shí)就是可定義的產(chǎn)品特性,配合 manifest merger 使用的時(shí)候就可以達(dá)成在一次編譯過程中產(chǎn)生多個(gè)具有自己特性配置的版本。上面這個(gè)配置的作用就是,為每個(gè)渠道包產(chǎn)生不同的 UMENG_CHANNEL_VALUE 的值。
(三)執(zhí)行打包操作
在AndroidStudio菜單欄點(diǎn)擊Build菜單–>Generate signed APK–>選擇key,并輸入密碼
然后下一步,選擇打包渠道
最后點(diǎn)擊完成按鈕
上圖可以看到,我們已經(jīng)成功的將五個(gè)渠道包打好。
(四)執(zhí)行打包命令 ./gradlew assembleRelease
除了使用AndroidStudio圖形打包操作以外,我們也可以使用命令行進(jìn)行打包操作,具體步驟如下:
在AndroidStudio窗口左下角打開Terminal面板,輸入gradlew assembleRelease
命令
如果系統(tǒng)中沒有安裝Gradle,則會(huì)自動(dòng)下載完成安裝及初始化
打包成功后會(huì)提示BUILD SUCCESSRUL
在app–>build–>outputs–>apk路徑中就可以看到打包成功后的APK
注意,此時(shí)這里的APK包名顯示為unsigned,也就是說未簽名,我們可以繼續(xù)在build.gradle文件中配置簽名信息
signingConfigs { release{ storeFile file("../wooyun_keystore") //簽名文件路徑 storePassword "123456" keyAlias "123456" keyPassword "123456" //簽名密碼 } }
然后再次執(zhí)行gradlew assembleRelease
命令
這次生成的就是含有簽名的渠道包。
當(dāng)我們的渠道包版本比較多時(shí),可以自定義所打APK包名稱,用以區(qū)分
// 自定義輸出配置,這里我們加上APK版本號1.0 applicationVariants.all { variant -> variant.outputs.each { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.apk')) { // 輸出apk名稱為wooyun_v1.0_wandoujia.apk def fileName = "wooyun_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk" output.outputFile = new File(outputFile.parent, fileName) } } }
assemble是Gradle中的編譯打包命令,有如下用法:
如果我們想打包wandoujia渠道的release版本,執(zhí)行如下命令就好了:
gradlew assembleWandoujiaRelease
如果我們想打包wandoujia渠道的debug版本,執(zhí)行如下命令就好了:
gradlew assembleWandoujiaDebug
如果我們只打wandoujia渠道版本,則:
gradlew assembleWandoujia
此命令會(huì)生成wandoujia渠道的Release和Debug版本
同理我想打全部Release版本:
gradlew assembleRelease
這條命令會(huì)把Product Flavor下的所有渠道的Release版本都打出來。
下面是我個(gè)人的build.gradle配置文件,分享給大家,以作參考
apply plugin: 'com.android.application' android { compileSdkVersion 23 buildToolsVersion "23.0.3" defaultConfig { applicationId "com.wooyun.castiel" minSdkVersion 15 targetSdkVersion 23 versionCode 1 versionName "1.0" } //簽名 signingConfigs { debugConfig { storeFile file("../wooyun_keystore") //簽名文件 storePassword "123456" keyAlias "123456" keyPassword "123456" //簽名密碼 } release{ storeFile file("../wooyun_keystore") //簽名文件 storePassword "123456" keyAlias "123456" keyPassword "123456" //簽名密碼 } } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' // 自定義輸出配置 applicationVariants.all { variant -> variant.outputs.each { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.apk')) { // 輸出apk名稱為wooyun_v1.0_wandoujia.apk def fileName = "wooyun_v${defaultConfig.versionName}_${variant.productFlavors[0].name}.apk" output.outputFile = new File(outputFile.parent, fileName) } } } } } productFlavors { kuan {} xiaomi {} qh360 {} baidu {} wandoujia {} } productFlavors.all { flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name] } } dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:23.4.0' }
上面的signingConfigs配置中,可以寫兩個(gè)代碼塊,分別名為debugConfig和releaseConfig,并在其中寫好一個(gè)完整簽名需要的keyAlias、keyPassword、storeFile file、storePassword。
然后在buildTypes中,分兩個(gè)代碼塊,分別是debug時(shí)用的,和release時(shí)用的。在其中引用剛剛寫好的debugConfig和releaseConfig即可。
注意:signingConfigs代碼塊一定要寫在buildTypes前面,否則會(huì)報(bào)下面這種錯(cuò):
Could not find property 'debugConfig' on SigningConfig container.
簽名密碼寫在gradle中不安全,故最好在打包上線的時(shí)候?qū)⑾嚓P(guān)代碼注釋掉。
ps:下面看下android studio 多渠道打包報(bào)錯(cuò)
What went wrong:
Execution failed for task ':項(xiàng)目名:shrinkGuanwangReleaseMultiDexComponents'.
java.io.IOException: Can't read D:\wanxiaoStudio-2.5\build\intermediates\classes-proguard\guanwang\release\classes.jar
Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
總結(jié)
以上所述是小編給大家介紹的Android Studio多渠道打包套路,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android實(shí)現(xiàn)可滑動(dòng)的自定義日歷控件
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)可滑動(dòng)的自定義日歷控件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07Android編程設(shè)計(jì)模式之中介者模式詳解
這篇文章主要介紹了Android編程設(shè)計(jì)模式之中介者模式,結(jié)合實(shí)例形式詳細(xì)分析了Android中介者模式的概念、原理、使用場景、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2017-12-12Android手機(jī)開發(fā) 控件 TextView文字居中
本文主要介紹Android手機(jī)開發(fā)TextView居中的方法,希望能幫到大家。2016-05-05Flutter開發(fā)技巧RadialGradient中radius計(jì)算詳解
這篇文章主要為大家介紹了Flutter小技巧RadialGradient?中?radius?的計(jì)算詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01android 使用瀏覽器打開指定頁面的實(shí)現(xiàn)方法
這篇文章主要介紹了android 使用瀏覽器打開指定頁面的實(shí)現(xiàn)方法,本文通過實(shí)例文字說明的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06android實(shí)現(xiàn)倒計(jì)時(shí)功能代碼
實(shí)現(xiàn)倒計(jì)時(shí)每隔1秒,變換一下時(shí)間,截圖如下,感興趣的朋友想看下實(shí)現(xiàn)代碼,希望對你學(xué)習(xí)有所幫助2013-06-06Android編程設(shè)置全屏的方法實(shí)例詳解
這篇文章主要介紹了Android編程設(shè)置全屏的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android設(shè)置全屏的兩種常見技巧,非常簡單實(shí)用,需要的朋友可以參考下2015-11-11