Wie kann ich mit der Annotation @Value in Spring Werte aus der Eigenschaftendatei in eine Map einfügen?
Meine Spring Java-Klasse ist und ich habe versucht, das $ zu verwenden, bekam aber die folgende Fehlermeldung
Feld konnte nicht automatisch aktiviert werden: private Java.util.Map Test.standard; geschachtelte Ausnahme ist Java.lang.IllegalArgumentException: Platzhalter 'com.test.standard' konnte nicht im Zeichenfolgenwert "$ {com.test.standard}" aufgelöst werden
@ConfigurationProperty("com.hello.foo")
public class Test {
@Value("${com.test.standard}")
private Map<String,Pattern> standard = new LinkedHashMap<String,Pattern>
private String enabled;
}
Ich habe die folgenden Eigenschaften in einer .properties-Datei
com.test.standard.name1=Pattern1
com.test.standard.name2=Pattern2
com.test.standard.name3=Pattern3
com.hello.foo.enabled=true
Ich glaube, Spring Boot unterstützt das Laden von Eigenschaften-Maps mit @ConfigurationProperties annotation.
Entsprechend diesen Dokumenten können Sie Eigenschaften laden:
my.servers[0]=dev.bar.com
my.servers[1]=foo.bar.com
so in die Bohne:
@ConfigurationProperties(prefix="my")
public class Config {
private List<String> servers = new ArrayList<String>();
public List<String> getServers() {
return this.servers;
}
}
Ich habe zuvor die Funktion @ConfigurationProperties verwendet, jedoch ohne in die Karte geladen zu werden. Sie müssen die Annotation @EnableConfigurationProperties verwenden, um diese Funktion zu aktivieren.
Das Coole an dieser Funktion ist, dass Sie Ihre Eigenschaften überprüfen können .
Mit der Annotation @Value
können Sie Werte aus der Eigenschaftendatei in eine Map einfügen.
Die Eigenschaft in der Eigenschaftendatei.
propertyname={key1:'value1',key2:'value2',....}
In deinem Code.
@Value("#{${propertyname}}") private Map<String,String> propertyname;
Beachten Sie den Hashtag als Teil der Anmerkung.
Sie können .properties
als Map in Ihre Klasse einfügen, indem Sie die @Resource
-Annotation verwenden.
Wenn Sie mitXML based configuration
, arbeiten, fügen Sie unten Bean in Ihrer Spring-Konfigurationsdatei hinzu:
<bean id="myProperties" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="location" value="classpath:your.properties"/>
</bean>
Für, basierend auf Anmerkungen:
@Bean(name = "myProperties")
public static PropertiesFactoryBean mapper() {
PropertiesFactoryBean bean = new PropertiesFactoryBean();
bean.setLocation(new ClassPathResource(
"your.properties"));
return bean;
}
Dann können Sie sie in Ihrer Anwendung als Map abholen:
@Resource(name = "myProperties")
private Map<String, String> myProperties;
So haben wir es gemacht. Zwei Beispielklassen wie folgt:
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);
}
...
Um die kafkaConsumer-Konfiguration aus einer Eigenschaftendatei bereitzustellen, können Sie Folgendes verwenden: mapname [Schlüssel] = Wert
//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
Um die kafkaConsumer-Konfiguration aus einer Yaml-Datei bereitzustellen, können Sie "[key]" verwenden: valueIn application.yml-Datei:
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
Um dies mit YAML zum Laufen zu bringen, gehen Sie wie folgt vor:
property-name: '{
key1: "value1",
key2: "value2"
}'
Ich hatte einen einfachen Code für Spring Cloud Config
so was:
In Anwendungseigenschaften
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 : mongoDbUris.entrySet()) {
String k = entry.getKey();
String v = entry.getValue();
MongoTemplate template = new MongoTemplate(new SimpleMongoDbFactory(new MongoClientURI(v)));
mongoTemplates.put(k, template);
}
return mongoTemplates;
}