由于要使用到第三方配置文件,需要将配置文件注入到属性中,特此记录一个demo:
- 搭建springboot 简易项目:
不做展示 - 引入配置文件相关依赖:
<!--导入配置文件处理器,配置文件进行绑定就会有提示-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
- 编辑配置文件application.yml
test:
map1:
key-map1-a: value-map1-a
key-map1-b: value-map1-b
map2:
key-map2-a: value-map2-a
key-map2-b: value-map2-b
- 创建配置类MapConfig
package cn.nudp.demo.config;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import java.util.HashMap;
import java.util.Map;
/**
* @author Anzimo
* @date 2020/7/24 9:44
*/
@Configuration
//@EnableConfigurationProperties 有人说这个注解用于开启@ConfigurationProperties, 测试显示这个注解可有可无,找原因中...
@ConfigurationProperties(prefix = "test") //值为yml文件中对应属性的上级
public class MapConfig {
/**
* map1、map2 为yml 中test下map的名
* 需要与其相匹配
*/
private Map<String, Object> map1 = new HashMap<>();
private Map<String, Object> map2 = new HashMap<>();
/**
* get/set 方法
*/
public Map<String, Object> getMap2() {
return map2;
}
public void setMap2(Map<String, Object> map2) {
this.map2 = map2;
}
public Map<String, Object> getMap1() {
return map1;
}
public void setMap1(Map<String, Object> map1) {
this.map1 = map1;
}
}
- 编辑测试类
package cn.nudp.demo;
import cn.nudp.demo.config.MapConfig;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.Map;
@SpringBootTest
class DemoApplicationTests {
@Autowired
MapConfig mapConfig;
@Test
void contextLoads() {
Map<String, Object> map1 = mapConfig.getMap1();
Map<String, Object> map2 = mapConfig.getMap2();
System.out.println("map1:");
map1.forEach((k,v)-> System.out.println(k+"----"+v));
System.out.println("map2:");
map2.forEach((k,v)-> System.out.println(k+"----"+v));
}
}
- 结果
map1:
key-map1-a----value-map1-a
key-map1-b----value-map1-b
map2:
key-map2-b----value-map2-b
key-map2-a----value-map2-a