如何在 Spring 中使用 @Value 注解将属性文件中的值注入到 Map 中?
我的 Spring Java 类是,我尝试使用 $,但收到以下错误消息:
无法自动装配字段:private java.util.Map Test.standard;嵌套异常是 java.lang.IllegalArgumentException:无法解析字符串值“${com.test.standard}”中的占位符“com.test.standard”
@ConfigurationProperty("com.hello.foo")
public class Test {
@Value("${com.test.standard}")
private Map<String,Pattern> standard = new LinkedHashMap<String,Pattern>
private String enabled;
}
我在 .properties 文件中有以下属性
com.test.standard.name1=Pattern1
com.test.standard.name2=Pattern2
com.test.standard.name3=Pattern3
com.hello.foo.enabled=true
您可以使用
@Value
注释将属性文件中的值注入到 Map 中,如下所示。
属性文件中的属性。
propertyname={key1:'value1',key2:'value2',....}
在你的代码中。
@Value("#{${propertyname}}") private Map<String,String> propertyname;
注意主题标签作为注释的一部分。
我相信 Spring Boot 支持使用 @ConfigurationProperties 注释加载开箱即用的属性映射。
根据该文档,您可以加载属性:
my.servers[0]=dev.bar.com
my.servers[1]=foo.bar.com
变成这样的豆子:
@ConfigurationProperties(prefix="my")
public class Config {
private List<String> servers = new ArrayList<String>();
public List<String> getServers() {
return this.servers;
}
}
我之前使用过@ConfigurationProperties功能,但没有加载到地图中。您需要使用 @EnableConfigurationProperties 注解来启用此功能。
此功能的一个很酷的地方是您可以验证您的属性。
要使其与 YAML 一起使用,请执行以下操作:
property-name: '{
key1: "value1",
key2: "value2"
}'
您可以使用
.properties
注释将 @Resource
作为地图注入到您的类中。
如果您正在使用
XML based configuration
,,请在 Spring 配置文件中添加以下 bean:
<bean id="myProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="location" value="classpath:your.properties"/>
</bean>
对于,基于注释:
@Bean(name = "myProperties")
public static PropertiesFactoryBean mapper() {
PropertiesFactoryBean bean = new PropertiesFactoryBean();
bean.setLocation(new ClassPathResource(
"your.properties"));
return bean;
}
然后您可以在应用程序中将它们作为地图选取:
@Resource(name = "myProperties")
private Map<String, String> myProperties;
我有一个简单的 Spring Cloud Config 代码
像这样:
在 application.properties 中
spring.data.mongodb.db1=mongodb://[电子邮件受保护]
spring.data.mongodb.db2=mongodb://[电子邮件受保护]
@Bean(name = "mongoConfig")
@ConfigurationProperties(prefix = "spring.data.mongodb")
public Map<String, Map<String, String>> mongoConfig() {
return new HashMap();
}
@Autowired
@Qualifier(value = "mongoConfig")
private Map<String, String> mongoConfig;
@Bean(name = "mongoTemplates")
public HashMap<String, MongoTemplate> mongoTemplateMap() throws UnknownHostException {
HashMap<String, MongoTemplate> mongoTemplates = new HashMap<>();
for (Map.Entry<String, String>> entry : mongoConfig.entrySet()) {
String k = entry.getKey();
String v = entry.getValue();
MongoTemplate template = new MongoTemplate(new SimpleMongoDbFactory(new MongoClientURI(v)));
mongoTemplates.put(k, template);
}
return mongoTemplates;
}
以下对我有用:
SpingBoot 2.1.7.发布
YAML 属性(用单引号括起来的通知值)
property:
name: '{"key1": false, "key2": false, "key3": true}'
在 Java/Kotlin 中用(注意使用 #)注释字段(对于 java 不需要用 '\' 转义 '$')
@Value("#{\${property.name}}")
我们是这样做的。 两个示例类如下:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.kafka.annotation.EnableKafka;
@EnableKafka
@Configuration
@EnableConfigurationProperties(KafkaConsumerProperties.class)
public class KafkaContainerConfig {
@Autowired
protected KafkaConsumerProperties kafkaConsumerProperties;
@Bean
public ConsumerFactory<String, String> consumerFactory() {
return new DefaultKafkaConsumerFactory<>(kafkaConsumerProperties.getKafkaConsumerConfig());
}
...
@Configuration
@ConfigurationProperties
public class KafkaConsumerProperties {
protected Map<String, Object> kafkaConsumerConfig = new HashMap<>();
@ConfigurationProperties("kafkaConsumerConfig")
public Map<String, Object> getKafkaConsumerConfig() {
return (kafkaConsumerConfig);
}
...
要从属性文件提供 kafkaConsumer 配置,您可以使用:mapname[key]=value
//application.properties
kafkaConsumerConfig[bootstrap.servers]=localhost:9092, localhost:9093, localhost:9094
kafkaConsumerConfig[group.id]=test-consumer-group-local
kafkaConsumerConfig[value.deserializer]=org.apache.kafka.common.serialization.StringDeserializer
kafkaConsumerConfig[key.deserializer=org.apache.kafka.common.serialization.StringDeserializer
要从 yaml 文件提供 kafkaConsumer 配置,您可以使用“[key]”:值 在 application.yml 文件中:
kafkaConsumerConfig:
"[bootstrap.servers]": localhost:9092, localhost:9093, localhost:9094
"[group.id]": test-consumer-group-local
"[value.deserializer]": org.apache.kafka.common.serialization.StringDeserializer
"[key.deserializer]": org.apache.kafka.common.serialization.StringDeserializer
您可以使用以下代码。
以下代码
application.yml
my:
mapValues:
dbData: '{
"connectionURL": "http://tesst:3306",
"userName": "myUser",
"password": "password123"
}'
要使用
@Value
注释访问这些键和值,请使用下面的 Java 代码。
@Value("#{${my.mapValues.dbData}}")
private Map<String,String> dbValues;
请注意,属性文件中的属性是弱类型。当 Spring 解析它时,转换类型可能是错误的。
这是一个例子:
属性文件中的属性。
delayedSeconds={default:300,004:900}
在您的代码中:
@Value("#{${delayedSeconds}}")
private Map<String, Long> allDelayedSeconds;
输出解析后的配置:
allDelayedSeconds={default=300, 4=900}
您需要添加引号到按键中。
delayedSeconds={"default":300,"004":900}