Android配置build.gradle解锁更高逼格玩法(多版本共存、分服务器打包等)
背景
在日常的AndroidAPP開發過程中,常常需要在同一設備上安裝同一APP的多個版本。如在沒有測試設備的情況下需要使用到個人設備進行測試,而該設備已安裝正式版本且有大量緩存數據。applicationId作為Android對APP的唯一識別,同一applicationId僅能在一個設備上出現一次,這時就需要對APP進行多版本共存處理。
分析
Android在對于APP安裝時,會首先校驗applicationId是否已在設備上存在。
Gradle是一個基于Apache Ant和Apache Maven概念的項目自動化構建開源工具。它使用一種基于Groovy的特定領域語言(DSL)來聲明項目設置,拋棄了基于XML的各種繁瑣配置。--來自百度百科
我只抓住了一點,“拋棄了基于XML的各種繁瑣配置”
代碼
1.建版本 首先,我們需要在APP的build.gradle中,buildTypes下建版本。
buildTypes {release {...}debug {debuggable true...}dev {...}...} 復制代碼這里的版本,可以建無數多個,但debug下一定要寫
debuggable true 復制代碼這樣AndroidStudio才能區分RunApp操作時調試的是哪一個版本。寫完之后,在Build-->Generate Signed APK中,BuildType就能去選擇對應的版本了。
2.改Id applicationIdSuffix可以很輕松地執行類似修改包名稱的操作,原理是在defaultConfig的applicationId后面拼接內容。例如在debug版本下:
buildTypes {...debug {applicationIdSuffix ".debug"debuggable true...}...} } 復制代碼同理,若需要存在N個版本,則在建立N個版本后,添加applicationIdSuffix屬性即可。如:
buildTypes {...debug {applicationIdSuffix ".debug"debuggable true...}dev {applicationIdSuffix ".dev"...}...dev_n {applicationIdSuffix ".dev_n"...}...} } 復制代碼做完以上兩步,如果沒有配置provider的話,多版本已經可以共存。但Android7.0以后,如果要使用一些權限的話,provider是必須的。
3.provider provider也是唯一的。這時候強大的Groovy再次登場。
buildTypes {release {manifestPlaceholders = [PROVIDER: "${defaultConfig.applicationId}.fileprovider"]}debug {applicationIdSuffix ".debug"manifestPlaceholders = [PROVIDER: "${defaultConfig.applicationId}.debug.fileprovider"]debuggable true} } 復制代碼注:${defaultConfig.applicationId}就是我們在defaultConfig中配置的,
同時,需要在manifest中替換authorities
<providerandroid:name="android.support.v4.content.FileProvider"android:authorities="${PROVIDER}"android:exported="false"android:grantUriPermissions="true"><meta-dataandroid:name="android.support.FILE_PROVIDER_PATHS"android:resource="@xml/filepaths" /> </provider> 復制代碼4.APP名 我感覺。。。你可能還需要在設備上區分版本
buildTypes {release {manifestPlaceholders = [APP_NAME: "HelloWorld", PROVIDER: "${defaultConfig.applicationId}.fileprovider"]}debug {applicationIdSuffix ".debug"manifestPlaceholders = [APP_NAME: "HelloWorld測試版", PROVIDER: "${defaultConfig.applicationId}.debug.fileprovider"]debuggable true}dev {manifestPlaceholders = [APP_NAME: "HelloWorld開發版", PROVIDER: "${defaultConfig.applicationId}.dev.fileprovider"]}... } 復制代碼同時替換manifest中,application標簽下的android:lable
<applicationandroid:name=".application.MyApplication"android:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="${APP_NAME}"android:supportsRtl="true"android:theme="@style/AppTheme"tools:replace="android:icon,android:label,android:theme">... <application/> 復制代碼注:tools:replace這個屬性最好加上,我之前沒加,編譯不通過。
綜上所述,如果想替換manifest中的任何配置,則需在manifestPlaceholders中,以key-value形式編寫字段,同時在manifest中以
${key-name} 復制代碼的形式調用就ok了,同理我們還能夠替換icon和其他例如阿里云推送的key等等。
5.服務器地址 嗯,是的,這個也是可以替換的。原理是替換BuildConfig中對應字段。 BuildConfig路徑
app\build\generated\source\buildConfig\PACKAGE_NAME\android\buildType
//正式環境 def SERVER_URL_RELEASE = "\"http://release.com/\"" //開發環境 def SERVER_URL_DEBUG = "\"http://debug.com/\""buildTypes {release {buildConfigField "String", "SERVER_URL", "${SERVER_URL_RELEASE}"...}debug {applicationIdSuffix ".debug"buildConfigField "String", "SERVER_URL", "${SERVER_URL_DEBUG}"debuggable true...}... } 復制代碼首先定義服務器地址String,并在對應的位置指明
"字段類型","要替換的字段名","字段"
在常量文件(通常習慣性為Constants.java)中
public static final String SERVER_URL = BuildConfig.SERVER_URL; 復制代碼只要字段名和字段類型能夠對應,替換這些都是可以實現的。
6.APK自動命名 我們希望在打包時自動命名格式,例如:xxx_v1.2.3.apk,可在android目錄下寫上
android.applicationVariants.all { variant ->variant.outputs.all {outputFileName = "xxx_v${defaultConfig.versionName}.apk"} } 復制代碼不僅如此,build.gradle文件還有其他玩法供大家解鎖,希望能集思廣益、不吝分享。
轉載于:https://juejin.im/post/5c887b3c6fb9a049e82c613c
總結
以上是生活随笔為你收集整理的Android配置build.gradle解锁更高逼格玩法(多版本共存、分服务器打包等)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: hyperledge工具-configt
- 下一篇: 简化路径