国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

Android Studio多渠道打包套路

2019-10-22 18:24:22
字體:
供稿:網(wǎng)友

       說到多渠道,這里不得不提一下友盟統(tǒng)計,友盟統(tǒng)計是大家日常開發(fā)中常用的渠道統(tǒng)計工具,而我們的打包方法就是基于友盟統(tǒng)計實(shí)施的。按照友盟官方文檔說明,渠道信息通常需要在AndroidManifest.xml中配置如下值:

<meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/>

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

(一)在AndroidManifest.xml里設(shè)置動態(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 使用的時候就可以達(dá)成在一次編譯過程中產(chǎn)生多個具有自己特性配置的版本。上面這個配置的作用就是,為每個渠道包產(chǎn)生不同的 UMENG_CHANNEL_VALUE 的值。

(三)執(zhí)行打包操作

在AndroidStudio菜單欄點(diǎn)擊Build菜單–>Generate signed APK–>選擇key,并輸入密碼

android,studio,打包

然后下一步,選擇打包渠道

android,studio,打包

最后點(diǎn)擊完成按鈕

android,studio,打包

上圖可以看到,我們已經(jīng)成功的將五個渠道包打好。

(四)執(zhí)行打包命令 ./gradlew assembleRelease

       除了使用AndroidStudio圖形打包操作以外,我們也可以使用命令行進(jìn)行打包操作,具體步驟如下:

在AndroidStudio窗口左下角打開Terminal面板,輸入gradlew assembleRelease命令

android,studio,打包

如果系統(tǒng)中沒有安裝Gradle,則會自動下載完成安裝及初始化

android,studio,打包

打包成功后會提示BUILD SUCCESSRUL

android,studio,打包

在app–>build–>outputs–>apk路徑中就可以看到打包成功后的APK

android,studio,打包

注意,此時這里的APK包名顯示為unsigned,也就是說未簽名,我們可以繼續(xù)在build.gradle文件中配置簽名信息

signingConfigs {    release{      storeFile file("../wooyun_keystore") //簽名文件路徑      storePassword "123456"      keyAlias "123456"      keyPassword "123456" //簽名密碼    }  }

然后再次執(zhí)行gradlew assembleRelease命令

android,studio,打包

這次生成的就是含有簽名的渠道包。

當(dāng)我們的渠道包版本比較多時,可以自定義所打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)          }        }      }

android,studio,打包

assemble是Gradle中的編譯打包命令,有如下用法:

如果我們想打包wandoujia渠道的release版本,執(zhí)行如下命令就好了:

gradlew assembleWandoujiaRelease

如果我們想打包wandoujia渠道的debug版本,執(zhí)行如下命令就好了:

gradlew assembleWandoujiaDebug

如果我們只打wandoujia渠道版本,則:

gradlew assembleWandoujia

此命令會生成wandoujia渠道的Release和Debug版本

同理我想打全部Release版本:

gradlew assembleRelease

這條命令會把Product Flavor下的所有渠道的Release版本都打出來。

下面是我個人的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配置中,可以寫兩個代碼塊,分別名為debugConfig和releaseConfig,并在其中寫好一個完整簽名需要的keyAlias、keyPassword、storeFile file、storePassword。 

       然后在buildTypes中,分兩個代碼塊,分別是debug時用的,和release時用的。在其中引用剛剛寫好的debugConfig和releaseConfig即可。

       注意:signingConfigs代碼塊一定要寫在buildTypes前面,否則會報下面這種錯:

Could not find property 'debugConfig' on SigningConfig container.

簽名密碼寫在gradle中不安全,故最好在打包上線的時候?qū)⑾嚓P(guān)代碼注釋掉。

ps:下面看下android studio 多渠道打包報錯

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多渠道打包套路,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VEVB武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到Android開發(fā)頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 乾安县| 西吉县| 三河市| 西贡区| 台安县| 偏关县| 江达县| 宜章县| 松阳县| 望奎县| 鲜城| 宾阳县| 台南县| 桐柏县| 台东县| 怀仁县| 贺州市| 铜川市| 温泉县| 大石桥市| 蛟河市| 洪洞县| 霍邱县| 富蕴县| 麻阳| 荆门市| 东阳市| 肥乡县| 溧阳市| 景宁| 凤凰县| 龙海市| 南投县| 确山县| 张家川| 崇文区| 西昌市| 柳州市| 高平市| 泸西县| 景洪市|