Gradle 本身提供了一些基本的概念和整体核心的框架,其他用于描述真实使用场景的都可以通过插件扩展的方式来实现。这样就可以通过抽象的方式提供一个核心的框架,其他具体的功能和业务都通过插件扩展的方式来实现。

Gradle 内置了很多常用的插件,基本满足大部分工作,但是也有一些插件是没有内置的,这时候就需要我们扩展现有插件或者自定义插件来达到我们的目的。比如 Android Gradle 插件就是基于内置的Java插件实现的。

一、插件的作用

插件会扩展项目的功能,帮助我们在项目的构建的过程中做很多事情:

  • 可以添加任务到项目中,帮助完成诸如 测试、编译、打包等事情。
  • 可以添加依赖配置到项目中,通过它们来配置我们在构建过程中的依赖。
  • 可以向项目中现有的对象类型添加新的扩展属性、方法等,可以使用它们来配置优化构建。例如:android{}这个配置块就是Android Gradle插件为Project对象添加的一个扩展。
  • 可以对项目进行一些约定,比如应用Java插件后,可以约定src/main/java目录下是我们的源代码的存放地址,在编译的时候也是编译这个目录下的Java源代码文件。

这就是插件,我们只需要按照它约定的方式,使用它提供的任务、方法或者扩展,就可以对我们的项目进行构建。

二、如何应用插件

插件的应用都是通过Project.apply()方法完成的。apply有好几种用法,并且插件也分为二进制插件和脚本插件。下面我们分别介绍一下:

1. 应用二进制插件

二进制插件就是实现了org.gradle.api.Plugin接口的插件,它们可以有plugin id。

举例:下面我们看一下如何应用一个Java插件:



apply plugin:'java'



使用上面的语句就可以把java插件应用到我们的项目中了,其中‘java’就是Java插件的plugin id,它是唯一的。

2. 应用脚本插件

脚本插件的使用方式如下例所示:

build.gradle:



apply from:'version.gradle'

task outVersion {

    println("APP版本是:${versionName},版本号是:${versionCode}")
    
}



version.gradle:



ext {
    versionName = '1.3.0'
    versionCode = 1
}



允许结果如下:



renhui$ gradle outVersion

> Configure project :
APP版本是:1.3.0,版本号是:1

BUILD SUCCESSFUL in 0s



应用脚本插件,其实就是把脚本加载进来,和二进制插件不同的是它使用的是from关键字,后面紧跟着一个脚本文件(可以是本地文件,也可以是网络文件)。

脚本插件能帮助我们把较大较复杂的脚本文件进行分块、分段整理,它是脚本文件模块化的基础。

3. 应用第三方发布的插件

第三方发布的作为jar的二进制插件,我们在应用的时候,必须要在buildscript{}里面配置其classpath才能使用,这个不像Gradle为我们内置的插件。

比如我们的Android Gradle插件就属于Android发布的第三方插件,如果我们要使用它就要先配置,示例如下:



buildscript {
    repositories {
        google()
        jcenter()
        
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.4.0'
    }
}



buildscript{}块是一个在构建项目之前,为项目进行前期准备和初始化相关配置依赖的地方,配置好所需的依赖,就可以应用其提供的插件了。

下面是在app层应用android gradle插件的方式:



apply plugin: 'com.android.application'



如果没有提前在buildscript里配置依赖的classpath,则会报错,提示找不到这个插件。

三、Java Gradle 插件

使用Java Gradle插件我们能够很轻松的构建出一个项目,我们常用的方式就是使用简称应用Java Gradle插件:



apply plugin: 'java'



通过以上的配置,Java插件会为工程添加很多有用的默认设置和约定,比如源代码的位置,单元测试代码的位置、资源文件的位置等。

作为Java项目,我们不可避免的会依赖很多第三方的Jar,这也是值得提倡的,因为有很多开源的工具和框架能够帮助我们更加高效的开发。下面我们就讲一下如何配置第三方依赖。

1. 配置第三方依赖

想要使用这些第三方依赖,就需要告诉Gradle如何找到这些依赖,也就是我们要讲的依赖配置。

一般情况下我们都是从仓库中查找我们需要的Jar包,在Gradle中要配置一个仓库的Jar依赖,首先我们得告诉Gradle我们要是有什么类型的仓库,这些仓库的位置在哪里,这样Gradle就知道从哪里去搜寻我们依赖的Jar,例如:



respositories {
    mavenCentral()
}



以上代码,我们配置了一个Maven中心库,告诉Gradle可以在Maven中心库中搜寻我们依赖的Jar,除此之外,我们也可以从jcenter库、ivy库、本地Maven库mavenLocal等中搜寻。由此可见,Gradle支持的仓库非常丰富,也可以多个仓库一起使用。比如一些公共的开源框架可以从mavenCenteral上下载,一些我们公司私有的Jar可以在自己搭建的Maven私服上下载:



respositories {
    mavenCentral()
    maven {
         url 'http://www.mavenurl.com'
    }
}



有了仓库,我们就可以通过配置告诉Gradle,我们需要依赖什么,例如:



dependencies {
     compile group: 'com.squareup.okhttp3', name: 'okhttp', version: '3.0.1'    
}



在上面的例子中,我们配置了一个okhttp的依赖,其中compile是依赖名称,它的意思表示我们在编译Java源文件时需要依赖okttp,并提供了GAV信息。

但是相对来说,上面的写法还是稍显麻烦的,Gradle为我们提供了简写的方式:



dependencies {
     compile 'com.squareup.okhttp3:okhttp:3.0.1'    
}



2. 配置项目&文件依赖

除了我们在上面提到的仓库的三方依赖,我们还可以进行项目的依赖以及文件的依赖。

项目依赖示例:



dependencies {
     compile project(':example')    
}



依赖后,此项目中的Java等类就可以进行使用了,就像使用自己项目中的类一样。

文件依赖,一般是依赖一个jar包(出于某些原因,不能将jar发布到Maven中心库中,只能放在项目中),例如:



dependencies {
     compile files('libs/example')    
}



通过上面的配置,我们就能成功引入这两个Jar包了。

但有时候,libs文件里的类太多了,不能一个个写,这时候我们就可以通过以下的方式配置:



dependencies {
     compile fileTree(dir: 'libs', include: '*.jar')    
}



这样配置后,libs下的文件夹的扩展名为jar的都会被依赖,非常方便。