上一篇: 08-Spring对象的生命周期https://blog.csdn.net/fsjwin/article/details/109427737
在spring的xml配置文件中。有些String类型的数据,对于运维人员十分不友好。比如数据库连接、用户名、密码。有没有好的办法把它们抽离呢?有的,spring提供了相关的技术支持。
即目标就是把xml中类似与这类的配置文件提取出来。步骤如下:
- 小配置化的配置文件 db.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/spring?useSSL=false
jdbc.username=root
jdbc.password=root
- spring的配置文件,为了方便,另外创建一个 applicationContext2.xml
这个${} 语法,是spring的解析语法,会通过 <context:property-placeholder location=“classpath:db.properties”/> 获得值,通过内置的priperties解析了工具PropertySourcesPropertyResolver.java对其进行解析,然后重新放入xml配置文件中。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!--context的命名空间中的properties的占位符,告诉spring properties在什么地方-->
<context:property-placeholder location="classpath:db.properties"/>
<bean id="conn" class="base.comobjectcreate.factorybean.MyConnectionFacoryBean">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
</beans>
- 测试
@Test
public void test19() {
ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext2.xml");
Connection conn = (Connection)ctx.getBean("conn");
System.out.println(conn);
}
- 结果
com.mysql.jdbc.JDBC4Connection@ca263c2
- 总结
这样就达到了我们的目标:配置文件的参数化,针对的是string类型的配置文件。
下一篇:10-Spring自定义类型转化器https://blog.csdn.net/fsjwin/article/details/109444479