Gradle for Android(二)全域性設定、自定義BuildConfig、混淆
阿新 • • 發佈:2019-01-09
全域性設定
如果有很多專案,可以設定全域性來統一管理版本號或依賴庫,根目錄下build.gradle下:
1 2 3 4 5 6 |
ext { compileSdkVersion = 23 buildToolsVersion = "23.0.2" minSdkVersion = 14 targetSdkVersion = 23 } |
app/build.gradle
1 2 3 4 5 6 7 8 9 10 11 |
android {
compileSdkVersion rootProject.ext.compileSdkVersion
|
可以在根目錄下建個config.gradle,然後只需在根目錄下build.gradle最頂部加上下面一行程式碼,然後同步下,意思就是所有的子專案或者所有的modules都可以從這個配置檔案裡讀取內容。
1
|
apply from: "config.gradle"
|
config.gradle
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
ext { android = [ compileSdkVersion: 23, buildToolsVersion: "23.0.2", minSdkVersion : 14, targetSdkVersion : 22, ] dependencies = [ appcompatV7': ' |
app/build.gradle
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
android { compileSdkVersion rootProject.ext.android.compileSdkVersion buildToolsVersion rootProject.ext.buildToolsVersion defaultConfig { applicationId "com.wuxiaolong.gradle4android" minSdkVersion rootProject.ext.android.minSdkVersion targetSdkVersion rootProject.ext.android.targetSdkVersion versionCode 1 versionName "1.0" } ... dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile rootProject.ext.dependencies.appcompatV7 compile rootProject.ext.dependencies.design } |
自定義BuildConfig
實際開發中伺服器可能有正式環境和測試環境,gradle可以通過buildConfigField來配置。
1 2 3 |
defaultConfig { buildConfigField 'String','API_SERVER_URL','"http://wuxiaolong.me/"' } |
buildConfigField 一共有3個引數,第一個是資料型別,和Java的型別是對等的;第二個引數是常量名,這裡是API_SERVER_URL;第三個引數就是你要配置的值。
如圖路徑下就有個常量API_SERVER_URL,如何在程式碼取得這個常量值:
1
|
Log.d("wxl", "API_SERVER_URL=" + BuildConfig.API_SERVER_URL);
|
啟用proguard混淆
一般release釋出版本是需要啟用混淆的,這樣別人反編譯之後就很難分析你的程式碼,而我們自己開發除錯的時候是不需要混淆的,所以debug不啟用混淆。對release啟用混淆的配置如下:
1 2 3 4 5 6 7 8 9 |
android { buildTypes { release { minifyEnabled true//是否啟動混淆 proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } |
minifyEnabled為true表示啟用混淆,proguardFile是混淆使用的配置檔案,這裡是module根目錄下的proguard-rules.pro檔案