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<String, String> topLinks; @Value("#{'${blog-list}'.split(',')}") private List<Integer> 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<String> list; @Value("#{${maps}}") private Map<String,String> maps; @Value("#{${redirectUrl}}") private Map<String,String> 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<String,String>
因为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 Web项目spring配置文件随服务器启动时自动加载
这篇文章主要介绍了Spring Web项目spring配置文件随服务器启动时自动加载,加载spring的配置文件,并且只加载一次,从而提高程序效率。具体内容详情大家通过本文一起学习吧2018-01-01
最新评论