SpEL(SpEL)이란 무엇인가요?
Spring 3에서는 Spring 표현식 언어인 SpringEL이 도입되었습니다. SpEL은 Bean을 어셈블하는 강력하고 간결한 방법입니다.
SpringEL은 런타임 중에 실행되는 표현식을 통해 속성이나 생성자에 값을 어셈블할 수 있습니다.
# 配置文件 com: codecoord: el: num: 1001 name: el language: - java - spring - mysql - linux # 逗号分隔可以注入列表 language02: java,spring,mysql,linux
사용 간단한 값을 삽입하는 EL
/** * 注入简单值,直接注入不使用EL,EL不支持直接指定常量 * 直接在EL中指定的常量会当做配置处理,和直接赋值等价 */ @Value("1432516744") private Integer no;
/** * 注入整型属性值 */ @Value("${com.codecoord.el.num}") private Integer num; /** * 注入字符属性值 */ @Value("${com.codecoord.el.name}") private String name;
Inject 기본값
/** * 注入字符不存在属性值并指定默认值,默认值使用过冒号分隔 : * 注入常量其实就可以指定一个不存在的配置然后使用默认值,此处skill的值为java */ @Value("${com.codecoord.el.skill:java}") private String skill;
쉼표로 구분된 구성을 식별할 수 있으며 스프링 기본값은 구분된
// 错误写法:不支持直接注入yml列表格式语法列表 @Value("${com.codecoord.el.language}") private List<String> listLanguage; @Value("${com.codecoord.el.language}") private String[] strLanguage;
/** * 支持,分隔的注入列表 */ @Value("${com.codecoord.el.language02}") private List<String> listLanguage02; @Value("${com.codecoord.el.language02}") private String[] strLanguage02;
server: port: 8888 com: codecoord: el: num: 1001 name: el language: - java - spring - mysql - linux # 逗号分隔可以注入列表 language02: java,spring,mysql,linux
import lombok.Data; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import java.util.List; @Data @Component public class ElConfig { /** * 注入简单值,直接注入不使用EL,EL不支持直接指定常量 * 直接在EL中指定的常量会当做配置处理,和直接赋值等价 */ @Value("1432516744") private Integer no; /** * 注入整型属性值 */ @Value("${com.codecoord.el.num}") private Integer num; /** * 注入字符属性值 */ @Value("${com.codecoord.el.name}") private String name; /** * 注入字符不存在属性值并指定默认值,默认值使用过冒号分隔 : * 注入常量其实就可以指定一个不存在的配置然后使用默认值,此处skill的值为java */ @Value("${com.codecoord.el.skill:java}") private String skill; /// 不支持直接注入列表 /*@Value("${com.codecoord.el.language}") private List<String> listLanguage; @Value("${com.codecoord.el.language}") private String[] strLanguage;*/ /** * 支持,分隔的注入列表 */ @Value("${com.codecoord.el.language02}") private List<String> listLanguage02; @Value("${com.codecoord.el.language02}") private String[] strLanguage02; }구성 클래스를 컨트롤러에 삽입한 다음 인터페이스 테스트 결과는 다음과 같습니다
{ "no": 1432516744, "num": 1001, "name": "el", "skill": "java", "listLanguage02": [ "java", "spring", "mysql", "linux" ], "strLanguage02": [ "java", "spring", "mysql", "linux" ] }3. SpringEL-기본 사용법1. SpEL을 사용하여 간단한 값을 주입하는 것은 기본적으로 일반 EL 주입을 사용하는 것과 동일합니다
2. SpEl 주입 맵
구성 파일이 필요합니다. 그렇지 않으면 삽입이 실패합니다.
# SpEl spEl: mapInject: "{"name": "SpEl", "website": "http://www.codeocord.com"}"
Java 클래스에서 먼저 ${spEl.mapInject}를 사용하여 문자열 값을 삽입하고 #{}를 구문 분석합니다. map
@Value("#{${spEl.mapInject}}") private Map<String, String> mapInject;3으로 변환합니다. SpEl은 list
spEl: listInject: "44#11#99#100"
팁: 빈 문자열을 기본값으로 지정하면 됩니다
@Value("#{"${spEl.listInject:}".split("#")}") private List<String> listInject;
위 주입은 모두 동적 주입이라고 하는 Spring 컨테이너의 정보 주입을 지원합니다. . 동적 주입 클래스는 다음과 같습니다
import lombok.AllArgsConstructor; import lombok.Data; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Component @Data public class SpElConstant { private String name = "SpElConstant-name"; private String nickname = "tianxin"; private int num = 100; private List<String> product = new ArrayList<String>() {{ add("huaweiMate30Pro"); add("xiaomi10x5g"); }}; private Map<String, String> productMap = new HashMap<String, String>() {{ put("huaweiMate30Pro", "5999"); put("xiaomi10x5g", "4999"); }}; private List<City> cityList = new ArrayList<City>() {{ add(new City("深圳", 1000L)); add(new City("杭州", 2000L)); add(new City("贵阳", 900L)); }}; public String showProperty() { return "showProperty-无参数"; } public String showProperty(String name) { return "showProperty-" + name; } @Data @AllArgsConstructor static class City { private String name; private long population; } }
Static 메서드: @Value("#{T(package.ClassName).ConstFieldName")
연산자 작업 지원
import lombok.Data; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import java.util.List; import java.util.Map; @Data @Component public class SpElConfig { /// 不支持直接注入配置文件值 /*@Value("#{com.codecoord.el.num}") private Integer num;*/ /** * 对象注入 */ @Value("#{spElConstant}") private SpElConstant spElConstant; /** * 注入ID为spElConstant Bean中的STR常量/变量 */ @Value("#{spElConstant.name}") private String name; /** * 调用无参方法 */ @Value("#{spElConstant.showProperty()}") private String method1; /** * 有参接收字符串的方法 */ @Value("#{spElConstant.showProperty("Hell SpringEL")}") private String method2; /** * 方法返回的String为大写 */ @Value("#{spElConstant.showProperty().toUpperCase()}") private String method3; /** * 若使用method3这种方式,若果showProperty返回为null * 将会抛出NullPointerException,可以使用以下方式避免 * 使用?.符号代表若然左边的值为null,将不执行右边方法 */ @Value("#{spElConstant.showProperty()?.toUpperCase()}") private String method4; /** * 注入math常量 */ @Value("#{T(java.lang.Math).PI}") private double pi; /** * 用random方法获取返回值 */ @Value("#{T(java.lang.Math).random()}") private double random; /** * 获取文件路径符号 */ @Value("#{T(java.io.File).separator}") private String separator; /** * 拼接字符串 */ @Value("#{spElConstant.nickname + " " + spElConstant.name}") private String concatString; /** * 对数字类型进行运算,spElConstant拥有num属性 */ @Value("#{3 * T(java.lang.Math).PI + spElConstant.num}") private double operation; /** * 进行逻辑运算 */ @Value("#{spElConstant.num > 100 and spElConstant.num <= 200}") private boolean logicOperation; /** * 进行或非逻辑操作 */ @Value("#{not (spElConstant.num == 100) or spElConstant.num <= 200}") private boolean logicOperation2; /** * 使用三元运算符 */ @Value("#{spElConstant.num > 100 ? spElConstant.num : spElConstant.num + 100}") private Integer logicOperation3; /** * 获取下标为0的元素 */ @Value("#{spElConstant.product[0]}") private String str; /** * 获取下标为0元素的大写形式 */ @Value("#{spElConstant.product[0]?.toUpperCase()}") private String upperStr; /** * 获取map中key为hello的value */ @Value("#{spElConstant.productMap["hello"]}") private String mapValue; /** * 根据product下标为0元素作为key获取testMap的value */ @Value("#{spElConstant.productMap[spElConstant.product[0]]}") private String mapStrByproduct; /** * 注入人口大于等于1000人口的城市 */ @Value("#{spElConstant.cityList.?[population >= 1000]}") private List<SpElConstant.City> cityList; /** * 注入人口等于900人口的城市 */ @Value("#{spElConstant.cityList.?[population == 900]}") private SpElConstant.City city; /** * 注入人口大于等于1000人口的城市,且只保留城市名称 */ @Value("#{spElConstant.cityList.?[population >= 1000].![name]}") private List<String> cityName; }삽입 결과
{ "spElConstant": { "name": "SpElConstant-name", "nickname": "tianxin", "num": 100, "product": [ "huaweiMate30Pro", "xiaomi10x5g" ], "productMap": { "xiaomi10x5g": "4999", "huaweiMate30Pro": "5999" }, "cityList": [ { "name": "深圳", "population": 1000 }, { "name": "杭州", "population": 2000 }, { "name": "贵阳", "population": 900 } ] }, "name": "SpElConstant-name", "method1": "showProperty-无参数", "method2": "showProperty-Hell SpringEL", "method3": "SHOWPROPERTY-无参数", "method4": "SHOWPROPERTY-无参数", "pi": 3.141592653589793, "random": 0.19997238292235787, "separator": "", "concatString": "tianxin SpElConstant-name", "operation": 109.42477796076938, "logicOperation": false, "logicOperation2": true, "logicOperation3": 200, "str": "huaweiMate30Pro", "upperStr": "HUAWEIMATE30PRO", "mapValue": null, "mapStrByproduct": "5999", "cityList": [ { "name": "深圳", "population": 1000 }, { "name": "杭州", "population": 2000 } ], "city": { "name": "贵阳", "population": 900 }, "cityName": [ "深圳", "杭州" ] }
<!-- 首先通过applicaContext.xml中<util:properties>增加properties文件 --> <!-- 注意需要引入Spring的util schemea命名空间和注意id属性,id属性将在SpringEL中使用 --> <util:properties id="db" location="classpath:application.properties"/>
public class TestSpringEL { // 注意db为xml文件中声明的id @Value("#{db["jdbc.url"]}") private String propertiesValue; }SpringEL은 사용될 때 문자열일 뿐입니다. 디버깅 및 문제 해결이 쉽지 않습니다. 테스트를 위해 구문을 확인할 수 있는 IDE가 없습니다. 오류 발생 시 감지하기 어렵기 때문에 SpringEL을 통해 복잡한 표현식을 삽입하는 것은 권장되지 않습니다. 필요한 경우가 아니면 SpEl의 복잡한 주입을 사용하지 않는 것이 좋습니다. 문제 해결에는 명확하고 읽기 쉬운 코드가 더 중요하고 도움이 됩니다.
org.springframework.boot.context.properties.ConfigurationProperties구성 클래스
user: id: ${random.uuid} name: autowire address: unknown website: www.codecoord.com age: ${random.int}자동 속성 주입 클래스 프런트 엔드를 접두사를 통해 사용자로 지정하면 이름에 따라 사용자 뒤의 유형이 주입됩니다 주의하세요 setter 메소드를 제공해야 합니다
import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Component @ConfigurationProperties(prefix = "user") @Data public class UserConfig { private String id; private String name; private String address; private String website; private Integer age; }
可以通过@EnableConfigurationProperties(value = UserConfig.class)将UserConfig再次强制注入,问题出现在如果UserConfig为第三方jar包内的配置类,则可能出现属性没有注入情况,所以可以指定注入
위 내용은 SpringBoot SpringEL 표현식을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!