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格式
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Python數據類型最全知識總結
- 基於springBoot配置文件properties和yml中數組的寫法
- SpringBoot中的@Value註解用法
- springboot application.properties 文件註入數組方式
- PHP中token的生成案例