spring SpEL

spring SpEL

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

概要:

spring SpEL



Spring表达式语言:SpEL

  • Spring表达式语言(简称SpEL):是一个支持执行时查询和操作对象图的强大的表达式语言
  • 语言类似于EL:SpEL使用#{…} 作为定界符,全部在大括号里的字符都将被觉得是SpEL
  • SpEL为bean的属性进行动态赋值提供了便利
  • 通过SpEL能够实现:
    • 通过bean的id对bean进行引用
    • 调用方法以及引用对象中的属性
    • 计算表达式的值
    • 正則表達式的匹配 

SpEL:字面量(仅赋予字面值,使用SpEL的意义不大)
  • 字面量的表示
    • 整数:<property name=”count” value=”#{5}“/>
    • 小数:<property name=”frequency” value=”#{89.7}“/>
    • 科学计算法:<property name=”capacity” value=”#{1e4}“/>
    • String能够使用单引號或者双引號作为字符串的定界符号:<property name=”name” value=”#{‘Chuck’}“/>或<property name=’name’ value=’#{“Chuck”}‘/>
    • Boolean:<property name=”enabled” value=”#{false}“/>

SpEL:引用Bean、属性和方法
  • 引用其它对象:
  • spring SpEL
  • 引用其它对象的属性(用普通的方式做不到的)
  • spring SpEL
  • 调用其它方法,还能够链式操作
  • spring SpEL
  • 调用静态方法或静态属性:通过T()调用一个类的静态方法,它将返回一个Class Object,然后再调用对应的方法或属性:spring SpEL


SpEL支持的运算符号
  • 算数运算符:+,-,*,/,%,^
  • spring SpEL
  • 加号还能够用作字符串连接:
  • spring SpEL
  • 比較运算符:<,>,==,<=,>=,lt,gt,eq,le,ge
  • spring SpEL
  • 逻辑运算符号:and,or,not,|
  • spring SpEL
  • if-else运算符:?:(temary),?:(Elvis)
  • spring SpEL
  • if-else的变体
  • spring SpEL
  • 正則表達式:matches
  • spring SpEL

实例代码具体解释

文件夹结构(用到的包)

spring SpEL

Address.java

package com.coslay.beans.spel;

public class Address {
	private String city;
	private String street;

	public String getCity() {
		return city;
	}

	public void setCity(String city) {
		this.city = city;
	}

	public String getStreet() {
		return street;
	}

	public void setStreet(String street) {
		this.street = street;
	}

	@Override
	public String toString() {
		return "Address [city=" + city + ", street=" + street + "]";
	}

}


Car.java

package com.coslay.beans.spel;

public class Car {
	private String brand;
	private double price;
	// 轮胎的周长
	private double tyrePerimeter;

	public String getBrand() {
		return brand;
	}

	public void setBrand(String brand) {
		this.brand = brand;
	}

	public double getPrice() {
		return price;
	}

	public void setPrice(double price) {
		this.price = price;
	}

	public Car() {
		System.out.println("Car's Constructor...");
	}

	public double getTyrePerimeter() {
		return tyrePerimeter;
	}

	public void setTyrePerimeter(double tyrePerimeter) {
		this.tyrePerimeter = tyrePerimeter;
	}

	@Override
	public String toString() {
		return "Car [brand=" + brand + ", price=" + price + ", tyrePerimeter="
				+ tyrePerimeter + "]";
	}

}

Person.java

package com.coslay.beans.spel;

public class Person {
	private String name;
	private Car car;
	// 引用address bean的city属性
	private String city;
	// 依据car的price确定info:car的price》=300000:金额
	// 否则为:白领
	private String info;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Car getCar() {
		return car;
	}

	public void setCar(Car car) {
		this.car = car;
	}

	public String getCity() {
		return city;
	}

	public void setCity(String city) {
		this.city = city;
	}

	public String getInfo() {
		return info;
	}

	public void setInfo(String info) {
		this.info = info;
	}

	@Override
	public String toString() {
		return "Person [name=" + name + ", car=" + car + ", city=" + city
				+ ", info=" + info + "]";
	}

}

Main.java

package com.coslay.beans.spel;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Main {
	public static void main(String[] args) {
		ApplicationContext ctx = new ClassPathXmlApplicationContext(
				"beans-spel.xml");

		Address address = (Address) ctx.getBean("address");
		System.out.println(address);
		
		Car car = (Car) ctx.getBean("car");
		System.out.println(car);
		
		Person person = (Person) ctx.getBean("person");
		System.out.println(person);
	}
}


beans-spel.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

	
	<bean id="address" class="com.coslay.beans.spel.Address">
		<!-- 使用spel为属性赋一个字面值 -->
		<property name="city" value="#{'beijint'}"></property>
		<property name="street" value="WuDaoKou"></property>
	</bean> 
	
	<bean id="car" class="com.coslay.beans.spel.Car">
		<property name="brand" value="Audi"></property>
		<property name="price" value="5000000"></property>
		<!-- 使用SpEL引用类的静态属性 -->
		<property name="tyrePerimeter" value="#{T(java.lang.Math).PI * 80}"></property>
	</bean>
	
	<bean id="person" class="com.coslay.beans.spel.Person">
		<!-- 使用 SpEL来引用其它的Bean -->
		<property name="car" value="#{car}"></property>
		<!-- 使用SpEL来引用其它的Bean的属性 -->
		<property name="city" value="#{address.city}"></property>
		<!-- SpEL中使用运算符 -->
		<property name="info" value="#{car.price > 300000 ? '金领' : '白领'}"></property>
		<property name="name" value="Tom"></property>
	</bean>
</beans>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118481.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux ext4无法使用超过16T磁盘的解决办法

    linux ext4无法使用超过16T磁盘的解决办法

    2022年3月11日
    43
  • break 和continue 区别以及用法。

    break 和continue 区别以及用法。今天我们来介绍一下循环里的break和continue的用法以及区别我们大家先记住一句话:break再循环中的作用是跳出一个循环或者结束一个循环接下来我们来写一个题目来实现一下这个break的功能。题目:从100打印到0是7的倍数并且求出最大值是多少publicclassDemo{publicstaticvoidmain(String[]agrs){for(

    2022年6月10日
    41
  • 【STM32】HAL库 STM32CubeMX系列学习教程[通俗易懂]

    【STM32】HAL库 STM32CubeMX系列学习教程[通俗易懂]STM32CubeMX简介1、STM32CubeMX是ST意法半导体近几年来大力推荐的STM32芯片图形化配置工具,目的就是为了方便开发者,允许用户使用图形化向导生成C初始化代码,可以大大减轻开发工作,时间和费用,提高开发效率。STM32CubeMX几乎覆盖了STM32全系列芯片。在CubeMX上,通过傻瓜化的操作便能实现相关配置,最终能够生成C语言代码,支持多种工具…

    2022年6月13日
    37
  • 简易http接口实现[通俗易懂]

    简易http接口实现[通俗易懂]http接口是什么,我一直没找到比较明确的定义(如果有哪位可以提点一下,我将非常感谢),今天就自己来总结一下吧。个人认为,http接口就是一种基于http服务的api,是系统之间交互的一种约定,所谓的webservice其实也就是一种http接口,只不过它是比较规范的、通用的。       http接口有什么用,个人体会是,http接口最主要的作用是能够较好地解决不同系统(可能是功能不同、

    2022年5月23日
    58
  • Oracle修改用户密码过期时间「建议收藏」

    Oracle修改用户密码过期时间「建议收藏」部署的Web应用突然无法登录系统,后台尝试重新启动看能不能恢复,发现启动时在数据库连接池部分报错,怀疑无法连接数据库。使用的是oracle数据库,通过plsql发现也无法连接,从报错可以看出应该是用户密码过期了,因此需要要修改用户密码。通过sysdba身份登录,修改用户密码:alteruserusernameidentifiedbypassword;为了避免密码再次过期,打算设…

    2022年7月28日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号