在gradle中构建java项目

简介: 在gradle中构建java项目

目录



简介


之前的文章我们讲到了gradle的基本使用,使用gradle的最终目的就是为了构建java项目。今天本文将会详细的讲解如何在gradle中构建java项目。


构建java项目的两大插件


安装java项目的目的不同,构建java项目有两大插件,一个是application,表示构建的是java应用程序;一个是java-library,表示构建的是java库,供别的项目使用。


不管是构建应用程序还是java库,我们都可以很方便的使用gradle init来创新一个新的gradle项目:


$ gradle init
Select type of project to generate:
  1: basic
  2: application
  3: library
  4: Gradle plugin
Enter selection (default: basic) [1..4] 2
Select implementation language:
  1: C++
  2: Groovy
  3: Java
  4: Kotlin
  5: Scala
  6: Swift
Enter selection (default: Java) [1..6] 3
Select build script DSL:
  1: Groovy
  2: Kotlin
Enter selection (default: Groovy) [1..2] 1
Select test framework:
  1: JUnit 4
  2: TestNG
  3: Spock
  4: JUnit Jupiter
Enter selection (default: JUnit 4) [1..4]
Project name (default: demo):
Source package (default: demo):
BUILD SUCCESSFUL
2 actionable tasks: 2 executed


application和library的不同之处在于第二步选择的不同。


两者在build.gradle中的不同在于plugins的不同,application的plugin是:


plugins {
    id 'application' 
}


而library的plugin是:


plugins {
    id 'java-library' 
}


还有一个不同之处是依赖的不同,先看一个application的依赖:


dependencies {
    testImplementation 'junit:junit:4.13' 
    implementation 'com.google.guava:guava:29.0-jre' 
}


再看一个library的依赖:


dependencies {
    testImplementation 'junit:junit:4.13' 
    api 'org.apache.commons:commons-math3:3.6.1' 
    implementation 'com.google.guava:guava:29.0-jre' 
}


因为library是需要给第三方应用程序使用的,所以这里多了一个api的使用,api表示是第三方应用程序也需要依赖这个包,而implementation表示的是该包只是在这个项目内部被依赖。


在构建libary的时候,还可以自定义manifest的信息:


tasks.named('jar') {
    manifest {
        attributes('Implementation-Title': project.name,
                   'Implementation-Version': project.version)
    }
}


上面的例子将会在META-INF/MANIFEST.MF生成:


Manifest-Version: 1.0
Implementation-Title: lib
Implementation-Version: 0.1.0


我们还可以指定编译的java版本号和lib的版本:


java {
    toolchain {
        languageVersion = JavaLanguageVersion.of(11)
    }
}
version = '1.2.1'


管理依赖


java的依赖一般都是jar包组成的library。和maven一样,我们在gradle中指定依赖需要指定依赖的名字和版本号,依赖的范围:是运行时依赖还是编译时依赖,还有一个重要的就是在哪里可以找到这个library。


前面两个属性我们可以在dependencies中找到,后面一个我们可以在repositories中找到,看一个例子:


repositories {
    mavenCentral()
}
dependencies {
    implementation 'org.hibernate:hibernate-core:3.6.7.Final'
}


还可以使用这种形式的maven:


repositories {
    maven {
        url "http://repo.mycompany.com/maven2"
    }
}


或者Ivy:


repositories {
    ivy {
        url "http://repo.mycompany.com/repo"
    }
}


甚至可以使用本地的local dir:


repositories {
    flatDir {
        dirs 'lib'
    }
    flatDir {
        dirs 'lib1', 'lib2'
    }
}


上面定义了一个mavenCentral的仓库,我们可以在这个仓库中去查找hibernate-core这个依赖的jar包。


在dependencies这一块,我们可以定义依赖包的工作范围:


  • compileOnly: 表示依赖包只被用来编译代码,并不用在程序的运行。
  • implementation:表示依赖包被用在编译和运行时。
  • runtimeOnly: 只在运行时使用。
  • testCompileOnly: 仅在test的编译时使用。
  • testImplementation:在test的编译和运行时使用。
  • testRuntimeOnly: 在test的运行时使用。


我们还可以添加动态的依赖:


dependencies {
    implementation 'org.springframework:spring-web:5.+'
}


使用项目作为依赖:


dependencies {
    implementation project(':shared')
}


编译代码


一般情况下你的源代码需要放在src/main/java 目录下,测试代码需要放在src/test/java下面。然后添加compileOnly 或者 implementation依赖,如果需要测试的话,添加testCompileOnly或者testImplementation依赖。


然后就可以运行compileJava和compileTestJava来编译代码了。


当然,如果你有自定义的源文件目录,也可以这样手动指定:


sourceSets {
    main {
         java {
            srcDirs = ['src']
         }
    }
    test {
        java {
            srcDirs = ['test']
        }
    }
}


上面的代码中我们给srcDirs重新赋值了。如果我们只是想要在现有的代码路径上再添加一个新的路径,那么可以使用srcDir:


sourceSets {
    main {
        java {
            srcDir 'thirdParty/src/main/java'
        }
    }
}


除了源代码的路径,我们还可以配置编译的参数,并指定编译的JDK版本号:


compileJava {
    options.incremental = true
    options.fork = true
    options.failOnError = false
    options.release = 7
}


注意,gradle必须要在JDK8以上才能运行,但是我们可以指定gradle去使用Java 6 或者 Java 7去编译源代码。


我们还可以指定预览版本的特性:


tasks.withType(JavaCompile) {
    options.compilerArgs += "--enable-preview"
}
tasks.withType(Test) {
    jvmArgs += "--enable-preview"
}
tasks.withType(JavaExec) {
    jvmArgs += "--enable-preview"
}


管理resource


java除了源代码文件之外,还有一些resource文件,比如配置文件,图片文件,语言文件等等。我们需要将这些配置文件拷贝到特定的目标目录中。


默认情况下,gradle会拷贝src/[sourceSet]/resources 中的文件到目标文件夹中。


我们看一个复杂的拷贝动作:


task copyDocs(type: Copy) {
    from 'src/main/doc'
    into 'build/target/doc'
}
//for Ant filter
import org.apache.tools.ant.filters.ReplaceTokens
//for including in the copy task
def dataContent = copySpec {
    from 'src/data'
    include '*.data'
}
task initConfig(type: Copy) {
    from('src/main/config') {
        include '**/*.properties'
        include '**/*.xml'
        filter(ReplaceTokens, tokens: [version: '2.3.1'])
    }
    from('src/main/config') {
        exclude '**/*.properties', '**/*.xml'
    }
    from('src/main/languages') {
        rename 'EN_US_(.*)', '$1'
    }
    into 'build/target/config'
    exclude '**/*.bak'
    includeEmptyDirs = false
    with dataContent
}


打包和发布


我们可以根据不同的构建类型来打包对应的文件。比如对应java lib来说,我们可以同时上传源代码和java doc文件:


java {
    withJavadocJar()
    withSourcesJar()
}


比如说我们还可以打包成一个fat jar包:


plugins {
    id 'java'
}
version = '1.0.0'
repositories {
    mavenCentral()
}
dependencies {
    implementation 'commons-io:commons-io:2.6'
}
task uberJar(type: Jar) {
    archiveClassifier = 'uber'
    from sourceSets.main.output
    dependsOn configurations.runtimeClasspath
    from {
        configurations.runtimeClasspath.findAll { it.name.endsWith('jar') }.collect { zipTree(it) }
    }
}


生成javadoc


gradle的java library插件有一个javadoc task,可以为java项目生成文档。它支持标准的javadoc,也支持其他类型的文档,比如说Asciidoc,我们看一个生成Asciidoc的例子:


configurations {
    asciidoclet
}
dependencies {
    asciidoclet 'org.asciidoctor:asciidoclet:1.+'
}
task configureJavadoc {
    doLast {
        javadoc {
            options.doclet = 'org.asciidoctor.Asciidoclet'
            options.docletpath = configurations.asciidoclet.files.toList()
        }
    }
}
javadoc {
    dependsOn configureJavadoc
}
相关文章
|
1月前
|
存储 监控 安全
单位网络监控软件:Java 技术驱动的高效网络监管体系构建
在数字化办公时代,构建基于Java技术的单位网络监控软件至关重要。该软件能精准监管单位网络活动,保障信息安全,提升工作效率。通过网络流量监测、访问控制及连接状态监控等模块,实现高效网络监管,确保网络稳定、安全、高效运行。
65 11
|
22天前
|
Java Maven
java项目中jar启动执行日志报错:no main manifest attribute, in /www/wwwroot/snow-server/z-server.jar-jar打包的大小明显小于正常大小如何解决
在Java项目中,启动jar包时遇到“no main manifest attribute”错误,且打包大小明显偏小。常见原因包括:1) Maven配置中跳过主程序打包;2) 缺少Manifest文件或Main-Class属性。解决方案如下:
java项目中jar启动执行日志报错:no main manifest attribute, in /www/wwwroot/snow-server/z-server.jar-jar打包的大小明显小于正常大小如何解决
|
18天前
|
存储 Java BI
java怎么统计每个项目下的每个类别的数据
通过本文,我们详细介绍了如何在Java中统计每个项目下的每个类别的数据,包括数据模型设计、数据存储和统计方法。通过定义 `Category`和 `Project`类,并使用 `ProjectManager`类进行管理,可以轻松实现项目和类别的数据统计。希望本文能够帮助您理解和实现类似的统计需求。
68 17
|
1月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
147 26
|
2月前
|
XML Java 测试技术
从零开始学 Maven:简化 Java 项目的构建与管理
Maven 是一个由 Apache 软件基金会开发的项目管理和构建自动化工具。它主要用在 Java 项目中,但也可以用于其他类型的项目。
80 1
从零开始学 Maven:简化 Java 项目的构建与管理
|
1月前
|
缓存 监控 安全
公司电脑监控软件的 Gradle 构建自动化优势
在数字化办公环境中,公司电脑监控软件面临代码更新频繁、依赖管理和构建复杂等挑战。Gradle 构建自动化工具以其强大的依赖管理、灵活的构建脚本定制及高效的构建缓存与增量构建特性,显著提升了软件开发效率和质量,支持软件的持续更新与优化,满足企业对员工电脑使用情况的监控与管理需求。
37 3
|
2月前
|
Java
Java项目中高精度数值计算:为何BigDecimal优于Double
在Java项目开发中,涉及金额计算、面积计算等高精度数值操作时,应选择 `BigDecimal` 而非 `Double`。`BigDecimal` 提供任意精度的小数运算、多种舍入模式和良好的可读性,确保计算结果的准确性和可靠性。例如,在金额计算中,`BigDecimal` 可以精确到小数点后两位,而 `Double` 可能因精度问题导致结果不准确。
|
2月前
|
Java Android开发
Eclipse Java 构建路径
Eclipse Java 构建路径
47 3
|
2月前
|
Java Android开发
Eclipse 创建 Java 项目
Eclipse 创建 Java 项目
57 4
|
2月前
|
SQL Java 数据库连接
从理论到实践:Hibernate与JPA在Java项目中的实际应用
本文介绍了Java持久层框架Hibernate和JPA的基本概念及其在具体项目中的应用。通过一个在线书店系统的实例,展示了如何使用@Entity注解定义实体类、通过Spring Data JPA定义仓库接口、在服务层调用方法进行数据库操作,以及使用JPQL编写自定义查询和管理事务。这些技术不仅简化了数据库操作,还显著提升了开发效率。
67 3