如何在 Spring Boot 中定义和读取 自定义配置

前言

在Spring Boot中定义和读取自定义配置是日常开发中常见的需求,它允许我们以灵活的方式管理应用的配置信息,无论是通过外部配置文件(如application.propertiesapplication.yml)还是通过环境变量。

作为高级程序员,我们需要掌握这一技能,以确保应用的可配置性和可维护性。以下是一个详细的步骤说明,包括示例代码,展示如何在Spring Boot中定义和读取自定义配置。

在Spring Boot中,你可以通过以下步骤定义和读取自定义配置:

  • application.propertiesapplication.yml中定义自定义配置项。

例如,在application.yml中添加:

XML 复制代码
app:
  custom:
    my-property: value
  • 创建一个配置类来绑定这些属性。
java 复制代码
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
 
@Configuration
@ConfigurationProperties(prefix = "app.custom")
public class CustomProperties {
 
    private String myProperty;
 
    public String getMyProperty() {
        return myProperty;
    }
 
    public void setMyProperty(String myProperty) {
        this.myProperty = myProperty;
    }
}
  • 在Spring Bean中注入CustomProperties类来使用配置值。
java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
 
@Component
public class MyComponent {
 
    private final CustomProperties customProperties;
 
    @Autowired
    public MyComponent(CustomProperties customProperties) {
        this.customProperties = customProperties;
    }
 
    public void printCustomProperty() {
        System.out.println(customProperties.getMyProperty());
    }
}

确保@ConfigurationProperties注解的prefix属性与你在配置文件中定义的前缀相匹配。Spring Boot会自动将配置属性绑定到CustomProperties类的字段上。然后你可以在应用程序的任何部分通过自动装配的方式来使用这些配置值。

或者:

定义自定义配置属性

XML 复制代码
# application.properties
myapp.name=Spring Boot Application
myapp.description=This is a demo application for custom configuration
myapp.server.port=8081

创建配置类

接下来,我们需要创建一个配置类来绑定这些自定义属性。在Spring Boot中,这通常通过@ConfigurationProperties注解实现,它允许我们将配置文件中的属性绑定到JavaBean上。

java 复制代码
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;

@Configuration
@ConfigurationProperties(prefix = "myapp")
public class MyAppConfig {

    private String name;
    private String description;
    private int serverPort;

    // 标准的getter和setter方法
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public int getServerPort() {
        return serverPort;
    }

    public void setServerPort(int serverPort) {
        this.serverPort = serverPort;
    }
}

注意,@ConfigurationProperties(prefix = "myapp")注解指定了配置属性的前缀为myapp,这样Spring Boot就能自动将application.properties中所有以myapp开头的属性绑定到MyAppConfig类的相应字段上。

读取配置

我们可以在应用的任何地方通过依赖注入的方式读取这些配置。例如,在一个Controller中

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyAppConfigController {

    private final MyAppConfig myAppConfig;

    @Autowired
    public MyAppConfigController(MyAppConfig myAppConfig) {
        this.myAppConfig = myAppConfig;
    }

    @GetMapping("/config")
    public String getConfig() {
        return "Name: " + myAppConfig.getName() + ", Description: " + myAppConfig.getDescription() + ", Server Port: " + myAppConfig.getServerPort();
    }
}

总结

通过上述步骤,我们成功地在Spring Boot中定义了自定义配置属性,并通过@ConfigurationProperties注解将它们绑定到了JavaBean上。最后,我们通过依赖注入的方式在应用中读取这些配置。这种方式不仅提高了代码的可读性和可维护性,还使得配置管理变得更加灵活和方便。在实际开发中,合理利用Spring Boot的配置管理功能,可以大大提升应用的灵活性和可扩展性。

相关推荐
lzp079138 分钟前
元数据驱动开发 - 面向对象编程思想的补充(上)
spring boot·后端·ui
●VON8 小时前
鸿蒙Flutter实战:分类管理页BottomSheet CRUD
数据库·flutter·华为·harmonyos·鸿蒙
Cosolar8 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
方也_arkling8 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮8 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei119 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1129 小时前
web-第一次课后作业
java·开发语言·idea
企服AI产品测评局9 小时前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
秋99 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本9 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven