Spring EL表达式和资源调用

时间:2023-03-10 05:26:02
Spring EL表达式和资源调用

Spring EL表达式

    Spring EL-Spring表达式语言,支持在xml和注解中使用表达式,类似于在jsp的EL表达式语言。

    Spring 开发中经常涉及调用各种资源的情况,包含普通文件、网址、配置文件、系统环境变量等,我们可以使用Spring的表达式语言实现资源的注入。

    Spring主要在注解@Value的参数中使用表达式语言。

  • 注入普通字符
  • 注入操作系统属性
  • 注入表达式运算结果
  • 注入其他Bean的属性
  • 注入文件内容
  • 注入网址内容
  • 注入属性文件

示例

  1. 在类路径下新建一个text.txt文件,内容随意,在类路径下新建一个test.propertes文件,内容如下:
book.author=xxx
book.name= spring boot
  1. 编写一个需要注入的Bean
	@Service
public class DemoService {
@Value("其他类中的属性") // 此处为注入普通字符串
private String another; public String getAnother(){
return another;
} public void setAnother(String anther){
this.another = anther;
}
}
  1. 配置类
	@Configuration
@ComponentScan("xxx.xx.xx")
@PropertySource("classpath:test.properties")
public class ELConfig { @Value("I Love You !") // 1
private String normal; @Value("#{systemProperties['os.name']}") // 2
private String osName; @Value("#{T(java.lang.Math).random() * 100.0}") // 3
private double randomNumber; @Value("#{demoService.another}") // 4
private String fromAnother; @Value("classpath:test.txt") // 5
private Resource testFile; @Value("http://www.baidu.com") // 6
private Resource testUrl; @Value("${book.name}")
private String bookName; @Bean // 7
public static PropertySourcesPlaceholderConfigurer propertyConfigure(){
return new PropertySourcesPlaceholderConfigurer();
} ...
setter and getter function
...
}
代码解释
  1. 注入普通字符串

  2. 注入操作系统属性

  3. 注入表达式结果

  4. 注入其他Bean属性

  5. 注入文件资源,文件资源可以是classpath路径下的也可以是系统文件目录下的

  6. 注入网址资源

  7. 注入配置文件中的资源,配置文件使用@PropertySource注解在类上标注

    注入配置件需要使用@PropertySource指定文件地址,若使用@Value注入,则要配置一个PropertySourcesPlaceholderConfigurer的Bean,@Value("${book.name}")使用的是"$"而不是"#"

Profile

    Profile为不同环境下使用不同的配置提供了支持(开发环境和生成环境)

  1. 通过设定Environment的ActiveProfiles类设定当前context需要使用的配置。在开发中使用@Profile注解类或者方法,达到不同情况下选择实例化不同的Bean。
  2. 通过设定JVM的spring.profiles.active参数来设计配置环境。
  3. Web项目设置在Servlet的context parameter中。
	<-- Servlet 2.5及以下 -->
<serlvet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>spring.profiles.active</param-name>
<param-value>prod</param-value>
</init-param>
</servlet>
	// servlet 3.0 以上
public class WebInit implements WebApplicationInitializer {
public void onStartup(ServletContext container) throws ServletException {
container.setInitParameter("spring.profiles.default", "dev");
}
}

示例

  1. 示例Bean
	public class DemoBean {
private String content;
public DemoBean(String content){
this.content = content;
}
public String getContent(){
return content;
}
}
  1. Profile配置
	@Configuration
public class ProfileConfig {
@Bean
@Profile("dev") // 1
public DemoBean devDemoBean(){
return new DemoBean("from development profile");
} @Bean
@Profile("prod") // 2
public DemoBean prodDemoBean() {
return new DemoBean("from production profile");
}
}
代码解释
  1. profile为dev时示例化devDemoBean

  2. profile为prod时实例化为prodDemoBean

  3. 运行

public class Main{
public static void main(String[] args){
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();
context.getEnvironment().setActiveProfiles("prod"); // 1
context.register(ProfileConfig.class); // 2
context.refresh(); // 3 DemoBean demoBean = context.getBean(DemoBean.class);
System.out.println(demoBean.getContext()); context.close();
}
}
说明
  1. 先将活动的Profile设置为prod
  2. 后置注册Bean配置类,不然会报Bean未定义的错误
  3. 刷新容器

相关文章