Gradle構建多模塊項目的方法步驟
通常我在使用Maven構建項目的時候是將應用項目劃分為多個更小的模塊。
Gradle 項目也擁有多于一個組件,我們也將其稱之為多項目構建(multi-project build)。
我們首先創(chuàng)建一個多項目構建:
mkdir cmdGradleProj && cd cmdGradleProj gradle init
這時候
D:\cmdGradleProj> 目錄下執(zhí)行:tree /f
的項目結構如下:
│ build.gradle
│ gradlew
│ gradlew.bat
│ settings.gradle
│
├─.gradle
│ └─3.0
│ └─taskArtifacts
│ cache.properties
│ cache.properties.lock
│ fileHashes.bin
│ fileSnapshots.bin
│ fileSnapshotsToTreeSnapshotsIndex.bin
│ taskArtifacts.bin
│
└─gradle
└─wrapper
gradle-wrapper.jar
gradle-wrapper.properties
然后,創(chuàng)建多個模塊,這里以 core 和 web 模塊為例,先創(chuàng)建四個目錄(test 文件夾用于編寫測試類):
mkdir core\src\main\java mkdir core\src\main\test mkdir web\src\main\java mkdir web\src\main\resources
core模塊 :包含一些通用的組件,它們能夠被程序的其他模塊使用。例子中,只包含一個類:MessageService類返回 ‘Hello World!' 字符串。該模塊有兩個依賴:Junit 4.11與commons-lang3。
web模塊:模塊包含HelloWorld類,是程序的開端,它從MessageService對象中獲取信息,并將接收到的信息寫入一個日志文件中。該模塊擁有兩個依賴:它需要core模塊,還使用Log4j作為日志。
現(xiàn)在,我們已經(jīng)創(chuàng)建了所需的目錄,下一步是配置Gradle構建,先對包含在多項目構建中的項目進行配置。
我們可以通過以下步驟,對包含在多項目構建中的項目進行配置:
1.在根項目的根目錄下創(chuàng)建 settings.gradle 文件,一個多項目Gradle構建必須含有這個文件,因為它指明了那些包含在多項目構建中的項目。
2.確保 web 和 core 項目包含在我們的多項目構建中。
我們的 settings.gradle 文件如下:
include 'core'
include 'web'
簡寫:include 'core','web'
修改根目錄下的 build.gradle:
// 所有子項目的通用配置
subprojects {
apply plugin: 'java'
// apply plugin: 'eclipse'
apply plugin: 'idea'
version = '1.0'
// JVM 版本號要求
sourceCompatibility = 1.8
targetCompatibility = 1.8
// java編譯的時候缺省狀態(tài)下會因為中文字符而失敗
[compileJava,compileTestJava,javadoc]*.options*.encoding = 'UTF-8'
//定義版本號
ext {
springVersion = '4.3.3.RELEASE'
hibernateVersion='5.2.2.Final'
}
repositories {
mavenCentral()
}
jar {
manifest {
attributes("Implementation-Title": "Gradle")
}
}
configurations {
// 所有需要忽略的包定義在此
all*.exclude group: 'commons-httpclient'
all*.exclude group: 'commons-logging'
all*.exclude group: 'commons-beanutils', module: 'commons-beanutils'
}
dependencies {
// 通用依賴
compile(
"org.springframework:spring-context:$springVersion",
"org.springframework:spring-orm:$springVersion",
"org.springframework:spring-tx:$springVersion",
"org.springframework.data:spring-data-jpa:1.10.3.RELEASE",
"org.hibernate:hibernate-entitymanager:$hibernateVersion",
"c3p0:c3p0:0.9.1.2",
"mysql:mysql-connector-java:6.0.4",
"org.slf4j:slf4j-nop:1.7.21",
"commons-fileupload:commons-fileupload:1.3.2",
"com.fasterxml.jackson.core:jackson-databind:2.8.2"
)
// 依賴maven中不存在的jar
ext.jarTree = fileTree(dir: 'libs', include: '**/*.jar')
ext.rootProjectLibs = new File(rootProject.rootDir, 'libs').getAbsolutePath()
ext.jarTree += fileTree(dir: rootProjectLibs, include: '**/*.jar')
compile jarTree
// 測試依賴
testCompile(
"org.springframework:spring-test:$springVersion",
"junit:junit:4.12"
)
}
// 顯示當前項目下所有用于 compile 的 jar.
task listJars(description: 'Display all compile jars.') << {
configurations.compile.each { File file -> println file.name }
}
}
接下來可以修改 core/build.gradle 來定義 core 模塊的依賴:
// jar包的名字
archivesBaseName = 'core'
// 還可以定義其他配置,這里直接繼承父模塊中的配置
web 模塊需要依賴 core 模塊,故定義 web/build.gradle 如下:
apply plugin:"war"
dependencies{
// 依賴 core 模塊
compile project(":core")
compile(
"org.springframework:spring-webmvc:$springVersion",
"org.apache.taglibs:taglibs-standard-impl:1.2.1"
)
//系統(tǒng)提供的依賴
providedCompile(
"javax.servlet:javax.servlet-api:3.1.0",
"javax.servlet.jsp:jsp-api:2.2.1-b03",
"javax.servlet.jsp.jstl:javax.servlet.jsp.jstl-api:1.2.1"
)
}
task jarWithoutResources(type: Jar) {
baseName project.name
from("$buildDir/classes/main")
}
war{
dependsOn jarWithoutResources
from("$projectDir/src/main/resources") {
include "*.properties"
into("WEB-INF/classes")
}
classpath=classpath - sourceSets.main.output
classpath fileTree(dir:libsDir, include:"${project.name}-${version}.jar")
}
task('jarPath')<<{
configurations.runtime.resolve().each {
print it.toString()+";"
}
println();
}
3. 編譯項目
查看所有 jar:
> gradle listJars // 查看各個模塊的依賴: > gradle :core:dependencies > gradle :web:dependencies //編譯所有模塊: > gradle build
對比一下,這時候的目錄如下:
│ build.gradle
│ gradlew
│ gradlew.bat
│ settings.gradle
│
├───.gradle
│ └───3.0
│ └───taskArtifacts
│ cache.properties
│ cache.properties.lock
│ fileHashes.bin
│ fileSnapshots.bin
│ fileSnapshotsToTreeSnapshotsIndex.bin
│ taskArtifacts.bin
│
├───core
│ │ build.gradle
│ │
│ ├───build
│ │ ├───libs
│ │ │ core-1.0.jar
│ │ │
│ │ └───tmp
│ │ └───jar
│ │ MANIFEST.MF
│ │
│ └───src
│ ├───main
│ │ └───java
│ └───test
│ └───java
├───gradle
│ └───wrapper
│ gradle-wrapper.jar
│ gradle-wrapper.properties
│
└───web
│ build.gradle
│
├───build
│ ├───libs
│ │ web-1.0.jar
│ │ web-1.0.war
│ │
│ └───tmp
│ ├───jarWithoutResources
│ │ MANIFEST.MF
│ │
│ └───war
│ MANIFEST.MF
│
└───src
└───main
├───java
└───resources
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot集成Mybatis-Plus多租戶架構實現(xiàn)
本文主要介紹了SpringBoot集成Mybatis-Plus多租戶架構實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
springboot-rabbitmq-reply?消息直接回復模式詳情
這篇文章主要介紹了springboot-rabbitmq-reply消息直接回復模式詳情,文章通過圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-09-09
Hibernate框架數(shù)據(jù)分頁技術實例分析
這篇文章主要介紹了Hibernate框架數(shù)據(jù)分頁技術,結合實例形式分析了Hibernate框架實現(xiàn)數(shù)據(jù)分頁的原理,步驟與相關實現(xiàn)技巧,需要的朋友可以參考下2016-03-03
解決SpringCloud Gateway配置自定義路由404的坑
這篇文章主要介紹了解決SpringCloud Gateway配置自定義路由404的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Netty之使用DelimiterBasedFrameDecoder進行消息分隔詳解
這篇文章主要介紹了Netty之使用DelimiterBasedFrameDecoder進行消息分隔詳解,在使用Netty進行TCP消息傳輸時,為了上層協(xié)議能夠?qū)ο⒄_區(qū)分,避免粘包和拆包導致的問題,一般可以通過消息定長、將回車換行符作為消息結束符,需要的朋友可以參考下2023-12-12

