spring boot3.x快速入门

下一篇:Spring Boot 3.x gradle脚手架工程build.gradle详解

本教程将基于gradle项目构建工具来快速构建一个spring boot 3.x的最简单的web应用,其中涉及各种构建技巧和细节,希望能帮到初学者~

文章目录

先决条件

JDK17

参考:JDK17安装与配置

gradle全局配置

参考:gradle全局配置

gradle项目构建工具

相比传统项目构建工具mavengradle提供了更加简洁且高效的配置方式,在大中型spring微服务项目中得到广泛的使用。在搭建spring boot项目时,spring官方提供的初始化器也推荐使用gradle。一起来看下gradle在本地项目构建所充当的角色吧。

创建spring boot工程

新建一个项目,选择spring初始化器来创建:

位置:E:\juan\springboot\code\001_spring_boot项目搭建\demo

这里我们添加了几个基本的依赖项:

  • Spring Boot DevTools

    提供了spring boot服务重启和热加载的开发环境动态更新代码和配置的能力

  • Lombok

    简化了开发中对POJO相关代码生成以及日志框架使用时提供隐式日志对象的能力

  • Spring Configuration Processor

    提供了根据@ConfigurationProperties注解生成配置元数据的能力,比如在我们使用.yml配置文件以及做一些自定义配置时,这个依赖项是必须的。

  • Spring Web

    用于spring mvc的开发

点创建,项目构建时,如果wrapper方式管理的Gradle软件下载很慢,或者连不上,出现下面情况:

可以修改下,gradle-wrapper.properties

properties 复制代码
#distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip
distributionUrl=https\://mirrors.cloud.tencent.com/gradle/gradle-8.7-bin.zip

改完后,刷新下gradle。

项目构建成功!

熟悉项目结构和构建方式

项目结构

项目的配置

软件环境的配置由idea集成开发环境以及gradle的wrapper管家帮我们自动完成了。可以看下完成了哪些设置:

  • 全局使用的jdk

  • gradle软件设置

  • Java编译器

开发Hello API

java 复制代码
package com.juan.demo;

import ...

// 为简化api开发,索性在启动类上启用rest控制器
@RestController
...
public class DemoApplication {

    @RequestMapping("hello")
    public String hello() {
        return "hello boot3!";
    }

    ...

}

单元测试

java 复制代码
package com.juan.demo;

import ...

import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;

@SpringBootTest
// 启用mockMvc自动配置
@AutoConfigureMockMvc
class DemoApplicationTests {

    ...

    @SneakyThrows
    @Test
    void hello(@Autowired MockMvc mvc) {
        mvc.perform(get("/hello")).andExpect(status().isOk()).andExpect(content().string("hello boot3!"));
    }

}

build.gradle中调整依赖

groovy 复制代码
configurations {
    ...
    // 实现依赖范围配置的局部扩展    
    testCompileOnly {
        extendsFrom testAnnotationProcessor
    }
}

...

dependencies {
    ...
    annotationProcessor 'org.projectlombok:lombok'
    // 为单元测试环境引入和启用lombok编译功能
    testAnnotationProcessor 'org.projectlombok:lombok'
    ...
}

修改好后,在当前编辑的build.gradle文件右上角会显式一个gradle的小象图标,点击以刷新gradle设置

服务启动与测试

idea会智能的识别项目的启用类,并添加spring boot快捷启动项,当然我们也可以在该界面中点Modify options来设置更多的可选项,比如添加jvm启用的参数等等。

启动本地web服务

idea提供的http client测试工具进行rest api的测试:

执行单元测试,可以先调整下编译和测试环境由gradle任务构建方式,改为IntelliJ Idea构建方式:

同时,开启注解处理器功能:

运行单元测试:

gradle打包和运行项目

通过命令方式来构建:

shell 复制代码
./gradlew clean build -x test

或者使用gradle插件提供的命令行:

或者直接双击执行构建目标任务:

运行项目的方式

创建jar-application的启动项

启动jar-application服务,并用http client工具测试hello api

还可以使用gradle的JavaExec基础任务,编写一个runBootJar

build.gradle

groovy 复制代码
tasks.register('runBootJar', JavaExec) {
    classpath = files('build/libs/demo-0.0.1-SNAPSHOT.jar')
}
相关推荐
kfaino31 分钟前
码农的AI翻身(六)你好,我叫 Parameter
后端·aigc
掘金者阿豪33 分钟前
把业务数据变成共享仪表盘:Metabase可视化与远程访问实践
前端·后端
猪猪拆迁队2 小时前
虚拟工厂仿真引擎的架构设计:让一条产线可编程、可观测、可干预
后端·ai编程
字节跳动数据库2 小时前
文章分享——相似函数处理方法
人工智能·后端·程序员
云技纵横2 小时前
@Transactional 失效的 7 种场景:第 5 种最难排查
后端
用户6757049885022 小时前
你知道 Go 结构体和结构体指针调用的区别吗?一文带你彻底搞懂!
后端·go
程序员cxuan3 小时前
读懂 Claude Code 架构分析系列,第一篇,开始!
人工智能·后端·架构
用户6757049885023 小时前
面试官问“装饰器模式”,这样回答薪资多要 3000!
后端
tntxia3 小时前
Geo Scene域名修改引起的一些问题
后端
用户298698530143 小时前
Java 实现 Word 文档加密与权限解除
java·后端