1、SpEL引用
SpEL的基本格式是 #{SpEL expression} 。
SpEL可以引用一个Bean、Bean属性和Bean方法,通过点符号(.)实现。
通过注解的形式:
@Component("customerBean")
public class Customer {
@Value("#{addressBean}") //引用Bean
private Address address;
@Value("#{addressBean.country}") //引用Bean属性
private String country;
@Value("#{addressBean.getFullAddress('ground')}") //引用Bean方法
private String fullAddress;
//getter and setter methods
}
@Component("addressBean")
public class Address {
@Value(#{'xianlin'.toUpperCase()}) //普通方法也可以引用
private String street;
@Value("CN")
private String country;
public String getFullAddress(String prefix) {
return prefix + " : " + street + " " + country;
}
//getter and setter methods
}
使用注解形式不要忘了启动自动组件扫描:
通过XML文件形式:
2、SpEL运算符
SpEL支持大多数标准的数学、逻辑和关系运算符。
关系运算符 : 等于 (==, eq), 不等于 (!=, ne), 小于 (, gt), 和大于或等于 (>=, ge).
逻辑运算符 : 且(and), 或(or), 非 (!).
数学运算符 : 加法(+), 减法 (-), 乘法 (*), 除法(/), 除模(%) 和指数幂 (^).
三元运算符 : 条件?true:false
在SpEL中使用运算符和平常使用没什么区别,比如:
@Value("#{itemBean.num < 100 ? true : false}")
private boolean warning;
3、SpEL从集合中取值
//get map whete key = 'MapA'
@Value("#{testBean.map['MapA']}")
private String mapA;
//get first value from list, list is 0-based.
@Value("#{testBean.list[0]}")
private String list;
4、SpEL正则表达式
SpEL可以使用正则表达式,通过一个关键字”matches"实现。
// 邮箱格式的正则表达式
String emailRegEx = "^[_A-Za-z0-9-]+(\\.[_A-Za-z0-9-]+)" +
"*@[A-Za-z0-9]+(\\.[A-Za-z0-9]+)*(\\.[A-Za-z]{2,})$";
// 正则表达式判断是否是一个合法的邮箱格式
@Value("#{emailBean.emailAddress matches customerBean.emailRegEx}")
private boolean validEmail;
// 正则表达式判断是否是数字
@Value("#{ ('100' matches '\\d+') == true ? " +
"'yes this is digit' : 'No this is not a digit' }")
private String msg;
转载至链接:https://my.oschina.net/HuoQibin/blog/1834927