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

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐