1 概述

Gradle由于构建速度比Maven快,且比Maven灵活,因此很多后端的应用都使用了Gradle进行构建,但一个问题是,Gradle的多模块项目比较难构建,再加上Gradle的更新非常快,这就给构建一个多模块Gradle项目造成了不少的困难。

基于此出发点,本文提供了两种形式的使用Gradle构建的Spring Boot多模块项目:

  • Java + Gradle
  • Kotlin + Gradle + Kotlin DSL

为了减少出现各种错误的概率,步骤做得非常详细(多图预警),文末也附上了源码,下面就一起来看看吧。

2 环境

  • Gradle 6.8.2
  • Spring Boot 2.4.3
  • Kotlin 1.4.30
  • Open JDK 11

3 Java + Gradle

主要步骤:

  • 使用Spring Initializer创建项目
  • 修改build.gradle
  • 创建模块
  • 编写模块
  • 运行
  • 测试

3.1 创建项目

直接使用IDEA提供的Spring Initializer即可,构建工具选择Gradle

依赖:

构建完成后删除src目录,因为根目录属于管理模块目录不提供运行的应用:

3.2 修改build.gradle

这是最复杂的一步,并且Gradle版本更新的话步骤可能会不一样,首先在底部添加一个空的subprojects

接着dependencies以及test移动进去

最后一步是,subprojects开头,添加插件apply,根据默认初始化创建的plugins,逐一添加

比如这里默认使用了三个插件:

applysubprojects中:

3.3 创建模块

File -> New -> Module

输入模块名即可,这里的例子是创建两个模块:

  • service
  • app

创建好后如图所示:

完成创建之后,把两个模块中的build.gradle除了repositories之外的全部删去,仅保留repositories

3.4 编写模块

3.4.1 service模块

首先创建包,根据根目录中的group创建:

接着编写一个叫TestService的带@Service注解的类,里面包含一个test方法:

同时修改service模块的build.gradle添加bootJar以及jar选项

bootJar{
enabled = false
} jar{
enabled = true
}

3.4.2 app模块

同样先根据根目录的group创建包

接着在app模块的build.gradle添加service模块的依赖

再创建启动类以及一个Controller

代码如下:

package com.example;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args);
}
}
package com.example.controller;

import com.example.service.TestService;
import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
@RequiredArgsConstructor(onConstructor = @__(@Autowired))
public class TestController {
private final TestService service;
@GetMapping("/test")
public String test(){
return service.test();
}
}

3.5 运行

接下来就可以运行了,可以直接点击Application旁边的绿色小三角:

或者从运行配置中选择Application运行(IDEA自动创建的,原来的那个DemoApplication带一个×是因为启动文件已经删除了,可以顺便把该配置删除):

没问题的话就可以成功运行了:

同时浏览器访问localhost:8080/test会出现test字样:

3.6 测试

在创建测试类之前,也需要先创建包,且需要确保包名与启动类的包名一致

再创建测试类:

package com.example;

import com.example.service.TestService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest; @SpringBootTest
public class JavaTest {
@Autowired
private TestService service;
@Test
public void test(){
System.out.println(service.test());
}
}

接着进行测试:

这样使用Java+Gradle构建一个多模块的Spring Boot项目就成功了。

4 Kotlin + Gradle + Kotlin DSL

Kotlin DSL在原生GradleGroovy DSL)的基础上进行改进,但同时语法也变得更加陌生,难度因此也加大了不少,不过这并没有难倒笔者。构建多模块的基本步骤与上面类似:

  • 使用Spring Initializer创建项目
  • 修改build.gradle.kts
  • 创建模块
  • 编写模块
  • 运行
  • 测试

4.1 创建项目

选择Kotlin+Gradle

依赖:

同样删除src

4.2 修改build.gradle.kts

同样在尾部添加一个空的subprojects

dependencies以及tasks移动进去

最后subprojects开始处apply插件根据默认的插件进行apply

代码如下:

apply{
plugin("io.spring.dependency-management")
plugin("org.springframework.boot")
plugin("org.jetbrains.kotlin.plugin.spring")
plugin("org.jetbrains.kotlin.jvm")
}

plugins中的kotlinorg.jetbrains.kotlin的简写,在subprjects中注意加上即可。

4.3 创建模块

File -> New -> Module,把一些必要选项勾选上:

这里同样创建两个模块:

  • app
  • service

同样把两个模块中的build.gradle.kts删除其他部分留下repositories

4.4 编写模块

4.4.1 service模块

首先根据根目录的build.gradle.kts创建包

编写TestService

最后修改build.gradle.kts加上tasks.bootJartasks.jar

tasks.bootJar{
enabled = false
} tasks.jar{
enabled = true
}

4.4.2 app模块

创建包

添加对service模块的依赖

再创建一个启动类以及一个Controller

代码如下:

package com.example

import org.springframework.boot.SpringApplication
import org.springframework.boot.autoconfigure.SpringBootApplication @SpringBootApplication
class Application fun main(args:Array<String>) {
SpringApplication.run(Application::class.java,*args)
}
package com.example.controller

import com.example.service.TestService
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.web.bind.annotation.GetMapping
import org.springframework.web.bind.annotation.RestController @RestController
class TestController {
@Autowired
lateinit var service: TestService
@GetMapping("/test")
fun test() = service.test()
}

4.5 运行

点击main旁边的绿色小三角即可:

运行成功:

同样可以访问localhost:8080/test

4.6 测试

注意在编写测试之前需要保证测试类与启动类在同一个包下,也就是需要先创建包

再创建测试类:

package com.example

import com.example.service.TestService
import org.junit.jupiter.api.Test
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.context.SpringBootTest @SpringBootTest
class KotlinTest {
@Autowired
lateinit var service: TestService
@Test
fun test(){
println(service.test())
}
}

直接点击小三角测试即可:

测试通过,这样Kotlin+Gradle+Kotlin DSL的多模块Spring Boot项目就算创建完成了。

5 总结

笔者在实践的过程中也遇到了无数的错误,比如找不到类,或者build.gradle/build.gradle.kts文件错误,幸好有万能的搜索引擎,帮笔者解决了错误,最后才成功写下这篇文章。

总的来说,Gradle创建多模块项目要比Maven要难,而且Gradle的更新速度很快,语法变化较大,相比之下Maven非常稳定,最新的Maven 3.6.3还是19年11月发布的,然而Gradle都准备7.0了:

笔者建议,如果是真的需要使用Gradle,需要考虑一下团队的状况,毕竟上手难度要大于Maven,如果在Gradle创建多模块的过程中遇到一些极其难以解决的问题,转为Maven不失为一个好办法。

6 源码

附上两个例子的源码:

SpringBoot+Gradle构建多模块项目的更多相关文章

  1. IDEA中使用springBoot+gradle构建多模块项目

    https://blog.csdn.net/forMelo/article/details/78995875

  2. Gradle构建多模块项目(转)

    废话不多说,直接进入主题. 1. 创建项目 首先创建项目,名称为 test: mkdir test && cd test gradle init 这时候的项目结构如下: ➜ test ...

  3. Gradle构建多模块项目

    通常我在使用Maven构建项目的时候是将应用项目划分为多个更小的模块. Gradle 项目也拥有多于一个组件,我们也将其称之为多项目构建(multi-project build). 我们首先创建一个多 ...

  4. 【转载】Gradle构建多模块项目

    本文转载自:https://yq.aliyun.com/articles/25589写的非常好! 改动如下: 1. 增加了一些[补充说明]. 2. 将执行命令使用较为显眼的博客园样式. 3. 将输出结 ...

  5. Eclipse Gradle 构建多模块项目

    注意: 1.Eclipse不如IDEA智能,Eclipse建立的Gradle Project项目在目录级别上是同级的; 2.user-web模块如果要引用user-service模块,直接引用是找不到 ...

  6. 使用Gradle构建多模块SpringBoot项目

    使用Gradle构建多模块SpringBoot项目 本项目使用Gradle构建SpringBoot项目,将不同的业务进行不同的模块划分(不做微服务与分布式架构); - 编辑器:Intellij IDE ...

  7. Spring-Boot构建多模块项目

    Spring-Boot构建多模块项目 功能模块单独项目开发,可以将一个庞大的项目分解成多个小项目,便于细分开发 Maven多模块项目不能独立存在,必须有一个介质来包含. 1.创建一个Maven 项目, ...

  8. 基于SpringBoot构建分模块项目

    前言 步骤过于详细,多图慎入!!! 假设一个场景,要开发一个4s店维修部的办公系统,其功能有:前台接待,维修抢单,财务结算,库存管理.于是我们创建一个项目balabalabala写完交工. 一段时间后 ...

  9. 用Gradle构建Spring Boot项目

    相比起Maven的XML配置方式,Gradle提供了一套简明的DSL用于构建Java项目,使我们就像编写程序一样编写项目构建脚本.本文将从无到有创建一个用Gradle构建的Spring Boot项目, ...

随机推荐

  1. 死磕Spring之IoC篇 - BeanDefinition 的解析阶段(XML 文件)

    该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读 Spring 版本:5.1. ...

  2. 无所不能的Embedding7 - 探索通用文本表达[FastSent/InferSent/GenSen/USE]

    在4/5章我们讨论过用skip-thought,quick-thought任务来进行通用文本向量提取,当时就有一个疑问为什么用Bookcorpus这种连续文本,通过预测前一个和后一个句子的方式得到的文 ...

  3. 第29天学习打卡(迭代器、泛型 、Collection工具类、set集合的特点及应用、Map集合的特点及应用)

    迭代器 对过程的重复,称为迭代. 迭代器是遍历Collection集合的通用方式,可以在对集合遍历的同时进行添加.删除等操作. 迭代器的常用方法 next():返回迭代的下一个元素对象 hasNext ...

  4. python爬虫登录保持及对http总结

    [前言]这几天一直看python爬虫登录保持.实现接口太多,太乱,新手难免云山雾罩.各种get.post,深入理解一下,其实就是由于http的特性需要这些操作.http是一种无状态.不保存上次通信结果 ...

  5. C# 处理PPT水印(三)—— 在PPT中添加多行(平铺)文本水印效果

    在PPT幻灯片中,可通过添加形状的方式,来实现类似水印的效果,可添加单一文本水印效果,即幻灯片中只有一个文本水印:也可以添加多行(平铺)文本水印效果,即幻灯片中以一定方式平铺排列多个文本水印效果.本文 ...

  6. iOS 14.5 有啥新功能?Apple Watch 也能解锁 iPhone 了

    转: iOS 14.5 有啥新功能?Apple Watch 也能解锁 iPhone 了 苹果今天发布了即将发布的 iOS 14.5 和 iPadOS 14.5 更新的第一个 Beta 版本,我们在其中 ...

  7. Java实现贪吃蛇

    游戏界面基本布局 贪吃蛇是基于JFrame的一款小游戏.它主要有两部分组成,一个是显示区域,一个是按钮区域.这两个区域都用JPanel来实现. 首先需要创建一个基于JFrame的类,例如创建一个MyF ...

  8. 剑指 Offer 10- II. 青蛙跳台阶问题

    剑指 Offer 10- II. 青蛙跳台阶问题 Offer 10- II 题目描述: 动态规划方程: 循环求余: 复杂度分析: package com.walegarrett.offer; impo ...

  9. SpringMVC-01 什么是SpringMVC

    SpringMVC-01 什么是SpringMVC 回顾MVC 1.什么是MVC MVC是模型(Model).视图(View).控制器(Controller)的简写,是一种软件设计规范. 是将业务逻辑 ...

  10. webstorm2020.3安装破解教程

    免责声明:本教程及相关附件仅限于学术交流,不能用于商业以及违法用途,请于下载后24小时内删除!如产生法律纠纷,一切与本人无关,呼吁各位小伙伴支持下正版软件.本文如有侵权,请联系小编删除之. 该操作是用 ...