PropertyOverrideConfigurer,类似于
PropertyPlaceholderConfigurer,但是与后者相比,前者对于bean属性可以有缺省值或者根本没有值。如果起覆盖作用的 Properties文件没有某个bean属性的内容,那么缺省的上下文定义将被使用。
package
Bean.propertytwo;





public
class
Chinese
...
{
privateStringname;
privateStringage;

publicStringgetAge()...{
returnage;
}

publicvoidsetAge(Stringage)...{
this.age=age;
}

publicStringgetName()...{
returnname;
}

publicvoidsetName(Stringname)...{
this.name=name;
}



}
<?
xmlversion="1.0"encoding="UTF-8"
?>
<!
DOCTYPEbeansPUBLIC"-//SPRING//DTDBEAN//EN""http://www.springframework.org/dtd/spring-beans.dtd"
>

<
beans
>

<
bean
id
="propertyConfigure"
class
="org.springframework.beans.factory.config.PropertyOverrideConfigurer"
>
<
property
name
="locations"
value
="classpath:Bean/propertytwo/person.properties"
>

</
property
>
</
bean
>
<
bean
id
="chinese"
class
="Bean.propertytwo.Chinese"
>
<
property
name
="age"
value
="30"
></
property
>
<
property
name
="name"
value
="gaoxiang"
></
property
>
</
bean
>
</
beans
>
public
static
void
main(String[]args)
throws
Exception
...
{

Stringpath=newTest().getClass().getResource("/").getPath();
Stringrealpath=path.substring(1,path.length());
ApplicationContextcontext=newFileSystemXmlApplicationContext(realpath+"/propertytwo.xml");

Chinesep=(Chinese)context.getBean("chinese");
System.out.println(p.getName()+p.getAge());

}
注意:bean 工厂的定义并 不会意识到被覆盖,所以仅仅察看XML定义文件并不能立刻明显地知道覆盖配置是否被使用了。在有多个PorpertyOverrideConfigurer对用一个bean属性定义了不同的值的时候,最后一个将取胜(取决于覆盖的机制)。
Properties文件的一行配置应该是如下的格式:
beanName.property=value,其中beanName是需要覆盖的bean的名字,property是需要覆盖的属性名
实体:






























配置文件:年龄age有注入值30















属性文件,将age设置为26:
chinese.age=26
测试代码:











运行结果:
gaoxiang26
可以看到,age已经被properties中的数值覆盖了,没有使用配置文件中的数值