Android 一站式打包(一)gradle 動態配置多環境

大家在項目打包時,可能會有以下需求:

1.需要針對不同環境進行打包,每次都要去代碼切換url現的繁瑣。

2.不同環境配置不同的第三方(例如:推送id,友盟或TD的id等等)

3.正式包與debug包日誌的打印

4.gradle版本或sdk版本每次提交問題

5.本地化配置簽名可方便測試微信支付、分享等


下面我就針對以上問題進行配置,目前公司的開發基本上都是切換置AS,所以我們用的就是gradle 去動態配置。

首先,針對不同的環境我們在項目的bulid.gradle中配置productFlavors,productFlavors功能就是配置多個環境,當然有人配置了多種渠道的定義(這裏我就不說了,下篇文章我會講解用美團的多渠道打包方案)。

  productFlavors{

        ApiDev{
            buildConfigField("String", "BASE_URL", "\"http://baidu.com/\"")
            manifestPlaceholders = [IM_VALUE: "",PUSH_ID:"",
                                    PUSH_KEY:"",PUSH_SECRET:""]
        }

        ApiTest{
            buildConfigField("String", "BASE_URL", "\"http://baidu.com/\"")
            manifestPlaceholders = [IM_VALUE: "",PUSH_ID:"",
                                    PUSH_KEY:"",PUSH_SECRET:""]
        }

        ApiPre{
            buildConfigField("String", "BASE_URL", "\"http://baidu.com/\"")
            manifestPlaceholders = [IM_VALUE: "",PUSH_ID:"",
                                    PUSH_KEY:"",PUSH_SECRET:""]
        }

   ApiHost{
            buildConfigField("String", "BASE_URL", "\"http://baidu.com/\"")
            manifestPlaceholders = [IM_VALUE: "",PUSH_ID:"",
                                    PUSH_KEY:"",PUSH_SECRET:""]
        }   
    }

以上是我配置了4個不同API環境的配置,buildConfigField定義了不同環境API的路徑,編譯後會BuildConfig中生成定義的BASE_URL字段,我們在代碼中直接調用BuildConfig.BASE_URL就可以動態配置了。


其次,針對第三方的例如:推送、統計、im等配置,我們需要先去清單文件中配置,例如我配置下個推的:

 <meta-data
            android:name="PUSH_APPID"
            android:value="${PUSH_ID}" />
        <meta-data
            android:name="PUSH_APPKEY"
            android:value="${PUSH_KEY}" />
        <meta-data
            android:name="PUSH_APPSECRET"
            android:value="${PUSH_SECRET}" />


需要用$去定義,然後在bulid.gradle中不同的環境中配置:

  manifestPlaceholders = [IM_VALUE: "",PUSH_ID:"",
                                    PUSH_KEY:"",PUSH_SECRET:""]


之前的productFlavors中已有完整的了。


針對 正式包與debug包日誌的打印的,我是在buildTypes下配置了2個:

 buildTypes {
        release {
            signingConfig signingConfigs.config_release
            buildConfigField("boolean", "SHOW_LOG", "false")
            minifyEnabled true
            shrinkResources true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }

        debug {
            minifyEnabled false
            shrinkResources false
            buildConfigField("boolean", "SHOW_LOG", "true")
        }
    }

一個release,一個debug,我們可以看到release中的buildConfigField,和上面定義不同環境的原理是一樣的,編譯後直接到代碼中BuildConfig.SHOW_LOG開啓或關閉。

同時我們在release中還配置了signingConfig,這個是配置打包證書的配置。


 //簽名配置 簽名信息在gradle.properties中
    signingConfigs{
        config_release{
            storeFile file(RELEASE_STORE_FILE)
            keyAlias RELEASE_KEY_ALIAS
            storePassword RELEASE_STORE_PASSWORD
            keyPassword RELEASE_KEY_PASSWORD
        }
    }

簽名的一些信息不要放在bulid.gradle,最好放在項目project下的gradle.properties或local.properties下

RELEASE_KEY_PASSWORD=123456

RELEASE_KEY_ALIAS=ckasldj

RELEASE_STORE_PASSWORD=123345

RELEASE_STORE_FILE=證書路徑

這樣我們在測試微信支付或分享就可以直接切換到release跑。不用去打包。


以上就是動態配置,說了這麼多,怎麼切換環境呢,上圖



最後說下,由於公司人員多,不同sdk提交build.gradle會出現更新代碼後不是自己的sdk版本信息,我們可以把一些本地的提取出來配置:

我的做法是:

在項目project下新建config.gradle,把一些全局的配置進去,

ext {
    android = [
            compileSdkVersion: 23,
            buildToolsVersion: "23.0.2"
    ]

    dependencies = [
            "support-v4"    : "com.android.support:support-v4:23.1.1",
            "recyclerview"  : "com.android.support:recyclerview-v7:23.1.1",
            "design"        : "com.android.support:design:23.1.1",
            "cardview"        : "com.android.support:cardview-v7:23.1.1"
    ]

}

以上就是config.gradle配置的全局屬性,配置完成後,在根目錄下的build.gradle下最頂部加上apply from:"config.gradle" 引用。

最後在在項目的build.gradle中:

compileSdkVersion rootProject.ext.android.compileSdkVersion
buildToolsVersion rootProject.ext.android.buildToolsVersion


compile rootProject.ext.dependencies["support-v4"]
 compile rootProject.ext.dependencies["recyclerview"]
 compile rootProject.ext.dependencies["design"]
 compile rootProject.ext.dependencies["cardview"]


這樣每次提交build。gradle就不會覆蓋了。

好了,gradle的動態配置就說到這,這也是我在項目實際中運用到的分享給大家,下篇會講解,利用美團的多渠道打包快速生成渠道包。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章