Spring 使用介绍(四)—— SpEL

一、SpEL介绍

Spring表达式语言全称为“Spring Expression Language”,缩写为“SpEL”,可在运行时构建复杂表达式

使用步骤:

1)创建解析器:ExpressionParser接口表示解析器,SpelExpressionParser提供默认实现

2)解析表达式:使用ExpressionParser.parseExpression()方法,将表达式解析为Expression对象

3)构造上下文:用于定义变量,由EvaluationContext接口表示,StandardEvaluationContext提供默认实现

4)求值:使用Expression.getValue()方法,根据上下文求得表达式值

@Test
public void testSpel() {
    // spel解析器
    ExpressionParser parser = new SpelExpressionParser();
    
    // spel语句
    Expression expression1 = parser.parseExpression("895");
    Assert.assertTrue(895 == expression1.getValue(int.class));
    
    // spel语句
    Expression expression2 = parser.parseExpression("'hello'");
    Assert.assertTrue(StringUtils.equals("hello", expression2.getValue(String.class)));
    
    // spel上下文
    EvaluationContext context = new StandardEvaluationContext();
    context.setVariable("end", "zz");
    Expression expression3 = parser.parseExpression("('yy' + 'pp').concat(#end)");
    Assert.assertTrue(StringUtils.equals("yyppzz", expression3.getValue(context, String.class)));
}

二、在bean定义中使用SpEL

ApplicationContext实现默认支持SpEL,在Bean定义时注入时,使用“#{SpEL表达式}”表示

1)xml方式

<bean id="str1" class="java.lang.String">
    <constructor-arg index="0" value="uouu"/>  
</bean>

<bean id="propBean" class="java.lang.String">
    <constructor-arg index="0" value="#{str1}"/>
</bean>
@Test
public void testSpel2() {
    ApplicationContext context = new ClassPathXmlApplicationContext("spring-context.xml");
    String prop = context.getBean("propBean", String.class);
    Assert.assertTrue(StringUtils.equals("uouu", prop));
}

2)注解方式

public class Hello {
    @Value("#{str1}")
    private String password;

    public String getPassword() {
        return password;
    }
}
<!-- 定义bean -->
<bean class="cn.matt.spel.Hello"></bean>

<!-- 开启注解 -->
<context:annotation-config />
@Test
public void testSpel3() {
    ApplicationContext context = new ClassPathXmlApplicationContext("spring-context.xml");
    Hello hello = context.getBean(Hello.class);
    Assert.assertTrue(StringUtils.equals("uouu", hello.getPassword()));
}

三、属性文件的使用

spring属性文件配置方式:

<!-- 全写方式 -->
<bean id="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="locations">
        <list>
            <value>jdbc1.properties</value>
            <value>jdbc2.properties</value>
        </list>
    </property>
</bean>

上述配置的简写方式:

<!-- 简写方式 -->
<context:property-placeholder location="classpath:jdbc1.properties,classpath:jdbc2.properties"/>

使用实例如下:

# jdbc1.properties 文件
username=root
password=root
# jdbc2.properties 文件
username=admin
password=admin
<bean id="propBean" class="java.lang.String">
    <constructor-arg index="0" value="${password}"/>  
</bean>
@Test
public void testSpel2() {
    ApplicationContext context = new ClassPathXmlApplicationContext("spring-context.xml");
    String prop = context.getBean("propBean", String.class);
    Assert.assertTrue(StringUtils.equals("admin", prop));
}

注:

1)spring使用“${属性名}”表示属性值,与SpEL使用"#{SpEL表达式}"不同

2)在多个属性文件中存在相同的属性值时,后者覆盖前者

3)支持注解方式,使用方式与SpEL注解类似,如:@Value("${password}")

参考:

第五章 Spring表达式语言 之 5.1 概述 5.2 SpEL基础 ——跟我学spring3

第五章 Spring表达式语言 之 5.3 SpEL语法 ——跟我学spring3

第五章 Spring表达式语言 之 5.4在Bean定义中使用EL—跟我学spring3

spring <context:property-placeholder>使用说明

使用<context:property-placeholder>标签导入多个properties文件

猜你喜欢

转载自www.cnblogs.com/MattCheng/p/8882394.html