多渠道打包
國內有太多Android App市場,每次發版幾十個渠道包。還好Android Gradle給我們提供了productFlavors,我們可以對生成的APK包進行定制。
productFlavors {//多渠道打包 xiaomi { applicationId 'com.wuxiaolong.gradle4android1' } googlepaly { applicationId 'com.wuxiaolong.gradle4android2' } }
定制生成的apk文件名
applicationVariants.all { variant -> if (variant.buildType.name.equals('release')) { variant.outputs.each { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.apk')) { def fileName = "gradle4android_v${defaultConfig.versionName}_${releaseTime()}_${variant.flavorName}.apk" output.outputFile = new File(outputFile.parent, fileName) } } } }
輸出apk名字:gradle4android_v1.0_2016-03-23_xiaomi.apk
占位符
多渠道打包,還會遇到一個問題,比如友盟統計的渠道號,Gradle處理辦法:manifestPlaceholders,它允許我們動態替換我們在AndroidManifest文件里定義的占位符。
AndroidManifest.xml: <meta-data android:name="UMENG_CHANNEL" android:value="${UMENG_CHANNEL_VALUE}" />
如下,${UMENG_CHANNEL_VALUE}占位符會被dev替換。
defaultConfig { manifestPlaceholders = [UMENG_CHANNEL_VALUE: 'dev'] }
如果渠道太多,不用這樣一個個去寫,可以循環:
productFlavors.all { flavor -> manifestPlaceholders.put("UMENG_CHANNEL_VALUE",name) }
渠道打包完整代碼:
android { //省略部分代碼 buildTypes { release { minifyEnabled false//是否啟動混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' applicationVariants.all { variant -> if (variant.buildType.name.equals('release')) { variant.outputs.each { output -> def outputFile = output.outputFile if (outputFile != null && outputFile.name.endsWith('.apk')) { def fileName = "gradleTest_v${defaultConfig.versionName}_${releaseTime()}_${variant.flavorName}.apk" output.outputFile = new File(outputFile.parent, fileName) } } } } //針對很多渠道 //productFlavors.all { flavor -> // manifestPlaceholders.put("UMENG_CHANNEL_VALUE",name) // } } } productFlavors {//多渠道打包 xiaomi { applicationId 'com.wuxiaolong.gradle4android1' manifestPlaceholders.put("UMENG_CHANNEL_VALUE", 'xiaomi') } googlepaly { applicationId 'com.wuxiaolong.gradle4android2' manifestPlaceholders.put("UMENG_CHANNEL_VALUE", 'googlepaly') } } //省略部分代碼 def releaseTime() { return new Date().format("yyyy-MM-dd", TimeZone.getTimeZone("UTC")) }
配置簽名信息
Android Studio設置默認的簽名文件
新浪微博SSO登錄,微信分享這些都需要簽名打包,才能看到效果,設置默認簽名文件為自己的簽名jks,這樣就不需要打包了直接運行起來就是正式的簽名。
在android.signingConfigs{}下定義一個或者多個簽名信息,然后在buildTypes{}配置使用即可。
在app目錄下添加你的.jks,然后app的build.gradle文件中的增加以下內容:
第一種:
android { signingConfigs { debug { storeFile file("WuXiaolong.jks") storePassword 'android' keyAlias 'android' keyPassword 'android' } } }
buildTypes沒有配置,也是直接取得debug,是不是不配置默認取得是debug呢?
第二種:
android { signingConfigs { release { storeFile file("WuXiaolong.jks") storePassword 'android' keyAlias 'android' keyPassword 'android' } } buildTypes { debug { signingConfig signingConfigs.release } } }
簽名打包
通過Android Studio簽名
這里不細說了。
通過命令行簽名
如上那樣配置簽名信息
android { signingConfigs { release { storeFile file("WuXiaolong.jks") storePassword 'android' keyAlias 'android' keyPassword 'android' } } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' signingConfig signingConfigs.release } } }
先”build-clean Project”,然后Terminal輸入命名行:
gradlew assembleRelease
打印信息如下:
E:\AndroidStudioProjects\Gradle4Android>gradlew assembleRelease :app:preBuild UP-TO-DATE :app:preReleaseBuild UP-TO-DATE :app:checkReleaseManifest //省略部分 :app:packageRelease :app:zipalignRelease :app:assembleRelease BUILD SUCCESSFUL
OK,打包成功的apk路徑如:E:\AndroidStudioProjects\Gradle4Android\app\build\outputs\apk\app-release.apk