一、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=/demoyml 写法(层级对应,更贴合代码结构):
server: port: 8088 servlet: context-path: /demoyml语法硬性规范:冒号后必须加空格、靠缩进控制层级、大小写敏感,特殊字符需单引号包裹,语法错误直接导致项目启动失败。官方建议:全程统一一种配置格式,避免版本优先级混乱。
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: dev2、命令行激活(生产部署常用):
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 父工程继承,统一项目基建规范
父工程只做版本声明与依赖管理,不引入具体业务依赖,避免依赖冗余
特殊模块需要差异化版本时,在子模块局部覆盖,不改动全局父工程
结合代码类继承 + 工程继承,实现项目架构+业务代码双层复用,是企业最优方案