Подтвердить что ты не робот

Как ввести карту с помощью аннотации @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
4b9b3361

Ответ 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"
}'