Android Project 检查依赖库和插件版本

2020-11-16 20:05:36

参考地址 Android Project 检查依赖库和插件版本


貌似我是用不到这东西,因为android studio 自带检查依赖更新的功能


纯当做个记录吧

内容简介:Android Project 检查依赖库和插件版本

本文转载自:http://blog.devwiki.net/index.php/2017/06/06/android-project-check-dependencies-plugin-version.html?utm_source=tuicool&utm_medium=referral,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有。

0x01 问题来源

随着项目的开发,引用的库也不断增加,维护引用的版本也是一个耗时的问题.比如一个项目的依赖库如下:

compile libraries.supportAppCompat
compile libraries.rxJava
compile libraries.rxAndroid
compile libraries.retrofit
compile libraries.retrofitConvertGson
compile libraries.retrofitAdapterRxJava
compile libraries.okhttp
compile libraries.okhttpLogInterceptor
compile libraries.okio
compile libraries.wire
compile libraries.glide

这么多版本,如何检查是否有新版呢?

0x02 查找解决方法

通过Google 查找找到一个问题和答案:

android studio - How to detect when dependency library version updates exist in build.gradle in AndroidStudio project - Stack Overflow

该问题的回答者写了个检测依赖库检查的插件,地址如下:

ben-manes/gradle-versions-plugin: Gradle plugin to discover dependency updates

根据使用说明,对现有的项目改造,即可实现版本检查.

0x03 方案实施

0x031. 修改依赖配置

根据插件的使用说明,将项目的依赖改为以下文件,文件地址:

VersionCheck/dependencies.gradle at master · Dev-Wiki/VersionCheck

ext {

    //编译SDK版本
    compileSdkVer = 25
    //构建 工具 版本
    buildToolsVer = "25.0.2"
    //最低兼容版本
    minSdkVer = 14
    //测试过的版本
    targetSdkVer = 25
    //支持库的版本
    supportVer = "25.0.0"
    //JDK版本
    sourceCompatVer = JavaVersion.VERSION_1_7
    targetCompatVer = JavaVersion.VERSION_1_7

    versions = [
        supportVersion:"25.0.0",
        supportMultidex : "1.0.1",
        junit : "4.12",

        gson : "2.6.1",
        rxJava : "1.3.0", //
        rxAndroid : "1.2.1", //
        retrofit : "2.3.0", //
        retrofitConvertGson : "2.3.0", //
        retrofitAdapterRxJava : "2.3.0", //
        okhttp : "3.4.1",//
        okhttpLogInterceptor : "3.4.1",
        okio : "1.9.0", //
        wire : "2.1.2",

        glide : "3.7.0",
    ]
    plugin_versions = [
        versions: "0.15.0",
    ]

    libraries = [
        supportAnnotations : "com.android.support:support-annotations:${versions.supportVersion}",
        supportAppCompat : "com.android.support:appcompat-v7:${versions.supportVersion}",
        supportRecyclerView : "com.android.support:recyclerview-v7:${versions.supportVersion}",
        supportDesign : "com.android.support:design:${versions.supportVersion}",
        supportCardView : "com.android.support:cardview-v7:${versions.supportVersion}",
        supportMultidex : "com.android.support:multidex:${versions.supportMultidex}",
        junit : "junit:junit:${versions.junit}",

        gson : "com.google.code.gson:gson:${versions.gson}",
        rxJava : "io.reactivex:rxjava:${versions.rxJava}", //
        rxAndroid : "io.reactivex:rxandroid:${versions.rxAndroid}", //
        retrofit : "com.squareup.retrofit2:retrofit:${versions.retrofit}", //
        retrofitConvertGson : "com.squareup.retrofit2:converter-gson:${versions.retrofitConvertGson}", //
        retrofitAdapterRxJava : "com.squareup.retrofit2:adapter-rxjava:${versions.retrofitAdapterRxJava}", //
        okhttp : "com.squareup.okhttp3:okhttp:${versions.okhttp}",//
        okhttpLogInterceptor : "com.squareup.okhttp3:logging-interceptor:${versions.okhttpLogInterceptor}",
        okio : "com.squareup.okio:okio:${versions.okio}", //
        wire : "com.squareup.wire:wire-runtime:${versions.wire}",

        glide : "com.github.bumptech.glide:glide:${versions.glide}",
    ]
    gradle_plugins = [
        versions: "com.github.ben-manes:gradle-versions-plugin:${plugin_versions.versions}",
    ]}

0x032. 修改项目配置

然后修改项目的 build.gradle ,引入上述的代码,文件在此:

VersionCheck/build.gradle at master · Dev-Wiki/VersionCheck :

buildscript {
    apply from: "${rootDir}/dependencies.gradle"
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'
        gradle_plugins.each { name, dependency -> classpath dependency }
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }}allprojects {
    apply from: "${rootDir}/dependencies.gradle"
    repositories {
        jcenter()
    }}task clean(type: Delete) {
    delete rootProject.buildDir}

0x033. 修改module的引用

在 module 的 build.gradle 中添加如下:

apply plugin: 'com.github.ben-manes.versions'defaultTasks 'dependencyUpdates'dependencyUpdates.resolutionStrategy = {
    componentSelection { rules ->
        rules.all { ComponentSelection selection ->
            boolean rejected = ['alpha', 'beta', 'rc', 'cr', 'm'].any { qualifier ->
                selection.candidate.version ==~ /(?i).*[.-]${qualifier}[.\d-]*/
            }
            if (rejected) {
                selection.reject('Release candidate')
            }
        }
    }}

如果是多个module还可以直接修改项目的 build.gradle ,将上述内容抽成一个gradle文件 check.gradle ,修改项目的 build.gradle 如下:

apply from: 'check.gradle'buildscript {
    apply from: "${rootDir}/dependencies.gradle"
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'
        gradle_plugins.each { name, dependency -> classpath dependency }
        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }}...

到此,即完成了配置改造.

0x04 执行检测

执行一下命令,来执行检查任务:

gradle dependencyUpdates

结果如下:

------------------------------------------------------------: Project Dependency Updates (report to plain text file)------------------------------------------------------------The following dependencies are using the latest milestone version:
 - com.squareup.retrofit2:adapter-rxjava:2.3.0
 - com.squareup.retrofit2:converter-gson:2.3.0
 - com.github.ben-manes:gradle-versions-plugin:0.15.0
 - com.squareup.retrofit2:retrofit:2.3.0
 - io.reactivex:rxandroid:1.2.1
 - io.reactivex:rxjava:1.3.0The following dependencies exceed the version found at the milestone revision level:
 - com.github.bumptech.glide:glide [3.7.0 <- 3.6.1]The following dependencies have later milestone versions:
 - com.android.support:appcompat-v7 [25.0.0 -> 25.3.1]
 - com.android.tools.build:gradle [2.2.3 -> 2.5.0-alpha-preview-02]
 - com.squareup.okhttp3:logging-interceptor [3.4.1 -> 3.8.0]
 - com.squareup.okhttp3:okhttp [3.4.1 -> 3.8.0]
 - com.squareup.okio:okio [1.9.0 -> 1.13.0]
 - com.squareup.wire:wire-runtime [2.1.2 -> 2.2.0]

从上述结果可以看出版本有无更新.

0x05 后记

以上项目地址如下:

Dev-Wiki/VersionCheck: 依赖版本检测Demo


  • 2020-11-22 23:00:16

    androidx中的lifecycle组件

    Lifecycle-aware components生命周期感知组件执行操作,以响应另一个组件生命周期状态的更改,例如Activity和Fragment。这些组件可以帮助您生成更有组织、更容易维护的轻量级代码。

  • 2020-11-22 23:02:50

    Android数据存储之DataBase的Room

    Room是Google在AndroidX中提供的一个ORM(Object Relational Mapping,对象关系映射)库。它是在SQLite上提供的一个抽象层,可以使用SQLite的全部功能,同时可以更好更便捷流畅地访问数据库。(关于AndroidX可以参考

  • 2020-11-22 23:04:39

    Android组件 LiveData与MutableLiveData教程

    LiveData与ViewMode是经常搭配在一起使用的,但是为了不太混乱,我还是拆分开来说明,此篇博客只讲解 LiveData 与 MutableLiveData的概念与使用方式(但是会涉及到ViewMode的部分代码).

  • 2020-11-22 23:14:52

    Dagger 2 在 Android 上的用法

    在前面的文章我们介绍了Dagger2 中的大部分注解的使用,接下来我们从源码角度分析下第一篇文章中例子的原理。

  • 2020-11-22 23:18:59

    Android开发从Dagger2迁移至Kodein的感受

    最近个人在尝试构建 Kotlin版本 的Android MVVM开发框架,在依赖注入框架的选型上,我最终选择了 Kodein 。这是一个非常轻量级的DI框架,相比于配置繁琐的Dagger(繁琐的配置也是导致Dagger学习成本一直居高不下的原因!),它的配置过程更清晰且简单,并且,这个库的源码也是 Kotlin 的。

  • 2020-11-22 23:25:56

    Dagger2源码解析inject过程

    添加inject后,通过编译生成的DaggerMainComponent类来导入,说明编译以后生成了一些类,那到底生成了什么类呢。 Module和Component又是什么,该怎么里理解 在这篇文章后里将一一讨论。

  • 2020-11-22 23:27:28

    dagger学习教程

    dagger android 学习(一):dagger基础使用 dagger android 学习(二):AndroidInjector的使用 dagger android 学习(三):ContributesAndroidInjector的进一步优化 dagger android 学习(四):基于dagger2的mvp架构

  • 2020-11-22 23:31:22

    Dagger2与AndroidInjector详解

    相信使用过Dagger开发Android应用的小伙伴会知道(如果你还不是很了解Daager,可以先看我之前的一篇基本介绍:Dagger2使用攻略),我们会在Activity或Fragment的生命周期方法中执行成员注入。比如这样:

  • 2020-11-23 08:52:59

    asm.js 和 Emscripten 入门教程

    asm.js 就是为了解决这两个问题而设计的:它的变量一律都是静态类型,并且取消垃圾回收机制。除了这两点,它与 JavaScript 并无差异,也就是说,asm.js 是 JavaScript 的一个严格的子集,只能使用后者的一部分语法。

  • 2020-11-23 09:11:07

    爬虫——记一次破解前端加密详细过程

    从最初使用webdriver+selenium爬虫到现在利用http请求解析html,经历过各种各样的问题,webdriver+selenium这种办法虽然万能,而且可以用JS写解析脚本方便调试,