一:項目中有一些key,value的簡單配置java
org.apache.commons.configuration.DatabaseConfiguration能夠輕鬆解決mysql
二:配置項目的xml中beanspring
1 <bean name="databaseConfiguration" class="org.apache.commons.configuration.DatabaseConfiguration"> 2 <constructor-arg type="javax.sql.DataSource"> 3 <bean class="org.springframework.jndi.JndiObjectFactoryBean"> 4 <property name="jndiName"> 5 <value>java:comp/env/jdbc/PROFILEDS</value> 6 </property> 7 </bean> 8 </constructor-arg> 9 <constructor-arg index="1" value="配置表的表名字"/> 10 <constructor-arg index="2" value="配置表的key的列名"/> 11 <constructor-arg index="3" value="配置表的value的列名"/> 12 </bean>
三:項目中就能夠使用Configuration做爲注入應用,就能夠獲取配置表中對應key的value值sql
1 @Autowired 2 private Configuration configuration;
四:spring的FactoryBean的接口數據庫
1 <!--該bean注入到ioc容器是一個Properties對象--> 2 <bean name="commonsConfigurationFactoryBean" class="org.springmodules.commons.configuration.CommonsConfigurationFactoryBean"> 3 <constructor-arg ref="databaseConfiguration"/> 4 </bean> 5 6 7 8 <!--查詢配置表的bean,項目中業務類能夠直接注入Configuration使用,實時查詢配置信息--> 9 <bean name="databaseConfiguration" class="org.apache.commons.configuration.DatabaseConfiguration"> 10 <constructor-arg type="javax.sql.DataSource"> 11 <bean class="org.springframework.jndi.JndiObjectFactoryBean"> 12 <property name="jndiName"> 13 <value>java:comp/env/jdbc/PROFILEDS</value> 14 </property> 15 </bean> 16 </constructor-arg> 17 <constructor-arg index="1" value="配置表的表名字"/> 18 <constructor-arg index="2" value="配置表的key的列名"/> 19 <constructor-arg index="3" value="配置表的value的列名"/> 20 </bean>
==>在xml中配置實現該接口的類的bean,返回給ioc容器中的對象,是實現該接口的類的getObject()返回的對象。apache
==& gt;上述配置中 org.springmodules.commons.configuration.CommonsConfigurationFactoryBean就 是實現FactoryBean的實現類。返回給ioc容器的對象爲ide
五:org.springframework.beans.factory.config.PropertyPlaceholderConfigurer佔位符號的應用工具
==>佔位符號應用的配置信息post
1 <!-- 這樣,就能夠在xml配置文件裏用展位符號,業務bean裏的屬性也能夠用佔位符號 --> 2 <bean id="commonsConfigurationPropertyPlaceholder" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 3 <property name="order" value="1" /> 4 <property name="ignoreUnresolvablePlaceholders" value="true" /> 5 <property name="properties" ref="commonsConfigurationFactoryBean"/> 6 </bean> 7 8 9 10 <!--該bean注入到ioc容器是一個Properties對象--> 11 <bean name="commonsConfigurationFactoryBean" class="org.springmodules.commons.configuration.CommonsConfigurationFactoryBean"> 12 <constructor-arg ref="databaseConfiguration"/> 13 </bean> 14 15 16 17 <!--查詢配置表的bean,項目中業務類能夠直接注入Configuration使用,實時查詢配置信息--> 18 <bean name="databaseConfiguration" class="org.apache.commons.configuration.DatabaseConfiguration"> 19 <constructor-arg type="javax.sql.DataSource"> 20 <bean class="org.springframework.jndi.JndiObjectFactoryBean"> 21 <property name="jndiName"> 22 <value>java:comp/env/jdbc/PROFILEDS</value> 23 </property> 24 </bean> 25 </constructor-arg> 26 <constructor-arg index="1" value="配置表的表名字"/> 27 <constructor-arg index="2" value="配置表的key的列名"/> 28 <constructor-arg index="3" value="配置表的value的列名"/> 29 </bean>
==>xml的應用案例編碼
<!--${}--> <bean class="org.springframework.beans.factory.config.MethodInvokingFactoryBean"> <property name="staticMethod" value="com.configuration.BusinessSourceHelper.setBusinessSource"/> <property name="arguments" value="${commons.configuration.businessSource}" /> </bean>
==>業務類的應用案例
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; @Producer public class AddRuleProducer { @Value("${billing.add.rule}") private String billingTopic; @Autowired private MessageSender messageSender; public void sendTopic(String message) { messageSender.send(billingTopic, message); } }
六:spring佔位符
Spring 利用PropertyPlaceholderConfigurer佔位符
1. PropertyPlaceholderConfigurer是個bean工廠後置處理器的實現,也就是 BeanFactoryPostProcessor接口的一個實現。PropertyPlaceholderConfigurer能夠將上下文(配置文 件)中的屬性值放在另外一個單獨的標準java Properties文件中去。在XML文件中用${key}替換指定的properties文件中的值。這樣的話,只須要對properties文件進 行修改,而不用對xml配置文件進行修改。
2.在Spring中,使用PropertyPlaceholderConfigurer能夠在XML配置文件中加入外部屬性文件,固然也能夠指定外部文件的編碼,如:
<bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location"> <value>conf/sqlmap/jdbc.properties</value> </property> <property name="fileEncoding"> <value>UTF-8</value> </property> </bean>
固然也能夠引入多個屬性文件,如:
<bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>/WEB-INF/mail.properties</value> <value>classpath: conf/sqlmap/jdbc.properties</value>//注意這兩種value值的寫法 </list> </property> </bean>
3.譬如,jdbc.properties的內容爲:
jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost/mysqldb?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=round; jdbc.username=root jdbc.password=123456
4.那麼在spring配置文件中,咱們就能夠這樣寫:
<bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath: conf/sqlmap/jdbc.properties </value> </list> </property> </bean> <bean id="dataSource"class="org.apache.commons.dbcp.BasicDataSource"destroy-method="close"> <property name="driverClassName"value="${jdbc.driverClassName}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}"/> <property name="password"value="${jdbc.password}" /> </bean>
5.這樣,一個簡單的數據源就設置完畢了。能夠看出:PropertyPlaceholderConfigurer起的做用就是將佔位符指向的數據庫配置信息放在bean中定義的工具。
6.查看源代碼,能夠發現,locations屬性定義在 PropertyPlaceholderConfigurer的祖父類 PropertiesLoaderSupport中,而location只有 setter方法。相似於這樣的配置,在spring的源程序中很常見的。
PropertyPlaceholderConfigurer若是在指定的Properties文件中找不到你想使用的屬性,它還會在Java的System類屬性中查找。
咱們能夠經過System.setProperty(key, value)或者java中經過-Dnamevalue來給Spring配置文件傳遞參數。