Spring properties to map

本文介绍如何使用Spring将properties文件以Map形式注入bean,并演示如何通过自定义PropertiesFactoryBean实现更复杂的转换逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring properties to map

一个key-value形式的properties文件 以Map的形式注入到Spring的bean中

properties文件形式

RF09001=fooService#method1#name,phone

spring 配置

    <bean id="noMethodMap" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
        <property name="location" value="classpath:foo.properties"/>
    </bean>

注入到Bean中

    @Resource(name="noMethodMap")
    private Map<String, String> noMethodMap;

其他

如何定位注入源码

修改为一个不存在的资源名称

@Resource(name="nonexist")

此时启动会报错

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'nonexist' available
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanDefinition(DefaultListableBeanFactory.java:687)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getMergedLocalBeanDefinition(AbstractBeanFactory.java:1207)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:284)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202)
    at org.springframework.context.annotation.CommonAnnotationBeanPostProcessor.autowireResource(CommonAnnotationBeanPostProcessor.java:522)

可知是在哪里注入的了

在哪里将PropertiesFactoryBean转成Map

同样的处理方式 将注入变量修改成一个错误的类型 查看错误信息即可

private String noMethodMap; // map --> String

启动会报错

Caused by: org.springframework.beans.factory.BeanNotOfRequiredTypeException: Bean named 'noMethodMap' is expected to be of type 'java.lang.String' but was actually of type 'java.util.Properties'
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:378)

就知道是在哪里进行类型转换的了

如果想对properties-->Map做一下自定义的处理呢

如RF09001-RF09010对应的都是同一个value

RF09001-RF09003=fooService#method1#name,phone

但是想Map中的实际形式为

RF09001=fooService#method1#name,phone
RF09002=fooService#method1#name,phone
RF09003=fooService#method1#name,phone

继承PropertiesFactoryBean 覆盖createProperties即可

public class MyPropertiesFactoryBean extends PropertiesFactoryBean{
    @Override
    protected Properties createProperties() throws IOException {
        Properties properties = super.createProperties();
        Enumeration<String> propertyNames = (Enumeration<String>) properties.propertyNames();
        while(propertyNames.hasMoreElements()){
            String name = propertyNames.nextElement();
            if(name.matches("\\w+-\\w+")){
                String rawName = name;
                String[] split = rawName.split("-");
                Integer start = Integer.valueOf(split[0].substring(2));
                Integer end = Integer.valueOf(split[1].substring(2));
                for (int i = start; i <= end; i++) {
                    properties.setProperty("RF" + i, properties.getProperty(rawName));
                }
            }
        }
        return properties;
    }

spring配置改成

<bean id="noMethodMap" class="com.foo.app.util.MyPropertiesFactoryBean">
### 如何在 Nacos 中通过 .properties 文件配置 Map 类型的数据 为了在 Nacos 中使用 `.properties` 文件来配置 `Map` 集合,可以采用键值对的形式表示映射关系。具体来说,可以通过定义一系列具有相同前缀的属性名,并将其对应的值作为键值对存储。 #### 定义 Properties 文件中的 Map 结构 假设要配置名为 `my.map` 的 `Map<String, String>` 对象,则可以在 `application.properties` 或者其他自定义命名的空间中加入如下形式的内容: ```properties # my.map.key1=value1 表示 key 为 "key1", value 为 "value1" my.map.key1=value1 my.map.key2=value2 my.map.key3=value3 ``` 上述方式适用于简单的字符串到字符串之间的映射[^1]。 对于更复杂的场景,比如当 Value 是对象时,可考虑 JSON 字符串化的方式保存复杂结构的信息。此时需要额外引入 Jackson 库或者其他序列化工具包来进行转换处理。 如果希望将这些配置项加载成 Java 程序内的实际 `Map` 实例,那么还需要编写相应的解析逻辑或者利用 Spring Boot 提供的功能自动装配该类别的 Bean。 例如,在应用程序启动过程中读取并注入此配置至某个服务组件内: ```java import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.PropertySource; import org.springframework.stereotype.Component; import javax.annotation.PostConstruct; import java.util.HashMap; import java.util.Map; @Component @PropertySource(value = {"classpath:application.properties"}) public class MyConfig { @Value("#{${my.map}}") // 使用 SpEL 解析 map 属性 private Map<String, Object> myMap = new HashMap<>(); public void setMyMap(Map<String, Object> myMap) { this.myMap.putAll(myMap); } @PostConstruct public void init() { System.out.println("Loaded configuration from properties file:"); for (String key : myMap.keySet()) { System.out.printf("%s -> %s%n", key, myMap.get(key)); } } } ``` 这段代码展示了如何借助于 Spring Expression Language(SpEL)语法获取带有特定前缀的所有属性条目,并最终形成一个完整的 `HashMap` 实例[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值