有时候我们配置一个bean,其属性值很多,也很复杂,维护起来很不方便。比如配置数据源的时候:
<bean id="DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="root"></property>
<property name="123456" value="${password}"></property>
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///test"></property>
</bean>
能否把这些属性值按照键值对的方式统一储存到一个文件里,要用的时候直接引用键名呢?这就可以用到外部文件了。
在src下新建一个文件db.properties,这个文件存储属性:
user=root
password=123456
driverClass=com.mysql.jdbc.Driver
jdbcUrl=jdbc:mysql:///test
我们要在xml里面使用到db.properties里的内容,当然需要把它引用进来:
<context:property-placeholder location="classpath:db.properties"/>
接下来就可以用类似EL表达式的方法访问到属性值:
<bean id="DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="${user}"></property>
<property name="password" value="${password}"></property>
<property name="driverClass" value="${driverClass}"></property>
<property name="jdbcUrl" value="${jdbcUrl}"></property>
</bean>
测试程序:
public static void main(String[] args) throws SQLException {
ApplicationContext ctx=new ClassPathXmlApplicationContext("bean-property.xml");
DataSource dataSource=(DataSource) ctx.getBean("DataSource");
System.out.println("begin....");
System.out.println("hello:"+dataSource.getConnection());
System.out.println("dataSorce:"+dataSource);
System.out.println("end....");
}
PS: 如果mySQL服务没有安装,是会报错的。