1,解析List:
testList:
list: aaa,bbb,ccc
@Value("#{'${testList.list}'.split(',')}")
private List<String> testList;
//加上默认值(多了一个 : 号,冒号后的值表示当 key 不存在时候使用的默认值,使用默认值时数组的 length = 0。),避免不配置这个 key 时候程序报错:
@Value("#{'${testList.list:}'.split(',')}")
private List<String> testList;
//但是这样有个问题,当不配置该 key 值,默认值会为空串,它的 length = 1(不同于数组,length = 0),这样解析出来 list 的元素个数就不是空了。
//这个问题比较严重,因为它会导致代码中的判空逻辑执行错误。这个问题也是可以解决的,在 split() 之前判断下是否为空即可。
@Value("#{'${testList.list:}'.empty ? null : '${testList.list:}'.split(',')}")
private List<String> testList;
2,解析Set
testSet:
set: 111,222,333,111
@Value("#{'${testSet.set:}'.empty ? null : '${testSet.set:}'.split(',')}") private Set<Integer> testSet;
3,解析Map
testMap:
map1: '{"name": "zhangsan", "sex": "male"}'
map2: '{"math": "90", "english": "85"}'
@Value("#{${test.map1}}") private Map<String,String> map1; @Value("#{${test.map2}}") private Map<String,Integer> map2;
注意,使用这种方式,必须得在配置文件中配置该 key 及其 value。我在网上找了许多资料,都没找到利用 EL 表达式支持不配置 key/value 的写法。
如果你真的很需要这个功能,就得自己写解析方法了
(1) 自定义解析方法
public class MapDecoder { public static Map<String, String> decodeMap(String value) { try { return JSONObject.parseObject(value, new TypeReference<Map<String, String>>(){}); } catch (Exception e) { return null; } } }
(2) 在程序中指定解析方法
@Value("#{T(com.github.jitwxs.demo.MapDecoder).decodeMap('${test.map1:}')}") private Map<String, String> map1; @Value("#{T(com.github.jitwxs.demo.MapDecoder).decodeMap('${test.map2:}')}") private Map<String, String> map2;
特别注意的是 @Value
注解不能和 @AllArgsConstructor
注解同时使用,否则会报错
转自:https://jitwxs.cn/d6d760c4.html