一、Spring Initializer 快速创建 SpringBoot 项目
Spring Initializer 是 Spring 官方提供的项目初始化工具,也是企业、教学中标准、最快的SpringBoot项目搭建方式,无需手动建包、写配置、引依赖,一键生成可运行完整项目。
1.1 两种创建方式
方式1:在线官网创建(通用所有开发工具)
访问 Spring 官方初始化地址,按需配置参数、选择依赖,一键下载项目压缩包,导入IDEA即可使用。
方式2:IDEA内置Initializer创建(主流首选)
新版IDEA已内置Spring Initializer,无需访问网页,直接本地可视化创建,支持实时选择版本、依赖,是目前开发、教学通用方式。
1.2 标准创建流程(零基础复刻)
-
打开IDEA,选择 New Project - Spring Initializr(新版为Spring boot);
-
配置项目基础信息:Group、Artifact、Java版本(SpringBoot3.x 强制JDK17+);
-
选择 SpringBoot 版本:3.3.x 长期支持版(稳定企业版);
-
勾选所需依赖:日常开发首选 Spring Web(Web开发必备,如果是父类项目可以不选)、Configuration Processor(配置绑定提示);
-
点击创建,IDEA自动联网生成完整项目,包含启动类、配置文件、标准目录结构。
1.3 初始化项目标准目录结构(核心必懂)
Initializer 自动生成规范目录,每个文件夹作用固定,遵循SpringBoot约定大于配置核心思想:
-
src/main/java:业务代码存放目录,自动生成项目启动主类
-
src/main/resources:核心资源与配置目录
-
static:存放静态资源(js、css、图片等)
-
templates:存放模板页面(配合thymeleaf、freemarker模板引擎,SpringBoot默认不支持JSP)
-
application.yml / application.properties:SpringBoot全局核心配置文件,修改框架默认配置、自定义业务参数
-
-
pom.xml:自动管理依赖版本,无需手动适配版本冲突
1.4 自定义 SpringApplication 启动配置
Initializer 生成的默认启动规则可自定义改造,通过原生API修改启动横幅、运行参数等,支持两种写法:
常规写法:
public static void main(String[] args) {
SpringApplication app = new SpringApplication(DemoApplication.class);
// 关闭启动横幅
app.setBannerMode(Banner.Mode.OFF);
app.run(args);
}
流式构造写法(简洁优雅):
new SpringApplicationBuilder()
.bannerMode(Banner.Mode.OFF)
.run(args);
二、SpringBoot 核心配置文件详解
通过 Initializer 创建的项目会自动生成全局配置文件,配置文件的核心作用:覆盖SpringBoot自动配置的默认值,自定义项目运行参数,是连接开发者与自动配置的核心桥梁。
2.1 两种配置文件格式
SpringBoot 支持两种全局配置文件,文件名固定、优先级版本适配新版规范:
-
application.properties:扁平 key-value 格式,结构简单,可读性差,老旧项目常用
-
application.yml / application.yaml:树形层级格式,简洁直观、可读性强
格式对比实战
properties 写法:
server.port=8088
server.servlet.context-path=/demo
yml 写法(层级对应,更贴合代码结构):
server:
port: 8088
servlet:
context-path: /demo
yml语法硬性规范 :冒号后必须加空格、靠缩进控制层级、大小写敏感,特殊字符需单引号包裹,语法错误直接导致项目启动失败。官方建议:全程统一一种配置格式,避免版本优先级混乱。
2.2 yml全类型语法大全
支持所有日常配置类型,新手可直接复用:
# 1.字面量(字符串、数字、布尔)
name: springboot3
age: 20
isOpen: true
# 2.对象/Map配置
user:
username: admin
password: 123456
# 3.数组/List配置
hobby:
- 编程
- 学习
- 运动
# 行内精简写法
map: {k1: v1, k2: v2}
list: [a,b,c]
2.3 配置文件占位符高级用法
支持随机数生成、配置引用、默认值兜底,适配动态配置场景:
# 随机参数
random:
uuid: ${random.uuid}
num: ${random.int(10,100)}
# 配置引用+默认值
person:
name: 测试用户${random.uuid}
desc: ${person.info:默认描述信息}
三、配置文件加载优先级与多环境Profile
3.1 配置文件全局加载顺序
SpringBoot 启动时会自动扫描4个位置的配置文件,遵循高优先级覆盖低优先级、互补配置原则,优先级从低到高:
-
项目内部 resources 根目录
-
项目内部 resources/config 目录
-
项目根目录外部配置
-
项目根目录 config 外部配置
最终最高优先级:命令行参数、系统环境变量、自定义外部配置,可覆盖所有文件配置。
3.2 多环境Profile配置(dev/test/prod)
开发、测试、生产环境参数不同,通过Profile实现环境隔离,命名规范固定:application-{环境}.yml
-
application-dev.yml:开发环境配置
-
application-test.yml:测试环境配置
-
application-prod.yml:生产环境配置
环境激活两种方式
1、配置文件激活(开发常用):
spring:
profiles:
active: dev
2、命令行激活(生产部署常用):
java -jar demo.jar --spring.profiles.active=prod
四、配置文件值注入Bean(两种核心方式)
将配置文件参数绑定到Java实体类,实现配置与代码解耦,是项目实例创建的基础。
4.1 @Value(单值零散注入)
适合少量参数获取,支持SpEL表达式运算:
@Component
public class ConfigDemo {
@Value("${person.name}")
private String name;
@Value("#{10*2}")
private Integer num;
}
4.2 @ConfigurationProperties(批量绑定,企业首选)
适合批量绑定对象、集合,支持松散绑定、配置提示、参数校验,是类继承实例创建的核心注解。
需先导入配置处理器依赖(Initializer可直接勾选):
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
4.3 两种注入方式核心区别
| 对比项 | @Value | @ConfigurationProperties |
|---|---|---|
| 注入方式 | 单个逐一注入 | 批量前缀绑定 |
| 松散绑定 | 不支持 | 支持(userName / user-name / user_name 通用) |
| SpEL表达式 | 支持 | 不支持 |
| 适用场景 | 少量零散参数 | 批量业务配置、实例绑定 |
五、基于类继承的项目实例创建(核心实战)
依托上述配置绑定能力,SpringBoot支持父类通用模板 + 子类差异化扩展的继承式实例创建,彻底解决多模块配置代码冗余问题,是企业标准化开发核心用法。
5.1 核心原理
-
公共父类:封装所有业务通用配置、校验规则,仅作为模板,不交给Spring托管
-
业务子类:继承父类,自动复用通用属性,扩展独有业务字段,绑定配置文件,Spring自动创建完整Bean实例
5.2 完整实战流程
步骤1:定义通用配置父类
import jakarta.validation.constraints.Max;
import jakarta.validation.constraints.Min;
// 公共配置父类:所有业务子类继承复用
public class BaseServiceConfig {
// 通用属性
private String name;
@Min(1000)
@Max(10000)
private Integer timeout;
private Boolean enableLog;
// 通用get/set
public String getName() { return name; }
public void setName(String name) { this.name = name; }
public Integer getTimeout() { return timeout; }
public void setTimeout(Integer timeout) { this.timeout = timeout; }
public Boolean getEnableLog() { return enableLog; }
public void setEnableLog(Boolean enableLog) { this.enableLog = enableLog; }
}
步骤2:定义业务子类(继承扩展)
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.validation.annotation.Validated;
import org.springframework.stereotype.Component;
// 订单业务配置子类,继承通用父类
@Component
@ConfigurationProperties(prefix = "business.order")
@Validated
public class OrderServiceConfig extends BaseServiceConfig {
// 子类独有属性
private Integer maxRetry;
private String orderPrefix;
public Integer getMaxRetry() { return maxRetry; }
public void setMaxRetry(Integer maxRetry) { this.maxRetry = maxRetry; }
public String getOrderPrefix() { return orderPrefix; }
public void setOrderPrefix(String orderPrefix) { this.orderPrefix = orderPrefix; }
}
步骤3:配置文件绑定参数
business:
order:
# 继承父类通用属性
name: 订单业务服务
timeout: 4000
enable-log: true
# 子类独有属性
max-retry: 3
order-prefix: ORDER_
步骤4:注入使用继承实例
import org.springframework.stereotype.Service;
@Service
public class OrderBusinessService {
// 直接注入完整继承实例
private final OrderServiceConfig orderConfig;
public OrderBusinessService(OrderServiceConfig orderConfig) {
this.orderConfig = orderConfig;
}
public void printConfig() {
// 父类继承属性
System.out.println("服务名称:" + orderConfig.getName());
// 子类独有属性
System.out.println("订单前缀:" + orderConfig.getOrderPrefix());
}
}
5.3 核心优势与规范
-
代码极致复用,多模块无需重复编写通用配置
-
父类统一校验规则,全局配置规范统一
-
子类独立绑定配置前缀,实例互不冲突、差异化灵活
六、基于 Maven Parent 父工程继承创建多模块项目(工程级继承)
前面第五章讲解的是代码类级别的继承 (Java子类继承父类实现配置复用),本章重点讲解企业真实多模块架构:Maven 工程级继承。
在 SpringBoot 微服务/多模块项目中,通过 pom.xml 的 <parent> 标签引入统一父工程,让所有子模块继承父工程的版本管理、依赖、插件、统一配置,实现一键标准化创建多子项目,是企业项目规范搭建的核心标准方式。
6.1 核心概念:Parent 父工程继承
Maven 继承分为两层核心逻辑,也是 SpringBoot 项目的底层构建基础:
-
SpringBoot 官方父工程 :所有 SpringBoot 项目默认继承
spring-boot-starter-parent,统一框架依赖版本、编译插件、默认编码、打包规则 -
自定义项目父工程:企业自建 Parent 工程,所有业务子模块继承该工程,统一项目内部依赖版本、公共依赖、自定义属性、环境配置
核心作用:父工程统一管控,子模块零配置继承,快速批量创建规范子项目,彻底解决版本混乱、依赖冗余问题。
6.2 工程继承整体架构
标准三层继承架构(企业通用):
-
第一层:SpringBoot 官方父工程:提供框架底层统一版本管控
-
第二层:自定义项目 Parent 父工程:继承官方父工程,定义项目全局统一依赖、版本、插件、属性
-
第三层:业务子模块:用户模块、订单模块、支付模块等,通过 <parent> 继承自定义父工程,无需重复配置
6.3 实战:通过 <parent> 实现项目继承创建多模块
本实战基于 Spring Initializer 创建的标准项目改造,从零实现父工程 + 多个子模块的继承架构。
步骤1:创建自定义 Parent 父工程
首先创建一个空 Maven 工程作为项目全局父工程,打包方式必须为 pom,仅用于统一管理,无业务代码。
父工程 pom.xml 核心配置:继承 SpringBoot 官方父工程,统一全局版本与依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!-- 1、继承SpringBoot官方父工程 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.3.0</version>
<relativePath/>
</parent>
<!-- 2、当前自定义父工程坐标 -->
<groupId>com.example</groupId>
<artifactId>boot-parent</artifactId>
<version>1.0.0</version>
<name>全局父工程</name>
<description>统一项目版本与依赖管理父工程</description>
<packaging>pom</packaging>
<!-- 3、全局统一版本属性 -->
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<mybatis.version>3.0.3</mybatis.version>
</properties>
<!-- 4、统一依赖版本管理(子模块自动继承) -->
<dependencyManagement>
<dependencies>
<!-- 统一web依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 统一配置处理器依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
</dependencyManagement>
<!-- 5、统一编译、打包插件 -->
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
步骤2:创建业务子模块,通过 <parent> 继承父工程
在父工程下创建多个业务子模块(user、order、pay),所有子模块无需定义版本、无需重复引入公共依赖 ,直接通过 <parent> 继承全局配置。
子模块 pom.xml 极简配置(所有版本、公共依赖全部继承父工程):
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!-- 核心:继承自定义全局父工程 -->
<parent>
<groupId>com.example</groupId>
<artifactId>boot-parent</artifactId>
<version>1.0.0</version>
<relativePath>../pom.xml</relativePath>
</parent>
<!-- 子模块唯一标识,无需写version,自动继承父工程 -->
<artifactId>boot-user</artifactId>
<name>用户模块子项目</name>
<!-- 仅引入当前模块独有依赖,公共依赖全部继承 -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
步骤3:快速批量创建多个子模块
按照上述子模块配置,可快速创建 order订单模块、pay支付模块、log日志模块 等多个子项目:
-
所有子模块版本统一、编译环境统一、公共依赖统一
-
新增模块只需新建子工程、绑定parent继承,无需重复配置基础环境
-
父工程统一管控,全局依赖版本一键升级、统一修改
6.4 Maven Parent 工程继承核心机制
-
版本继承:子模块无需指定 version,自动继承父工程版本,全局版本统一
-
依赖继承:父工程 dependencyManagement 声明的依赖,子模块可直接引用、无需写版本
-
插件继承:编译、打包插件全局统一,所有子模块打包、编译规则一致
-
属性继承:编码格式、JDK版本、自定义变量全局统一,避免环境不一致
6.5 基于 <parent> 项目继承的优缺点
✅ 核心优点
-
版本统一,杜绝冲突:所有子模块继承父工程版本管控,彻底解决多模块依赖版本不一致、Jar包冲突问题
-
极大简化子模块配置:子项目pom极简,无需重复编写公共依赖、插件、JDK配置,开发效率大幅提升
-
全局统一规范:编码格式、编译规则、打包方式、依赖管理全局统一,项目规范性极强
-
迭代维护方便:框架升级、依赖版本更新只需修改父工程,所有子模块一键同步生效
-
快速批量建模块:新增业务模块无需搭建基础环境,继承parent即可快速成型,适配微服务多模块架构
❌ 核心缺点
-
耦合度较高 :子模块强依赖父工程,父工程配置出错、版本冲突会导致所有子项目全部报错
-
版本灵活性差:全局统一版本,若个别子模块需要特殊版本依赖,需要单独重写覆盖,配置繁琐
-
父工程维护成本高:随着项目迭代,父工程依赖越来越多,容易出现冗余依赖、无效依赖堆积
-
单继承限制 :Maven 仅支持单父继承,一个子项目只能继承一个父工程,无法实现多工程继承组合
6.6 工程继承 VS 代码类继承(核心区别)
| 继承方式 | 继承层级 | 作用范围 | 核心用途 |
|---|---|---|---|
| Maven Parent 工程继承 | Pom 工程层级 | 整个项目模块 | 统一版本、依赖、插件、环境配置,批量创建规范子项目 |
| Java 类继承 | 代码类层级 | 单个业务Bean实例 | 复用代码属性、校验规则,实现业务实例差异化扩展 |
6.7 企业开发使用规范
-
大型多模块、微服务项目:必须使用 Parent 父工程继承,统一项目基建规范
-
父工程只做版本声明与依赖管理,不引入具体业务依赖,避免依赖冗余
-
特殊模块需要差异化版本时,在子模块局部覆盖,不改动全局父工程
-
结合代码类继承 + 工程继承,实现项目架构+业务代码双层复用,是企业最优方案