Androidstudio高效管理第三方API的KEY及Gradle版本管理

1,556 阅读1分钟
  • 第三方API的KEY的管理
    Android开发,基本都会用到第三方SDK,例如百度地图、支付宝支付等。
    通常第三方的KEY都是保存在AndroidManifest中:
    <!-- 百度地图的KEY-->
    <meta-data
      android:name="com.baidu.lbsapi.API_KEY"
     android:value="百度地图注册的KEY"/>
    每次更换KEY或者多渠道打包;总是在Gradle和Mainfest中来回更改,有时候一个疏忽,可能就漏了一个,怎能让人不蛋疼。
    能不能将他们统一配置到某个位置,统一管理,轻松更改呢?Google替我们想到了。利用manifestPlaceholders
  • ######方法
    AndroidManifest中的KEY,我们用一个变量代替,在build.gradle中动态的替换,还以百度地图SDK的KEY为例:

    <meta-data
           android:name="com.baidu.lbsapi.API_KEY"
           android:value="${baidu_key}"/>

    在build.gradle中:

          debug {
              manifestPlaceholders = [baidu_key: 百度地图的KEY]
          }
    
          release {
             manifestPlaceholders = [baidu_key: 百度地图的KEY]
          }

    其它的第三方KEY管理类似,例如新加入友盟SDK

    <meta-data
           android:name="com.baidu.lbsapi.API_KEY"
           android:value="${baidu_key}"/>
    <meta-data
           android:name="UMENG_APPKEY"
           android:value="${umeng_key}"/>

    在build.gradle中:

          debug {
              manifestPlaceholders = [baidu_key: 百度地图的KEY,umeng_key: 友盟的KEY]
          }
    
          release {
             manifestPlaceholders = [baidu_key: 百度地图的KEY,umeng_key: 友盟的KEY]
          }

搞定,类似第三方KEY都可以在gradle中管理

  • Gradle中版本管理
    gradle中,包含包名、VersionCode、versionName、compileSdkVersion以及第三方依赖库等大量信息,管理起来,稍有不慎就会误删或者改错,导致编译失败,能不能像管理第三方KEY一样,将所有需要修改的参数统一管理起来,只修改参数,不干扰其他因素这样在版本升级中,无需打开gradle在繁杂的代码中修改各种版本号,例如:

统一管理.png
统一管理.png

需要修改compileSdkVersion 时,只需要修改COMPILE_SDK_VERSION,何乐而不为,那就开始吧:

  • 命名规则:命名自定义,但是最好见名知意,字母大写,类似于全局常量命名,后面加修饰符号
  • 例如:minSdkVersion,命名MIN_SDK_VERSION,修饰符号 as int ,
    完整命名:minSdkVersion MIN_SDK_VERSION as int

    针对所有需要统一管理的参数命名之后,就类似于上面的图片,这个时候问题来了,命名之后,具体参数我们在哪里记录,并让gradle找到的我们设置的参数呢?

    在Project目录下,找到gradle.properties

    Paste_Image.png
    Paste_Image.png

    gradle.properties中,去配置我们声明的参数:
    Paste_Image.png
    Paste_Image.png

    这样,在版本升级中,更改VERSION_NAME和VERSION_CODE就是再简单不过,还不容易出错

  • 然鹅,不仅仅如此:

    run.gif
    run.gif

开发中经常使用到的第三方库,以依赖方式添加的库,管理起来也一样方便,例如,现在如日中天的Rxjava库、Retrofit库,RxAndroid库:

    compile 'com.squareup.retrofit2:retrofit:2.1.0'
    compile 'com.squareup.retrofit2:converter-gson:2.1.0'
    compile 'com.squareup.retrofit2:adapter-rxjava:2.1.0'
    compile 'io.reactivex:rxandroid:1.2.0'
    compile 'io.reactivex:rxjava:1.1.6'

对应版本,也可以在gradle.properties统一管理,不过在build.gradle中命名方式,类似于第三方KEY的命名:

compile "io.reactivex:rxandroid:${RX_ANDROID_VERSION}"
compile "io.reactivex:rxjava:${RX_JAVA_VERSION}"
compile "com.squareup.retrofit2:retrofit:${RETROFIT_VERSION}"
compile "com.squareup.retrofit2:converter-gson:${RETROFIT_VERSION}"

同理,对应的版本号在gradle.properties

依赖库的版本管理.png
依赖库的版本管理.png

通过gradle,并不需要复杂操作,统一管理各种第三方KEY和依赖库的版本,避免开发中出错,希望大家能使用这些开发的小技巧,提高开发效率,代码无bug, 月活过百万,月薪6位数,迎娶白富美,打哭产品,走上人生巅峰