Spring中@Value读取properties作为map或list的操作

Spring读取properties作为map:

properties文件中:

blog-top-links={home:"/home"}
blog-list=1,2,3

map的写法和json差不多,但是应该不支持嵌套,没有尝试。

key加不加引号都可以,value加双引号单引号都可以,但是当key中有”-“时就必须加引号,例如key为:about-me时,就必须加引号否则解析失败

list的写法和数组差不多,可以自定义分隔符,在java中分割即可

配置类中:

@Component
@ConfigurationProperties
@PropertySource("properties文件路径")
public class BlogConfig {
    @Value("#{${blog-top-links}}")
    private Map topLinks;
    @Value("#{'${blog-list}'.split(',')}")
    private List list;
    ...
    省略get/set
    实际不能省略,否则虽然能启动不报错,但是无法获取到值
}

获取map的方法:

@Value("#{${blog-top-links}}")

使用#{${key}}的方式

获取list的方法:

@Value("#{'${blog-list}'.split(',')}")

使用@Value(“#{‘${key}'.split(‘,')}”)的方式

split(‘,')只以','为分隔符,也可以换成别的

当配置文件中没有key时,也可以使用key:default_value的方法设置默认值

@Value注入map、List

yaml格式

@Value("#{'${list}'.split(',')}")
private List list;
 
@Value("#{${maps}}")  
private Map maps;

@Value("#{${redirectUrl}}")
private Map redirectUrl;

配置文件

list: topic1,topic2,topic3
maps: "{key1: 'value1', key2: 'value2'}"
redirectUrl: "{sso_client_id: '${id}',sso_client_secret: '${secret}',redirect_url: '${client.main.url.default}'}"

注意上面的map解析中,一定要用"“把map所对应的value包起来,要不然解析会失败,导致不能转成 Map

因为yaml语法中如果一个值以 “{” 开头, YAML 将认为它是一个字典, 所以我们必须引用它必须用”"

http://www.ansible.com.cn/docs/YAMLSyntax.html

yaml写法注意:

字符串默认不用加上单引号或者双引号

“”:双引号;不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思

name: “zhangsan \n lisi”:输出;zhangsan 换行 lisi

‘':单引号;会转义特殊字符,特殊字符最终只是一个普通的字符串数据

name: ‘zhangsan \n lisi':输出;zhangsan \n lisi

properties格式

Spring中@Value读取properties作为map或list的操作_第1张图片

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(Spring中@Value读取properties作为map或list的操作)