多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > 綜合技術 > 手把手教你AndroidStudio多渠道打包

手把手教你AndroidStudio多渠道打包

來源:程序員人生   發布時間:2016-08-10 13:52:32 閱讀次數:2876次

       最近不斷有朋友向我咨詢AndroidStudio多渠道的打包方法,今天整理1下之前積累的打包套路,寫1篇文章,手把手的教給大家。
       說到多渠道,這里不能不提1下友盟統計,友盟統計是大家平常開發中經常使用的渠道統計工具,而我們的打包方法就是基于友盟統計實行的。依照友盟官方文檔說明,渠道信息通常需要在AndroidManifest.xml中配置以下值:

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

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

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

<meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" />

(2)在build.gradle設置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其實就是可定義的產品特性,配合 manifest merger 使用的時候就能夠達成在1次編譯進程中產生多個具有自己特性配置的版本。上面這個配置的作用就是,為每一個渠道包產生不同的 UMENG_CHANNEL_VALUE 的值。

(3)履行打包操作

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

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

選擇打包渠道

最后點擊完成按鈕

這里寫圖片描述

上圖可以看到,我們已成功的將5個渠道包打好。

(4)履行打包命令 ./gradlew assembleRelease

       除使用AndroidStudio圖形打包操作之外,我們也能夠使用命令行進行打包操作,具體步驟以下:

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

這里寫圖片描述

  • 如果系統中沒有安裝Gradle,則會自動下載完成安裝及初始化

這里寫圖片描述

  • 打包成功后會提示BUILD SUCCESSRUL

這里寫圖片描述

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

這里寫圖片描述

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

signingConfigs { release{ storeFile file("../wooyun_keystore") //簽名文件路徑 storePassword "123456" keyAlias "123456" keyPassword "123456" //簽名密碼 } }
  • 然后再次履行gradlew assembleRelease命令

這里寫圖片描述

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

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

// 自定義輸出配置,這里我們加上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版本,履行以下命令就行了:

gradlew assembleWandoujiaRelease

如果我們想打包wandoujia渠道的debug版本,履行以下命令就行了:

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,并在其中寫好1個完全簽名需要的keyAlias、keyPassword、storeFile file、storePassword。
       然后在buildTypes中,分兩個代碼塊,分別是debug時用的,和release時用的。在其中援用剛剛寫好的debugConfig和releaseConfig便可。

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

Could not find property 'debugConfig' on SigningConfig container.

簽名密碼寫在gradle中不安全,故最好在打包上線的時候將相干代碼注釋掉。

參考鏈接:http://stormzhang.com/devtools/2015/01/15/android-studio-tutorial6/




安卓開發高級技術交換QQ群:108721298 歡迎入群

微信公眾號:mobilesafehome

(本公眾號支持投票)

Android安全技術大本營

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 久久久国产在线 | 日本欧美一二三区色视频 | 国产视频在线看 | 欧美一级淫片漂亮的老师 | 久久这里只有精品9 | 97精品一区二区三区在线不卡 | 亚洲无砖砖区免费 | 波多野结衣178部中文字幕 | 波多野结衣在线资源 | 亚洲免费视频网站 | 欧美国产亚洲精品a第一页 欧美国产亚洲精品高清不卡 | 日韩欧美国产精品第一页不卡 | 欧美不卡一区二区三区 | 91久久偷偷做嫩草影院 | 亚洲精品在线视频 | 羞羞影院在线观看 | 亚洲综合网站 | 亚洲天堂在线播放 | 国内精品免费一区二区三区 | 日本福利片午夜免费观着 | 法国性xxxxx极品 | 日韩一级欧美一级 | 成人sq视频在线观看网站 | 一区二区三区久久 | 欧美xx性 | 欧美亚洲图区 | 亚洲另类图片专区 | 久久久久久国产精品免费免费 | 性做久久久久久免费观看 | 日本青草视频 | 九九精品免视频国产成人 | 91亚洲国产成人久久精品网址 | 欧美亚洲另类在线观看 | 亚洲图片欧美日韩 | 理伦三级 | 视频一区中文字幕 | 欧美三级真做在线观看 | 宇都宫紫苑ed2k | 国产高清视频在线观看不卡v | 成人免费视频网 | 男人懂得成a人v网站 |