Gradle8.4构建SpringBoot多模块项目
Gradle8.4构建SpringBoot多模块项目
一、基本
1、版本
- 这个版本是Jdk8最后一个SpringBoot版本
| 软件 | 版本 |
|---|---|
| Gradle | 8.4 |
| SpringBoot | 2.7.15 |
| JDK | 8 |
2、Gradle基本介绍
2.1、使用Wrapper方式构建
- 好处:统一gradle的版本
- 好处:不用安装gradle就可以使用
- Maven也是一样的可以用Wrapper的方式
2.2、导包方式
- 列举常用的四种
implementation
api
compileOnly
compileOnlyApi
①、implementation
- 导入依赖,不传递给子模块,依赖项将被编译和打包到项目中
②、api
- 导入依赖,传递给子模块,依赖项将被编译和打包到项目中
③、implementation和api的区别
关于implementation、api的传递依赖具体问题可以见我的博问(感谢大佬:@basic60)
https://q.cnblogs.com/q/143866/关于所有的导包方式的区别也可以见管网:
https://docs.gradle.org/current/userguide/java_library_plugin.html截图

④、compileOnly
- 导入依赖,不传递给子模块,依赖项将被编译到项目中,不打包到项目
⑤、compileOnlyApi
- 导入依赖,传递给子模块,依赖项将被编译到项目中,不打包到项目
2.3、build.gradle配置文件
- 相当于Maven的pom文件,主要是配置模块,导入依赖的作用
①、allprojects
- 里面的配置,所有模块生效
- 一般配置包的信息、编码、仓库地址
allprojects {
}
②、subprojects
- 里面的配置,只有自己和子模块生效
- 一般配置插件、统一包的版本管理、打包方式等等
subprojects {
}
③、dependencies
- 导入依赖,相当于Maven的<dependency></dependency> 导包
- 引入依赖演示
dependencies {
// api可以传递依赖、implementation不能传递依赖
// hutool工具类
api 'cn.hutool:hutool-all'
}
- 引入模块演示
dependencies {
//依赖公共模块
api project(":模块地址")
implementation project(":GradleParent:GradleUtil")
}
2.4、settings.gradle配置文件
- 配置模块间的信息,见后面具体实现
二、实现
1、项目结构
-GradleMultiModule
-GradleParent 包装common、util的父模块(实际中可以不要,这里演示导包、传递依赖等)
-GradleCommon 公共模块,用于装entity或者mapper等
-GradleUtil 工具类模块
-GradleServer 业务模块的父模块,用于给子模块统一导入springboot的包
-GradleOne 业务模块1 - 依赖GradleCommon、GradleUtil
-GradleTwo 业务模块2 - 依赖
-GradleStart 启动模块 - 导入GradleOne、GradleTwo依赖,启动项目
- 结构

2、新建模块
- 只演示一遍
- 就是用idea创建springboot的gradle项目

3、各个模块的配置及类
3.1、GradleMultiModule模块
顶级父模块
统一配置 build.gradle (还可以配置gradle的版本)
配置所有模块的关系 settings.gradle
①、build.gradle
wrapper:配置gradle的版本,需要单独点击执行,执行后查看gradle版本是否生效

- 具体配置
//插件
plugins {
id 'java'
id 'idea'
id 'java-library'
id 'org.springframework.boot' version '2.7.15'
id 'io.spring.dependency-management' version '1.0.15.RELEASE'
}
//allprojects:所有模块生效
allprojects {
// 配置项目信息
group = 'com.cc'
version = '0.0.1-SNAPSHOT'
// 配置字符编码
tasks.withType(JavaCompile).configureEach {
options.encoding = 'UTF-8'
}
java {
sourceCompatibility = '8'
targetCompatibility = '8'
}
//仓库配置
repositories {
//本地
mavenLocal()
//阿里仓库
maven { url 'https://maven.aliyun.com/repository/public/' }
//公司仓库。必须用:https。Gradle默认情况下不允许使用不安全的协议,以提高安全性。
maven { url 'https://******:****/repository/maven-public/' }
//中央仓库
mavenCentral()
}
}
//subprojects:所有子模块生效——springboot配置、导包版本管理、打包管理
subprojects {
apply plugin: 'java'
apply plugin: 'java-library'
apply plugin: 'idea'
//所有子模块都是springboot项目,如不是,不能打包。
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management'
//所有子模块的-依赖版本管理
dependencyManagement {
dependencies {
dependency 'cn.hutool:hutool-all:5.0.7'
dependency "org.apache.commons:commons-lang3:3.5"
}
}
//使用 gradle打包工具
jar {
manifest.attributes provider: 'gradle'
}
tasks.named('test') {
useJUnitPlatform()
}
}
// 配置gradle的版本
wrapper {
//gradle的版本
gradleVersion = '8.4'
//版本类型:BIN、ALL(完全版,可以看gradle的代码)
distributionType = 'ALL'
}
①、settings.gradle
配置模块间的关系
可以新增一个模块配置一个模块,不用一次性配置完成
具体配置
rootProject.name = 'GradleMultiModule'
//公共模块总模块
include 'GradleParent'
include ':GradleParent:GradleCommon'
include ':GradleParent:GradleUtil'
project(':GradleParent:GradleCommon')?.name = 'GradleCommon'
project(':GradleParent:GradleUtil')?.name = 'GradleUtil'
//业务模块总模块
include 'GradleServer'
include ':GradleServer:GradleStart'
include ':GradleServer:GradleOne'
include ':GradleServer:GradleTwo'
project(':GradleServer:GradleStart')?.name = 'GradleStart'
project(':GradleServer:GradleOne')?.name = 'GradleOne'
project(':GradleServer:GradleTwo')?.name = 'GradleTwo'
3.2、GradleParent模块(公共)
统一公共模块依赖
build.gradle
//配置所有子模块
subprojects {
//这里可以导入公共的依赖
dependencies {
// compileOnly:这样做可以确保Lombok在编译时可用,但不会包含在最终的构建产物中,从而减小构建产物的大小。
// api:依赖可以传递给子模块
// compileOnlyApi:仅编译时可用,不包含在构建产物中,并且可以传递给子模块
compileOnlyApi 'org.projectlombok:lombok'
// 表示将Lombok库作为注解处理器导入。
annotationProcessor 'org.projectlombok:lombok'
}
}
3.3、GradleCommon模块(公共)
公共模块,存放Entity
build.gradle
dependencies {
// api可以传递依赖、implementation不能传递依赖
// hutool工具类
api 'cn.hutool:hutool-all'
}
新建的类

3.4、GradleUtil模块(公共)
存放所有工具类
build.gradle
dependencies {
// api可以传递依赖、implementation不能传递依赖
api 'org.apache.commons:commons-lang3'
}
新建类

3.5、GradleServer模块(业务)
业务模块的父模块,用于统一导入springboot的包
build.gradle
// 子模块生效
subprojects {
//配置子模块依赖
dependencies {
//导入业务模块的公共包 - SpringBoot的包
//不用api,不用传递
implementation 'org.springframework.boot:spring-boot-starter'
implementation 'org.springframework.boot:spring-boot-starter-web'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
}
3.6、GradleOne模块(业务)
引入:GradleCommon、GradleUtil模块
测试是否能使用引入模块的类、引入模块的依赖
build.gradle
dependencies {
//依赖公共模块
//api传递给子模块
api project(":GradleParent:GradleCommon")
api project(":GradleParent:GradleUtil")
}
启动提示

测试

3.7、GradleTwo模块(业务)
引入:GradleCommon、GradleUtil模块
测试是否能使用引入模块的类、引入模块的依赖
build.gradle
dependencies {
//依赖公共模块:implementation不传递依赖;api传递依赖
//这里不传递依赖,因为会造成GradleStart有多个重复依赖
implementation project(":GradleParent:GradleCommon")
implementation project(":GradleParent:GradleUtil")
}
启动提示

测试

3.8、GradleStart启动模块(业务)
启动springboot项目
引入所有业务模块
配置SpringMVc
此模块不写任何的业务
build.gradle
dependencies {
// 依赖GradleOne、GradleTwo,将该模块纳入启动中(加入springboot项目中)
api project(':GradleServer:GradleOne')
api project(':GradleServer:GradleTwo')
// 其他依赖项...
}
- SpringMvc配置
package com.cc.go.config;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import javax.annotation.Resource;
import java.util.ArrayList;
/** <p>SpringMvc配置<p>
* <li>自定义Spring MVC的特性和扩展Spring MVC的功能</li>
* @since 2023/9/21
* @author CC
**/
@SpringBootConfiguration
public class WebGlobalConfig implements WebMvcConfigurer {
@Resource
private MyHandlerInterceptor myHandlerInterceptor;
/**
* 拦截器(Interceptors)
*/
@Override
public void addInterceptors(InterceptorRegistry registry) {
ArrayList<String> list = new ArrayList<>();
list.add("/login");
//自定义拦截器,或其他拦截器
registry.addInterceptor(myHandlerInterceptor)
//添加拦截地址为所有拦截
.addPathPatterns("/**")
//不拦截的地址
.excludePathPatterns(list);
}
/**
* 资源处理器(Resource Handlers)
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/**")
.addResourceLocations("classpath:/resources/","classpath:/static/");
}
/**
* 跨域资源共享(CORS)
*/
@Bean
public CorsFilter corsFilter() {
//创建CorsConfiguration对象后添加配置
CorsConfiguration config = new CorsConfiguration();
//允许所有原始域
config.addAllowedOriginPattern("*");
//允许所有头部信息
config.addAllowedHeader("*");
//允许所有头部信息
config.addExposedHeader("*");
//放行的请求方式
// config.addAllowedMethod("GET");
// config.addAllowedMethod("PUT");
// config.addAllowedMethod("POST");
// config.addAllowedMethod("DELETE");
config.addAllowedMethod("*"); //放行全部请求
//是否发送Cookie
config.setAllowCredentials(true);
//2. 添加映射路径
UrlBasedCorsConfigurationSource corsConfigurationSource =
new UrlBasedCorsConfigurationSource();
corsConfigurationSource.registerCorsConfiguration("/**", config);
//返回CorsFilter
return new CorsFilter(corsConfigurationSource);
}
}
- 启动类
package com.cc.go;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/** <p>启动类<p>
* @since 2023/9/20
* @author CC
**/
@SpringBootApplication
public class GradleStartApplication {
public static void main(String[] args) {
SpringApplication.run(GradleStartApplication.class, args);
}
}
- application.yml
server:
port: 2222
三、测试
1、传递依赖测试,在二实现中,已经验证了,能引入依赖
2、启动测试,测试业务模块的接口调用
启动项目,模块启动

接口调用

调用后打印的

四、总结
- 项目地址(blog-code/SpringBoot/GradleMultiModule)
https://gitee.com/KakarottoChen/blog-code.git
Gradle8.4构建SpringBoot多模块项目的更多相关文章
- 使用IDEA构建Spring-boot多模块项目配置流程
使用IDEA构建Spring-boot多模块项目配置流程 1.创建项目 点击Create New Project 在左侧选中Spring Initializer,保持默认配置,点击下一步. 在Grou ...
- Java秒杀系统实战系列~构建SpringBoot多模块项目
摘要:本篇博文是“Java秒杀系统实战系列文章”的第二篇,主要分享介绍如何采用IDEA,基于SpringBoot+SpringMVC+Mybatis+分布式中间件构建一个多模块的项目,即“秒杀系统”! ...
- 使用Gradle构建springboot多模块项目,并混合groovy开发
idea设置本地gradle 打包: build.gradle //声明gradle脚本自身需要使用的资源,优先执行 buildscript { ext { springBootVersion = ' ...
- SpringBoot多模块项目打包问题
项目结构图如下: 在SpringBoot多模块项目打包时遇见如下错误: 1.repackage failed: Unable to find main class -> [Help 1] 解决步 ...
- Jenkins构建Maven多模块项目时,单独编译子模块,并且不触发构建其它模块
一.Jenkins构建Maven多模块项目时,单独编译子模块 配置: 1.Root POM指向父pom.xml 2.Goals and options指定构建模块的参数:mvn -pl jsoft-w ...
- 2017-09-26 发布 SpringBoot多模块项目实践(Multi-Module)
https://segmentfault.com/a/1190000011367492?utm_source=tag-newest 2017-09-26 发布 SpringBoot多模块项目实践(Mu ...
- SSM001/构建maven多模块项目
一.Idea构建maven多模块项目 1.创建maven项目--创建父模块 [1].File->New->Module... [2].点击next,填写:GroupId,ArtifactI ...
- 记Spring搭建功能完整的个人博客「Oyster」全过程[其二] Idea中Maven+SpringBoot多模块项目开发的设计和各种坑(模块间依赖和打包问题)
大家好嘞,今天闲着没事干开写写博客,记录一下Maven+SpringBoot的多模块设计和遇到的坑. 多模块设计 简单说明一下截止目前的需求: 需要RESTful API:对文章.标签.分类和评论等的 ...
- docker部署 springboot 多模块项目+vue
之前学习了docker,今天就来试试将这个项目打包成docker镜像并通过运行一个镜像来运行项目.这里使用的项目是el-admin.是一个开源的springboot后端管理框架(前端vue),有兴趣的 ...
- springboot 多模块项目创建
1.File>new>project 直接点击next 2.输入groupId .artifactId 3.选择项目保存路劲 finish 4.成功创建多模块项目的根模块 5.创建子 ...
随机推荐
- clickhouse在各大厂商的应用
案例-ClickHouse在头条的技术演进
- Java Agent技术
在定位公司问题的时候,需要了解一下skywalking的相关知识,而agent就提上了日程. 官网文档 Agent技术是Jdk在1.5版本之后,所提供的一个在jvm启动前后对部分java类代理加强的机 ...
- 论文阅读小结(B/S和C/S结构)
论文阅读小结 一.B/S 和 C/S 软件体系结构选择 1) C/S . B/S 结构概述 C/S 结构,即 Client/Server (客户机 / 服务器 ), C/S 结构软件分为客户机和服务器 ...
- 企业数据清洗项目实践day1
今天先把国标excel表的数据在Python里转化成了字典类型, 暂时定共分为四层,层层分类. 代码 1 def std_excel(): 2 dict={"A":{"0 ...
- 理解持续测试,才算理解DevOps
软件产品的成功与否,在很大程度上取决于对市场需求的及时把控,采用DevOps可以加快产品交付速度,改善用户体验,从而有助于保持领先于竞争对手的优势. 作为敏捷开发方法论的一种扩展,DevOps强调开发 ...
- .net 发邮件的小工具,包含json,环境变量,命令行参数三种配置方式
一.业务需求 在工作中遇到一个场景,软件bug或功能发布之后,会通知测试进行测试,要求写一个小工具能自动发送邮件,功能包含发送和抄送支持多个,因为只是通知没有写进附件功能,这个其他博客都有搜一下就可以 ...
- 使用PTK卸载数据库时删除用户失败怎么办?
使用 PTK 卸载数据库时删除用户失败怎么办? 背景介绍: PTK (Provisioning Toolkit)是一款针对 MogDB 数据库开发的软件安装和运维工具,旨在帮助用户更便捷地安装部署 M ...
- mybatis plugin源码解析
概述 Plugin,意为插件,是mybatis为开发者提供的,对方法进行自定义编程的手段.其中用到了动态代理.反射方法,通过指定需要增强的对象与方法,进行程序编写. 核心类 主要涉及几个核心类:Int ...
- Linux系统中查找文件的方法
-name 必须用到的选项.表明要求系统按照文件名查找. 一般格式:find /(dirname) -name filename 具体文件名查找法: 如果知道了某个文件的文件名,而不知道这个文件放到哪 ...
- nginx重新整理——————http请求的11个阶段[十二]
前言 已经到了关键的http请求的11个阶段了. 正文 概念图: 11 个阶段的处理顺序: 那么就来介绍一下: 先来了解一下postread阶段的realip这个处理,realip 是 real ip ...