跳到主要内容Javajava
SpringBoot 配置文件核心用法:Properties 与 YAML
综述由AI生成SpringBoot 配置文件用于集中管理项目参数,包括服务端口、数据库连接及日志设置。系统支持 properties 和 YAML 两种格式,其中 YAML 因树形结构更利于复杂配置的可读性。深入解析两种格式的语法特性、加载优先级,演示如何通过 @Value 和 @ConfigurationProperties 注解实现基础值、对象、集合及 Map 的自动注入,并补充了初始化方法 @PostConstruct 的实际应用场景,助力开发者规范配置管理流程。
小熊软糖7 浏览 SpringBoot 配置文件作用
SpringBoot 定义了规范的配置文件格式,用于集成其他框架,并集中管理项目各类配置信息,典型场景包括:
- 项目启动端口:自定义服务监听端口
- 数据库连接信息:包含用户名、密码等
- 第三方系统调用密钥
- 日志配置:普通日志、异常日志,用于问题定位与排查
关键配置场景说明
- 项目启动端口
SpringBoot 内置 Tomcat 服务器,默认端口号为 8080。若 8080 端口被其他程序占用,需通过配置文件自定义端口号。
- 数据库连接信息
持久层框架(如 MyBatis、JPA 等)是对 JDBC 的深层封装。不同应用访问的数据库不同,需通过配置文件自定义数据库连接参数。
配置文件快速入门
SpringBoot 项目创建时,会自动生成配置文件。可通过修改配置文件,更改服务端口号(解决 8080 端口被占用问题)。
修改 application.properties 文件
server.port=9090
重启后显示 Tomcat 启动端口号为 9090。访问程序:http://127.0.0.1:9090/login.html。此时 http://127.0.0.1:8080/login.html 将无法访问。
配置文件的格式
Spring Boot 配置文件主要有三种:
application.properties
application.yml
application.yaml
注意:yml 为 yaml 的简写,实际开发中出现频率最高。当应用程序启动时,Spring Boot 会自动从 classpath 路径找到并加载这些文件。也可以通过 spring.config.name 指定文件路径和名称。
配置文件包装类比
类似商品包装,.properties 是传统格式(Spring Boot 项目默认),.yml 是现代推荐格式,实际开发中更推荐使用。
特殊说明
- 共存与优先级:理论上
.properties 和 .yml 可共存,启动时都会加载;若配置冲突,.properties 优先级更高。
- 实践建议:实际业务中建议统一使用一种格式,便于维护、降低故障概率。
注意事项:切换文件格式后,如果 IDE 出现乱码,通常是因为编码设置不一致。解决方法包括检查 IDE 的文件编码设置(如 UTF-8)以及本地配置文件的编码格式。
properties 配置文件说明
基本语法
- 格式:键值对,
key=value 形式
- 注释:使用
# 添加注释
示例:
# 配置项目端口号
server.port=8080
# 配置数据库连接信息
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/testdb?characterEncoding=utf8&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
读取配置文件
方式:使用 @Value 注解,以 ${key} 格式读取。
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class PropertiesController {
@Value("${mykey.key1}")
private String key1;
@RequestMapping("/key")
public String key() {
return "读取到值:" + key1;
}
}
访问 /key 接口时,会返回配置文件中 mykey.key1 对应的值(如 读取到值:bite)。
@PostConstruct 核心说明
@PostConstruct 是 Java EE 中的注解(Spring 也完全支持),作用是:在 Spring 容器创建完 Bean 实例、完成依赖注入后,自动执行标注了这个注解的方法。简单说:Bean 先被创建 → 依赖注入(比如 @Autowired 注入的对象)→ @PostConstruct 方法执行。
- 初始化数据(比如加载配置、初始化缓存、连接第三方服务);
- 执行 Bean 创建后的前置操作(依赖注入完成后才能执行,避免空指针)。
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
@Component
public class UserService {
@Autowired
private ConfigService configService;
@PostConstruct
public void init() {
String config = configService.getConfig();
System.out.println("Bean 初始化完成,加载配置:" + config);
}
}
@Component
class ConfigService {
public String getConfig() {
return "数据库连接配置:jdbc:mysql://localhost:3306/test";
}
}
- 标注的方法必须是:无参数、无返回值(void)、非静态;
- 执行时机:晚于
@Autowired 依赖注入,早于 Bean 被业务代码使用;
- 替代方案:Spring 的
InitializingBean 接口(但 @PostConstruct 更简洁)。
properties 缺点分析
properties 配置是以 key-value 的形式配置的,配置文件中会有很多的冗余的信息,比如层级关系需要用点号连接。想要解决这个问题,就可以使用 yml 配置文件的格式化优势。
yml 配置文件说明
yml 是 YAML 的缩写,它的全称是 Yet Another Markup Language,翻译成中文就是'另一种标记语言'。我们先来学习 yml 的语法。
yml 基本语法
yml 是树形结构的配置文件,它的基础语法是 "key: value"。
- key 和 value 之间使用英文冒号加空格的方式组成,空格不可省略。
server:
port: 8080
host: localhost
1. 基础键值对(核心语法)
2. 数据类型
name: 张三
nickname: "zhangsan:001"
remark: 'hello\nworld'
age: 20
score: 98.5
enabled: true
disabled: false
empty: null
birthday: 2024-03-18
3. 集合 / 数组(两种写法)
user:
hobbies:
- 篮球
- 游泳
- 编程
user:
tags: [Java, SpringBoot, MySQL]
4. 对象 / 嵌套配置
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/test
username: root
password: 123456
redis:
host: 127.0.0.1
port: 6379
timeout: 5000ms
5. 注释规则
使用 yml 连接数据库
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/dbname?characterEncoding=utf8&useSSL=false
username: root
password: root
yml 和 properties 连接数据库的配置对比:yml 结构更清晰,减少了重复的前缀。
yml 使用进阶
配置不同数据类型及 null
string.value: Hello
boolean.value: true
boolean.value1: false
int.value: 10
float.value: 3.14159
null.value: ~
empty.value: ''
yml 配置读取
yml 读取配置的方式和 properties 相同,使用 @Value 注解即可。
@RestController
public class ReadYml {
@Value("${string.hello}")
private String hello;
@RequestMapping("/ymlKey")
public String key() {
return "读取到值:" + hello;
}
}
访问地址:http://127.0.0.1:8080/ymlKey。运行结果页面显示:读取到值:bite。
注意事项:value 值加单双引号
字符串默认不用加上单引号或者双引号,如果加英文的单双引号可以表示特殊的含义。
尝试在 application.yml 中配置如下信息:
string:
str1: Hello \n Spring Boot.
str2: 'Hello \n Spring Boot.'
str3: "Hello \n Spring Boot."
@RestController
public class ReadYml {
@Value("${string.str1}")
private String str1;
@Value("${string.str2}")
private String str2;
@Value("${string.str3}")
private String str3;
@RequestMapping("/yml")
public String readYml() {
System.out.println(str1);
System.out.println(str2);
System.out.println(str3);
return "yml";
}
}
Hello \n Spring Boot.
Hello \n Spring Boot.
Hello Spring Boot.
- 字符串默认不用加上单引号或者双引号。
- 单引号会转义特殊字符,使其失去特殊功能,始终是一个普通的字符串。
- 双引号不会转义字符串里面的特殊字符,特殊字符会表示本身的含义。
- 使用单引号会转义,
\n 不再表示换行,而是表示一个普通的字符串。
- 使用双引号不会转义,
\n 表示的是它本身的含义,就是换行。
配置对象
student:
id: 1
name: Java
age: 18
student: {id: 1, name: Java, age: 18}
这个时候就不能用 @Value 来读取配置中的对象了,此时要使用另一个注解 @ConfigurationProperties 来读取。
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@ConfigurationProperties(prefix = "student")
@Component
@Data
public class Student {
private int id;
private String name;
private int age;
}
@RestController
public class StudentController {
@Autowired
private Student student;
@RequestMapping("/readStudent")
public String readStudent() {
return student.toString();
}
}
访问地址:http://127.0.0.1:8080/readStudent。
配置集合
dbtypes:
name:
- mysql
- sqlserver
- db2
集合的读取和对象一样,也是使用 @ConfigurationProperties 来读取的。
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import java.util.List;
@Component
@ConfigurationProperties("dbtypes")
@Data
public class ListConfig {
private List<String> name;
}
@RestController
public class ReadYml2 {
@Autowired
private ListConfig listConfig;
@RequestMapping("/readList")
public String readList() {
return listConfig.toString();
}
}
配置 Map
maptypes:
map:
k1: kk1
k2: kk2
k3: kk3
maptypes: {map: {k1: kk1, k2: kk2, k3: kk3}}
Map 的读取和对象一样,也是使用 @ConfigurationProperties 来读取的。
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import java.util.HashMap;
@Component
@ConfigurationProperties("maptypes")
@Data
public class MapConfig {
private HashMap<String, String> map;
}
@RestController
public class ReadYml2 {
@Autowired
private MapConfig mapConfig;
@RequestMapping("/readMap")
public String readStudent() {
return mapConfig.toString();
}
}
yml 优缺点
优点
- 可读性高,写法简单,易于理解
- 支持更多的数据类型,可以简单表达对象、数组、List、Map 等数据形态
- 支持更多的编程语言,不止是 Java 中可以使用,在 Golang、Python、Ruby、JavaScript 中也可以使用
缺点
- 不适合写复杂的配置文件
转换的过程也比较花费精力,如果配置更复杂一点,可读性会更差,代码也会更难写
- 对格式有较强的要求(一个空格可能会引起一场血案)
keycloak:
realm: demo
resource: fm-cache-cloud
credentials:
secret: d4589683-0ce7-4982-bcd3
security:
- authRoles:
- user
collections:
- name: ssologinurl
patterns:
- /login/*
keycloak.realm=demo
keycloak.resource=fm-cache-cloud
keycloak.credentials.secret=d4589683-0ce7-4982-bcd3
keycloak.security[0].authRoles[0]=user
keycloak.security[0].collections[0].name=ssologinurl
keycloak.security[0].collections[0].patterns[0]=/login/*
相关免费在线工具
- Keycode 信息
查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online
- Escape 与 Native 编解码
JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online
- JavaScript / HTML 格式化
使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online
- JavaScript 压缩与混淆
Terser 压缩、变量名混淆,或 javascript-obfuscator 高强度混淆(体积会增大)。 在线工具,JavaScript 压缩与混淆在线工具,online
- Base64 字符串编码/解码
将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online
- Base64 文件转换器
将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online