Spring EL表达式和资源调用
Spring EL表达式
Spring EL-Spring表达式语言,支持在xml和注解中使用表达式,类似于在jsp的EL表达式语言。
Spring 开发中经常涉及调用各种资源的情况,包含普通文件、网址、配置文件、系统环境变量等,我们可以使用Spring的表达式语言实现资源的注入。
Spring主要在注解@Value的参数中使用表达式语言。
- 注入普通字符
- 注入操作系统属性
- 注入表达式运算结果
- 注入其他Bean的属性
- 注入文件内容
- 注入网址内容
- 注入属性文件
示例
- 在类路径下新建一个text.txt文件,内容随意,在类路径下新建一个test.propertes文件,内容如下:
book.author=xxx
book.name= spring boot
- 编写一个需要注入的Bean
@Service
public class DemoService {
@Value("其他类中的属性") // 此处为注入普通字符串
private String another;
public String getAnother(){
return another;
}
public void setAnother(String anther){
this.another = anther;
}
}
- 配置类
@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
...
}
代码解释
-
注入普通字符串
-
注入操作系统属性
-
注入表达式结果
-
注入其他Bean属性
-
注入文件资源,文件资源可以是classpath路径下的也可以是系统文件目录下的
-
注入网址资源
-
注入配置文件中的资源,配置文件使用@PropertySource注解在类上标注
注入配置件需要使用@PropertySource指定文件地址,若使用@Value注入,则要配置一个PropertySourcesPlaceholderConfigurer的Bean,@Value("${book.name}")使用的是"$"而不是"#"
Profile
Profile为不同环境下使用不同的配置提供了支持(开发环境和生成环境)
- 通过设定Environment的ActiveProfiles类设定当前context需要使用的配置。在开发中使用@Profile注解类或者方法,达到不同情况下选择实例化不同的Bean。
- 通过设定JVM的spring.profiles.active参数来设计配置环境。
- 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");
}
}
示例
- 示例Bean
public class DemoBean {
private String content;
public DemoBean(String content){
this.content = content;
}
public String getContent(){
return content;
}
}
- 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");
}
}
代码解释
-
profile为dev时示例化devDemoBean
-
profile为prod时实例化为prodDemoBean
-
运行
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();
}
}
说明
- 先将活动的Profile设置为prod
- 后置注册Bean配置类,不然会报Bean未定义的错误
- 刷新容器