手把手教你AndroidStudio多渠道打包

numberbb 8年前
   <p>       最近不断有朋友向我咨询AndroidStudio多渠道的打包方法,今天整理一下之前积累的打包套路,写一篇文章,手把手的教给大家。<br>        说到多渠道,这里不得不提一下友盟统计,友盟统计是大家日常开发中常用的渠道统计工具,而我们的打包方法就是基于友盟统计实施的。按照友盟官方文档说明,渠道信息通常需要在AndroidManifest.xml中配置如下值:</p>    <pre>  <code class="language-java"><meta-data android:value="Channel ID" android:name="UMENG_CHANNEL"/></code></pre>    <p>       上面的value值Channel_ID就是渠道标识。我们的期望的就是在编译时候这个值能够自动变化以满足区分多渠道的需求。</p>    <h2>(一)在AndroidManifest.xml里设置动态渠道变量</h2>    <pre>  <code class="language-java"><meta-data      android:name="UMENG_CHANNEL"      android:value="${UMENG_CHANNEL_VALUE}" /></code></pre>    <h2>(二)在build.gradle设置productFlavors</h2>    <pre>  <code class="language-java">这里假定我们需要打包的渠道为酷安市场、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"]          }      }    }</code></pre>    <p>或者批量修改</p>    <pre>  <code class="language-java">android {        productFlavors {          kuan {}          xiaomi {}          qh360 {}          baidu {}          wandoujia {}      }          productFlavors.all {           flavor -> flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]       }  }</code></pre>    <p>       所谓ProductFlavors其实就是可定义的产品特性,配合 manifest merger 使用的时候就可以达成在一次编译过程中产生多个具有自己特性配置的版本。上面这个配置的作用就是,为每个渠道包产生不同的 UMENG_CHANNEL_VALUE 的值。</p>    <h2>(三)执行打包操作</h2>    <p>在AndroidStudio菜单栏点击Build菜单–>Generate signed APK–>选择key,并输入密码<br> <img alt="输入密码" src="https://simg.open-open.com/show/55b0edc5626c00832d044850f64927b4.png"></p>    <p>然后下一步,选择打包渠道</p>    <p><img alt="选择打包渠道" src="https://simg.open-open.com/show/ce8554731d1be5f24f15145005581f45.png"></p>    <p>最后点击完成按钮</p>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/1d5724f92c276ebb3c2142aa41dc43aa.png"></p>    <p>上图可以看到,我们已经成功的将五个渠道包打好。</p>    <h2>(四)执行打包命令 ./gradlew assembleRelease</h2>    <p>       除了使用AndroidStudio图形打包操作以外,我们也可以使用命令行进行打包操作,具体步骤如下:</p>    <ul>     <li> <p>在AndroidStudio窗口左下角打开Terminal面板,输入gradlew assembleRelease命令</p> </li>    </ul>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/88d299d7f884b116bdafce5872242bf6.png"></p>    <ul>     <li> <p>如果系统中没有安装Gradle,则会自动下载完成安装及初始化</p> </li>    </ul>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/a3e76deb142b47926d624d41796d714c.png"></p>    <ul>     <li> <p>打包成功后会提示BUILD SUCCESSRUL</p> </li>    </ul>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/f35898d08ca3f516b040870b5961f97a.png"></p>    <ul>     <li> <p>在app–>build–>outputs–>apk路径中就可以看到打包成功后的APK</p> </li>    </ul>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/c5f87e12d6f835fd610f2511388435ed.png"></p>    <p>注意,此时这里的APK包名显示为unsigned,也就是说未签名,我们可以继续在build.gradle文件中配置签名信息</p>    <pre>  <code class="language-java">signingConfigs {          release{              storeFile file("../wooyun_keystore") //签名文件路径              storePassword "123456"              keyAlias "123456"              keyPassword "123456"  //签名密码          }      }</code></pre>    <ul>     <li> <p>然后再次执行gradlew assembleRelease命令</p> </li>    </ul>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/0009b7dcb06850e27821a41694e68367.png"></p>    <p>这次生成的就是含有签名的渠道包。</p>    <ul>     <li> <p>当我们的渠道包版本比较多时,可以自定义所打APK包名称,用以区分</p> </li>    </ul>    <pre>  <code class="language-java">// 自定义输出配置,这里我们加上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)                      }                  }              }</code></pre>    <p><img alt="这里写图片描述" src="https://simg.open-open.com/show/621f970f2733d92f732bec186544e2bd.png"></p>    <ul>     <li> <p>assemble是Gradle中的编译打包命令,有如下用法:</p> </li>    </ul>    <p>如果我们想打包wandoujia渠道的release版本,执行如下命令就好了:</p>    <pre>  <code class="language-java">gradlew assembleWandoujiaRelease</code></pre>    <p>如果我们想打包wandoujia渠道的debug版本,执行如下命令就好了:</p>    <pre>  <code class="language-java">gradlew assembleWandoujiaDebug</code></pre>    <p>如果我们只打wandoujia渠道版本,则:</p>    <pre>  <code class="language-java">gradlew assembleWandoujia</code></pre>    <p>此命令会生成wandoujia渠道的Release和Debug版本</p>    <p>同理我想打全部Release版本:</p>    <pre>  <code class="language-java">gradlew assembleRelease</code></pre>    <p>这条命令会把Product Flavor下的所有渠道的Release版本都打出来。</p>    <p><strong>下面是我个人的build.gradle配置文件,分享给大家,以作参考</strong></p>    <pre>  <code class="language-java">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'  }</code></pre>    <p>       上面的signingConfigs配置中,可以写两个代码块,分别名为debugConfig和releaseConfig,并在其中写好一个完整签名需要的keyAlias、keyPassword、storeFile file、storePassword。<br>        然后在buildTypes中,分两个代码块,分别是debug时用的,和release时用的。在其中引用刚刚写好的debugConfig和releaseConfig即可。</p>    <p>       注意:signingConfigs代码块一定要写在buildTypes前面,否则会报下面这种错:</p>    <pre>  <code class="language-java">Could not find property 'debugConfig' on SigningConfig container.</code></pre>    <p>签名密码写在gradle中不安全,故最好在打包上线的时候将相关代码注释掉。</p>    <p>参考链接:<a href="/misc/goto?guid=4958861827639179431">http://stormzhang.com/devtools/2015/01/15/android-studio-tutorial6/</a></p>    <p><strong>安卓开发高级技术交流QQ群:108721298 欢迎入群 微信公众号:mobilesafehome</strong><br> <img alt="Android安全技术大本营" src="https://simg.open-open.com/show/c71a6fdf6423c2ada3b6ea6a16e7de02.jpg"></p>    <p> </p>    <p>来自: <a href="/misc/goto?guid=4959674914163615882" rel="nofollow">http://blog.csdn.net/mynameishuangshuai/article/details/51783303</a></p>    <p> </p>