Как ввести карту с помощью аннотации @Value Spring?
Как я могу вводить значения в Map из файла свойств с помощью аннотации @Value в Spring?
Мой Spring класс Java и я попытался использовать $, но получил следующее сообщение об ошибке
Не удалось создать поле autwire: private java.util.Map Test.standard; Вложенное исключение - это java.lang.IllegalArgumentException: Не удалось разрешить placeholder '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
Ответы
Ответ 1
Я верю, что Spring Загрузка поддерживает загрузку карт свойств из коробки с помощью аннотации @ConfigurationProperties.
В соответствии с этими документами вы можете загружать свойства:
my.servers[0]=dev.bar.com
my.servers[1]=foo.bar.com
в bean следующим образом:
@ConfigurationProperties(prefix="my")
public class Config {
private List<String> servers = new ArrayList<String>();
public List<String> getServers() {
return this.servers;
}
}
Раньше я использовал функцию @ConfigurationProperties, но без загрузки на карту. Чтобы включить эту функцию, вам необходимо использовать @EnableConfigurationProperties аннотацию.
Прохладный материал об этой функции состоит в том, что вы можете проверить свои свойства.
Ответ 2
Вы можете вводить значения в карту из файла свойств с помощью аннотации @Value
, как это.
Свойство в файле свойств.
propertyname={key1:'value1',key2:'value2',....}
В вашем коде.
@Value("#{${propertyname}}") private Map<String,String> propertyname;
Обратите внимание на хэштег как часть аннотации.
Ответ 3
Вы можете ввести .properties
в качестве карты в своем классе с помощью аннотации @Resource
.
Если вы работаете с XML based configuration
,, добавьте ниже bean в конфигурационный файл spring:
<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;
Ответ 4
Вот как мы это сделали. Два класса примеров:
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
Чтобы предоставить конфигурацию kafkaConsumer из файла yaml, вы можете использовать "[ключ]": значение В файле 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
Ответ 5
У меня был простой код для Spring Cloud Config
как это:
В приложении. Свойства
spring.data.mongodb.db1 = MongoDB://[email protected]
spring.data.mongodb.db2 = MongoDB://[email protected]
читать
@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;
}
Ответ 6
Чтобы заставить это работать с YAML, сделайте это:
property-name: '{
key1: "value1",
key2: "value2"
}'