Spring Boot 自定义配置类(包含字符串、数字、布尔、小数、集合、映射、嵌套对象)实现步骤及示例

Spring Boot 自定义配置类实现步骤及示例


步骤说明
  1. 创建配置类 :定义一个 POJO 类,使用 @ConfigurationProperties 注解指定配置前缀。
  2. 启用配置绑定 :在启动类或配置类上添加 @EnableConfigurationProperties 注解。
  3. 配置文件写法 :在 application.propertiesapplication.yml 中按前缀配置参数。
  4. 注入配置类 :通过 @Autowired 在需要的组件中使用配置参数。

完整代码示例
java 复制代码
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

import java.util.List;
import java.util.Map;

@Component
@ConfigurationProperties(prefix = "app.config") // 指定配置前缀
@Data // Lombok 自动生成 getter/setter
public class AppConfig {

    // 基本类型
    private String name;          // 字符串类型
    private int port;             // 整型
    private boolean enabled;      // 布尔型
    private double version;       // 双精度浮点型

    // 集合类型
    private List<String> roles;   // 列表
    private Map<String, String> metadata; // 键值对

    // 嵌套对象
    private NestedConfig nested;

    // 嵌套类(需在父类中定义或单独定义)
    @Data
    public static class NestedConfig {
        private String field1;
        private Integer field2;
    }
}

启用配置绑定

在 Spring Boot 启动类或配置类上添加 @EnableConfigurationProperties

java 复制代码
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.properties.EnableConfigurationProperties;

@SpringBootApplication
@EnableConfigurationProperties(AppConfig.class) // 启用配置类
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

配置文件示例
application.properties
properties 复制代码
app.config.name=MyApp
app.config.port=8080
app.config.enabled=true
app.config.version=1.0.0
app.config.roles=ROLE_USER,ROLE_ADMIN
app.config.metadata.key1=value1
app.config.metadata.key2=value2
app.config.nested.field1=nestValue
app.config.nested.field2=42
application.yml
yaml 复制代码
app:
  config:
    name: MyApp
    port: 8080
    enabled: true
    version: 1.0.0
    roles:
      - ROLE_USER
      - ROLE_ADMIN
    metadata:
      key1: value1
      key2: value2
    nested:
      field1: nestValue
      field2: 42

字段类型总结表格
字段类型 字段名 配置示例 说明
String name app.config.name=MyApp 基础字符串配置
int port app.config.port=8080 整数类型配置
boolean enabled app.config.enabled=true 布尔值开关配置
double version app.config.version=1.0.0 浮点数配置
List roles app.config.roles=ROLE_USER,ROLE_ADMIN 列表集合配置(逗号分隔)
Map metadata app.config.metadata.key1=value1 键值对配置(YAML 需层级结构)
嵌套对象 nested app.config.nested.field1=nestValue 嵌套对象需通过子属性层级配置

关键注释说明
  1. @ConfigurationProperties :必须指定 prefix 属性,对应配置文件的前缀。
  2. 嵌套对象 :通过字段名继续扩展配置层级(如 nested.field1)。
  3. 集合类型List 用逗号分隔值,Map 需通过键名直接赋值。
  4. 启用配置 :通过 @EnableConfigurationProperties 或在配置类上添加 @Component 自动注册 Bean。
相关推荐
甜鲸鱼5 分钟前
【Spring AOP】操作日志的完整实现与原理剖析
java·spring boot·spring
狗头大军之江苏分军10 分钟前
年底科技大考:2025 中国前端工程师的 AI 辅助工具实战盘点
java·前端·后端
一 乐38 分钟前
酒店客房预订|基于springboot + vue酒店客房预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
计算机毕设指导639 分钟前
基于Spring Boot的防诈骗管理系统【源码文末联系】
java·spring boot·后端·spring·tomcat·maven·intellij-idea
a程序小傲1 小时前
饿了吗Java面试被问:Redis的持久化策略对比(RDBVS AOF)
java·redis·面试
我家领养了个白胖胖1 小时前
MCP模型上下文协议 Model Context Protocol & 百度地图MCP开发
java·后端·ai编程
Coder_Boy_1 小时前
基于DDD+Spring Boot 3.2+LangChain4j构建企业级智能客服系统
java·人工智能·spring boot·后端
来鸟 鸣间1 小时前
MIPI D-PHY 理解
linux·音视频·sensor·mipi
么么...1 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker
黄俊懿1 小时前
【深入理解SpringCloud微服务】Spring-Security作用与原理解析
java·后端·安全·spring·spring cloud·微服务·架构师