Spring中@Value讀取properties作為map或list的操作
blog-top-links={home:'/home'}blog-list=1,2,3
map的寫法和json差不多,但是應(yīng)該不支持嵌套,沒有嘗試。
key加不加引號(hào)都可以,value加雙引號(hào)單引號(hào)都可以,但是當(dāng)key中有”-“時(shí)就必須加引號(hào),例如key為:about-me時(shí),就必須加引號(hào)否則解析失敗
list的寫法和數(shù)組差不多,可以自定義分隔符,在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 實(shí)際不能省略,否則雖然能啟動(dòng)不報(bào)錯(cuò),但是無法獲取到值}獲取map的方法:
@Value('#{${blog-top-links}}')
使用#{${key}}的方式
獲取list的方法:@Value('#{’${blog-list}’.split(’,’)}')
使用@Value(“#{‘${key}’.split(‘,’)}”)的方式
split(‘,’)只以’,’為分隔符,也可以換成別的
當(dāng)配置文件中沒有key時(shí),也可以使用key:default_value的方法設(shè)置默認(rèn)值
@Value注入map、Listyaml格式@Value('#{’${list}’.split(’,’)}')private List<String> list; @Value('#{${maps}}') private Map<String,String> maps;@Value('#{${redirectUrl}}')private Map<String,String> redirectUrl;配置文件
list: topic1,topic2,topic3maps: '{key1: ’value1’, key2: ’value2’}'redirectUrl: '{sso_client_id: ’${id}’,sso_client_secret: ’${secret}’,redirect_url: ’${client.main.url.default}’}'
注意上面的map解析中,一定要用'“把map所對(duì)應(yīng)的value包起來,要不然解析會(huì)失敗,導(dǎo)致不能轉(zhuǎn)成 Map<String,String>
因?yàn)閥aml語法中如果一個(gè)值以 “{” 開頭, YAML 將認(rèn)為它是一個(gè)字典, 所以我們必須引用它必須用”'
http://www.ansible.com.cn/docs/YAMLSyntax.html
yaml寫法注意:字符串默認(rèn)不用加上單引號(hào)或者雙引號(hào)
“”:雙引號(hào);不會(huì)轉(zhuǎn)義字符串里面的特殊字符;特殊字符會(huì)作為本身想表示的意思
name: “zhangsan n lisi”:輸出;zhangsan 換行 lisi
‘’:單引號(hào);會(huì)轉(zhuǎn)義特殊字符,特殊字符最終只是一個(gè)普通的字符串?dāng)?shù)據(jù)
name: ‘zhangsan n lisi’:輸出;zhangsan n lisi
properties格式
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. el-input無法輸入的問題和表單驗(yàn)證失敗問題解決2. Vue中原生template標(biāo)簽失效如何解決3. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)4. XML 非法字符(轉(zhuǎn)義字符)5. 不要在HTML中濫用div6. 父div高度不能自適應(yīng)子div高度的解決方案7. XML入門的常見問題(三)8. vue跳轉(zhuǎn)頁面常用的幾種方法匯總9. Jquery使用原生AJAX方法請(qǐng)求數(shù)據(jù)10. js開發(fā)中的頁面、屏幕、瀏覽器的位置原理(高度寬度)說明講解(附圖)
