如题所示,有时候我们的一些配置并不能在代码中“写死”,而是需要动态配置在配置文件中。这样可以使得以后需要修改该参数时只需要修改配置文件中的参数值即可,而不需要修改代码。具体配置如下:
(1)在Spring的配置文件中添加以下配置用于引入参数所在的文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
< bean id = "configProperties"
class = "org.springframework.beans.factory.config.PropertiesFactoryBean" >
< property name = "locations" >
< list >
< value >classpath:jdbc.properties</ value >
< value >classpath:article.properties</ value >
</ list >
</ property >
</ bean >
< bean id = "propertyConfigurer"
class = "org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer" >
< property name = "properties" ref = "configProperties" />
</ bean >
|
注:如果想在Controller中也使用@Value注解引入配置文件中的参数的话,那么需要将上面的“propertyConfigurer”这个bean在SpringMVC的配置文件中也重复复制一遍,也就是:
1
2
3
4
|
< bean id = "propertyConfigurer"
class = "org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer" >
< property name = "properties" ref = "configProperties" />
</ bean >
|
(2)article.properties文件的具体内容如下:
1
|
test.author=zifangsky |
(3)测试:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
package cn.zifangsky.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller public class TestController {
@Value ( "#{configProperties['test.author']}" )
private String author;
@RequestMapping ( "/test.html" )
public void test(){
System.out.println( "---------------" );
System.out.println( "测试: " + author);
}
} |
可以看出,这里使用了@Value注解,其语法如下:
@Value(“#{configProperties[‘参数名’]}”)
当然,还有一种简写的语法是:
@Value(“${参数名}”)
也就是说上面加载参数那里也可以这样使用:
1
2
|
@Value ( "${test.author}" )
private String author;
|
(4)最后输出如下:
1
2
|
--------------- 测试: zifangsky
|
本文转自 pangfc 51CTO博客,原文链接:http://blog.51cto.com/983836259/1889581,如需转载请自行联系原作者