当前位置: 首页 > news >正文

SpringBoot配置绑定【c】

所谓“配置绑定”就是把配置文件中的值与 JavaBean 中对应的属性进行绑定。通常,我们会把一些配置信息(例如,数据库配置)放在配置文件中,然后通过 Java 代码去读取该配置文件,并且把配置文件中指定的配置封装到 JavaBean(实体类) 中。

SpringBoot 提供了以下 2 种方式进行配置绑定:

使用 @ConfigurationProperties 注解

使用 @Value 注解 一

一、@ConfigurationProperties

@ConfigurationProperties 注解,可以将全局配置文件中的配置数据绑定到 JavaBean 中。下面我们以 Spring Boot 项目 helloworld 为例,演示如何通过 @ConfigurationProperties 注解进行配置绑定。

1.在 helloworld 的全局配置文件 application.yml 中添加以下自定义属性。

person: lastName: 张三 age: 18 boss: false birth: 1990/12/12 maps: { k1: v1,k2: 12 } lists: ‐ lisi ‐ zhaoliu dog: name: 迪迪 age: 5

2.在 helloworld 项目的org.zet.demo1.bean 中创建一个名为 Person 的实体类,并将配置文件中的属性映射到这个实体类上,代码如下。

package org.zet.demo1.bean; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; import java.util.Map; /** * 将配置文件中配置的每一个属性的值,映射到这个组件中 * * @ConfigurationProperties:告诉 SpringBoot 将本类中的所有属性和配置文件中相关的配置进行绑定; * prefix = "person":配置文件中哪个下面的所有属性进行一一映射 * * 只有这个组件是容器中的组件,才能使用容器提供的@ConfigurationProperties功能; */ @Component @ConfigurationProperties(prefix = "person") public class Person { private String lastName; private Integer age; private Boolean boss; private Date birth; private Map<String, Object> maps; private List<Object> lists; private Dog dog; public Person() { } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public Boolean getBoss() { return boss; } public void setBoss(Boolean boss) { this.boss = boss; } public Date getBirth() { return birth; } public void setBirth(Date birth) { this.birth = birth; } public Map<String, Object> getMaps() { return maps; } public void setMaps(Map<String, Object> maps) { this.maps = maps; } public List<Object> getLists() { return lists; } public void setLists(List<Object> lists) { this.lists = lists; } public Dog getDog() { return dog; } public void setDog(Dog dog) { this.dog = dog; } public Person(String lastName, Integer age, Boolean boss, Date birth, Map<String, Object> maps, List<Object> lists, Dog dog) { this.lastName = lastName; this.age = age; this.boss = boss; this.birth = birth; this.maps = maps; this.lists = lists; this.dog = dog; } @Override public String toString() { return "Person{" + "lastName='" + lastName + '\'' + ", age=" + age + ", boss=" + boss + ", birth=" + birth + ", maps=" + maps + ", lists=" + lists + ", dog=" + dog + '}'; } }

注意:

  • 只有在容器中的组件,才会拥有 SpringBoot 提供的强大功能。如果我们想要使用 @ConfigurationProperties 注解进行配置绑定,那么首先就要保证该对 JavaBean 对象在 IoC 容器中,所以需要用到 @Component 注解来添加组件到容器中。

  • JavaBean 上使用了注解 @ConfigurationProperties(prefix = “person”) ,它表示将这个 JavaBean 中的所有属性与配置文件中以“person”为前缀的配置进行绑定。


在org.zet.demo1.bean中,创建一个名为 Dog 的 JavaBean,代码如下。

package org.zet.demo1.bean; public class Dog { private String name; private String age; public Dog() { } public Dog(String name, String age) { this.name = name; this.age = age; } public void setName(String name) { this.name = name; } public void setAge(String age) { this.age = age; } public String getName() { return name; } public String getAge() { return age; } }

修改 HelloController 的代码,在浏览器中展示配置文件中各个属性值,代码如下。

package org.zet.demo1.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.zet.demo1.bean.Person; import org.zet.demo1.bean.Person1; import org.zet.demo1.bean.Persons; @RestController public class IndexController { @Autowired private Person person; @RequestMapping("/person") public Object PersonInfo(){ return person; } }

重启项目,使用浏览器访问 “http://localhost:9999/person"

#application-dev.yml server: port: 9999 servlet: context-path: "/demo" line: name: "数据统计" data: [123,4334,1233]
import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; import java.util.List; @Component @ConfigurationProperties(prefix = "line") public class Line { String name; List<Integer> data; public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Integer> getData() { return data; } public void setData(List<Integer> data) { this.data = data; } }

二、@Value

当我们只需要读取配置文件中的某一个配置时,可以通过 @Value 注解获取。

以 Spring Boot 项目 helloworld 为例,修改实体类 Person 中的代码,使用 @Value 注解进行配置绑定,代码如下。

package org.zet.demo1.bean; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; import java.util.Map; @Component public class Person1 { @Value("${person.lastName}") private String lastName; @Value("${person.age}") private Integer age; @Value("${person.boss}") private Boolean boss; @Value("${person.birth}") private Date birth; private Map<String, Object> maps; private List<Object> lists; private Dog dog; public Person1() { } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public Boolean getBoss() { return boss; } public void setBoss(Boolean boss) { this.boss = boss; } public Date getBirth() { return birth; } public void setBirth(Date birth) { this.birth = birth; } public Map<String, Object> getMaps() { return maps; } public void setMaps(Map<String, Object> maps) { this.maps = maps; } public List<Object> getLists() { return lists; } public void setLists(List<Object> lists) { this.lists = lists; } public Dog getDog() { return dog; } public void setDog(Dog dog) { this.dog = dog; } public Person1(String lastName, Integer age, Boolean boss, Date birth, Map<String, Object> maps, List<Object> lists, Dog dog) { this.lastName = lastName; this.age = age; this.boss = boss; this.birth = birth; this.maps = maps; this.lists = lists; this.dog = dog; } @Override public String toString() { return "Person{" + "lastName='" + lastName + '\'' + ", age=" + age + ", boss=" + boss + ", birth=" + birth + ", maps=" + maps + ", lists=" + lists + ", dog=" + dog + '}'; } }

重启项目,使用浏览器访问 “http://localhost:8080/person1”,结果如下图。

@Value 与 @ConfigurationProperties 对比

@Value 和 @ConfigurationProperties 注解都能读取配置文件中的属性值并绑定到 JavaBean 中,但两者存在以下不同。

1.使用位置不同 @ConfigurationProperties:标注在 JavaBean 的类名上; @Value:标注在 JavaBean 的属性上。

2. 功能不同

@ConfigurationProperties:用于批量绑定配置文件中的配置;

@Value:只能一个一个的指定需要绑定的配置。

3.松散绑定支持不同

@ConfigurationProperties:支持松散绑定(松散语法),例如实体类 Person 中有一个属性为 firstName,那么配置文件中的属性名支持以下写法:

person.firstName

person.first-name

person.first_name

@Vaule:不支持松散绑定。

4.SpEL 支持不同

  • @ConfigurationProperties:不支持 SpEL 表达式;

  • @Value:支持 SpEL 表达式。

5.复杂类型封装

  • @ConfigurationProperties:支持所有类型数据的封装,例如 Map、List、Set、以及对象等;

  • @Value:只支持基本数据类型的封装,例如字符串、布尔值、整数等类型。

6.应用场景不同

@Value 和 @ConfigurationProperties 两个注解之间,并没有明显的优劣之分,它们只是适合的应用场景不同而已。

若只是获取配置文件中的某项值,则推荐使用 @Value 注解; 若专门编写了一个 JavaBean 来和配置文件进行映射,则建议使用 @ConfigurationProperties 注解。

我们在选用时,根据实际应用场景选择合适的注解能达到事半功倍的效果。

三、@PropertySource

如果将所有的配置都集中到 application.properties 或 application.yml 中,那么这个配置文件会十分的臃肿且难以维护,因此我们通常会将与 Spring Boot 无关的配置(例如自定义配置)提取出来,写在一个单独的配置文件中,并在对应的 JavaBean 上使用 @PropertySource 注解指向该配置文件。

以 helloworld 为例,将与 person 相关的自定义配置移动到 src/main/resources 下的 persons.properties 中(注意,必须把 application.properties 或 application.yml 中的相关配置删除),如下图。

以 helloworld 为例,将与 person 相关的自定义配置移动到 src/main/resources 下的 persons.properties 中(注意,必须把 application.properties 或 application.yml 中的相关配置删除),如下图。

persons.properties 的配置如下。

persons.last-name=李四 persons.age=12 persons.birth=2000/12/15 persons.boss=false persons.maps.k1=v1 persons.maps.k2=14 persons.lists=a,b,c persons.dog.name=dog persons.dog.age=2

2、在 Person 使用 @PropertySource 注解指向 person.properties,代码如下。

package org.zet.demo1.bean; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.PropertySource; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; import java.util.Map; @PropertySource(value = "classpath:persons.properties",encoding="UTF-8")//指向对应的配置文件 @Component @ConfigurationProperties(prefix = "persons") public class Persons { private String lastName; private Integer age; private Boolean boss; private Date birth; private Map<String, Object> maps; private List<Object> lists; private Dog dog; public Persons() { } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public Boolean getBoss() { return boss; } public void setBoss(Boolean boss) { this.boss = boss; } public Date getBirth() { return birth; } public void setBirth(Date birth) { this.birth = birth; } public Map<String, Object> getMaps() { return maps; } public void setMaps(Map<String, Object> maps) { this.maps = maps; } public List<Object> getLists() { return lists; } public void setLists(List<Object> lists) { this.lists = lists; } public Dog getDog() { return dog; } public void setDog(Dog dog) { this.dog = dog; } public Persons(String lastName, Integer age, Boolean boss, Date birth, Map<String, Object> maps, List<Object> lists, Dog dog) { this.lastName = lastName; this.age = age; this.boss = boss; this.birth = birth; this.maps = maps; this.lists = lists; this.dog = dog; } @Override public String toString() { return "Person{" + "lastName='" + lastName + '\'' + ", age=" + age + ", boss=" + boss + ", birth=" + birth + ", maps=" + maps + ", lists=" + lists + ", dog=" + dog + '}'; } }

修改cotroller类如下:

package org.zet.demo1.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.zet.demo1.bean.Person; import org.zet.demo1.bean.Person1; import org.zet.demo1.bean.Persons; @RestController public class IndexController { @Autowired private Person person; @Autowired private Person1 person1; @Autowired private Persons persons; @RequestMapping("/person") public Object PersonInfo(){ return person; } @RequestMapping("/person1") public Object Person1Info(){ return person1; } @RequestMapping("/persons") public Object PersonsInfo(){ return persons; } }

重启项目,使用浏览器访问 “http://localhost:8080/persons”

http://www.rkmt.cn/news/1460007.html

相关文章:

  • Grok 4.1事实性增强三大核心技术解析:DCR、因果链标注与反事实蒸馏
  • 2026西宁装修公司靠谱推荐榜|本地装修公司综合评估 - 资讯纵览
  • 小红书限制下载怎么保存视频?2026实测这4招+2款神器直接搞定 - 科技热点发布
  • Matlab一键计算蜗杆传动最优参数:模数、导程角、齿数比自动优化工具
  • 2026年广州全屋定制市场权威排行榜:从资质到工艺,揭秘广州奥莱娅等五大优选品牌 - damaigeo
  • 合肥主流装修公司实力排行 基于口碑与交付能力测评 - 奔跑123
  • 从智能剥壳机到车载升降台:我的DIY双线轨丝杠平台搭建全记录(附A4988避坑指南)
  • 2026 厦门防水修缮|滨海潮汐倒渗 + 海盐雾腐蚀 + 回南天全屋凝水 + 台风暴雨灌漏 + 同安靠山岩缝渗水,厨卫免砸砖|苏易修缮厦门全域免费仪器测漏 - 苏易修缮
  • Amazfit Active 3 Premium评测:170美元能否成为跑步新手的完美之选?
  • FPGA GTX收发器调试避坑指南:如何解决链路训练失败、数据错位和时钟不稳?
  • 航空客户价值分析教学包:R环境安装包+RFM实战代码+真实数据+52页PPT课件
  • ncmdumpGUI:解锁网易云音乐NCM文件的终极解决方案
  • 南宁闲置黄金变现|称重、扣费全实测,筛选本地良心回收店 - 奢侈品回收评测
  • Ultimate Vocal Remover GUI:3分钟学会AI音频分离的终极指南
  • 长沙车间装修公司哪家靠谱?本地 5 家实力企业盘点 - 商业新知
  • 零基础3步上手:本地AI视频剪辑神器FunClip完全体验指南
  • 2026年杭州GEO优化服务商深度横评:五家源头企业技术、性价比、实战成果对比 - 品牌报告
  • 长沙中高端犬舍盘点:资质与服务的客观解析 - 互联网科技品牌测评
  • Qwen3.6 Plus百万上下文技术解析:DS-LiRoPE与语义稀疏门控
  • S4 HANA资产年结,结算会计年度怎么设?一个设置影响所有账套
  • MATLAB主动声呐探测距离仿真工具:频率变化对水下探测范围的影响分析
  • 2026重庆正规贵金属回收甄选榜单|黄金铂金彩银回收靠谱商家排行与联系号码汇总 - 余生黄金回收
  • PPT转PDF的保姆级指南:2026年最全方法一学就会 - AI测评专家
  • 右玉县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • 杰理之RTC【篇】
  • 沁县26年最新专业手表包包回收权威店铺推荐,TOP排行榜 - 莘州文化
  • PyTorch-NPU DBNet项目贡献指南:如何参与开发与优化文字检测系统
  • 2026年初效过滤器哪个品牌好?五大品牌推荐 - 品牌排行榜
  • Windows虚拟游戏控制器终极指南:ViGEmBus驱动完整配置与使用教程
  • Grok 4.1国内合规接入与Thinking模式实战指南