您好,登錄后才能下訂單哦!
一個系統中通常會存在如下一些以Properties形式存在的配置文件
1.數據庫配置文件demo-db.properties:
database.url=jdbc:mysql://localhost/smaple database.driver=com.mysql.jdbc.Driver database.user=root database.password=123
2.消息服務配置文件demo-mq.properties:
#congfig of ActiveMQ mq.java.naming.factory.initial=org.apache.activemq.jndi.ActiveMQInitialContextFactory mq.java.naming.provider.url=failover:(tcp://localhost:61616?soTimeout=30000&connectionTimeout=30000)?jms.useAsyncSend=true&timeout=30000 mq.java.naming.security.principal= mq.java.naming.security.credentials= jms.MailNotifyQueue.consumer=5
3.遠程調用的配置文件demo-remote.properties:
remote.ip=localhost remote.port=16800 remote.serviceName=test
一、系統中需要加載多個Properties配置文件
應用場景:Properties配置文件不止一個,需要在系統啟動時同時加載多個Properties文件。
配置方式:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 將多個配置文件讀取到容器中,交給Spring管理 --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <!-- 這里支持多種尋址方式:classpath和file --> <value>classpath:/opt/demo/config/demo-db.properties</value> <!-- 推薦使用file的方式引入,這樣可以將配置和代碼分離 --> <value>file:/opt/demo/config/demo-mq.properties</value> <value>file:/opt/demo/config/demo-remote.properties</value> </list> </property> </bean> <!-- 使用MQ中的配置 --> <bean id="MQJndiTemplate" class="org.springframework.jndi.JndiTemplate"> <property name="environment"> <props> <prop key="java.naming.factory.initial">${mq.java.naming.factory.initial}</prop> <prop key="java.naming.provider.url">${mq.java.naming.provider.url}</prop> <prop key="java.naming.security.principal">${mq.java.naming.security.principal}</prop> <prop key="java.naming.security.credentials">${mq.java.naming.security.credentials}</prop> <prop key="userName">${mq.java.naming.security.principal}</prop> <prop key="password">${mq.java.naming.security.credentials}</prop> </props> </property> </bean> </beans>
我們也可以將配置中的List抽取出來:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 將多個配置文件位置放到列表中 --> <bean id="propertyResources" class="java.util.ArrayList"> <constructor-arg> <list> <!-- 這里支持多種尋址方式:classpath和file --> <value>classpath:/opt/demo/config/demo-db.properties</value> <!-- 推薦使用file的方式引入,這樣可以將配置和代碼分離 --> <value>file:/opt/demo/config/demo-mq.properties</value> <value>file:/opt/demo/config/demo-remote.properties</value> </list> </constructor-arg> </bean> <!-- 將配置文件讀取到容器中,交給Spring管理 --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations" ref="propertyResources" /> </bean> <!-- 使用MQ中的配置 --> <bean id="MQJndiTemplate" class="org.springframework.jndi.JndiTemplate"> <property name="environment"> <props> <prop key="java.naming.factory.initial">${mq.java.naming.factory.initial}</prop> <prop key="java.naming.provider.url">${mq.java.naming.provider.url}</prop> <prop key="java.naming.security.principal">${mq.java.naming.security.principal}</prop> <prop key="java.naming.security.credentials">${mq.java.naming.security.credentials}</prop> <prop key="userName">${mq.java.naming.security.principal}</prop> <prop key="password">${mq.java.naming.security.credentials}</prop> </props> </property> </bean> </beans>
二、整合多工程下的多個分散的Properties
應用場景:工程組中有多個配置文件,但是這些配置文件在多個地方使用,所以需要分別加載。
配置如下:
<?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" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 將DB屬性配置文件位置放到列表中 --> <bean id="dbResources" class="java.util.ArrayList"> <constructor-arg> <list> <value>file:/opt/demo/config/demo-db.properties</value> </list> </constructor-arg> </bean> <!-- 將MQ屬性配置文件位置放到列表中 --> <bean id="mqResources" class="java.util.ArrayList"> <constructor-arg> <list> <value>file:/opt/demo/config/demo-mq.properties</value> </list> </constructor-arg> </bean> <!-- 用Spring加載和管理DB屬性配置文件 --> <bean id="dbPropertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="order" value="1" /> <property name="ignoreUnresolvablePlaceholders" value="true" /> <property name="locations" ref="dbResources" /> </bean> <!-- 用Spring加載和管理MQ屬性配置文件 --> <bean id="mqPropertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="order" value="2" /> <property name="ignoreUnresolvablePlaceholders" value="true" /> <property name="locations" ref="mqResources" /> </bean> <!-- 使用DB中的配置屬性 --> <bean id="rmsDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" p:driverClassName="${demo.db.driver}" p:url="${demo.db.url}" p:username="${demo.db.username}" p:password="${demo.db.password}" pp:maxActive="${demo.db.maxactive}"p:maxWait="${demo.db.maxwait}" p:poolPreparedStatements="true" p:defaultAutoCommit="false"> </bean> <!-- 使用MQ中的配置 --> <bean id="MQJndiTemplate" class="org.springframework.jndi.JndiTemplate"> <property name="environment"> <props> <prop key="java.naming.factory.initial">${mq.java.naming.factory.initial}</prop> <prop key="java.naming.provider.url">${mq.java.naming.provider.url}</prop> <prop key="java.naming.security.principal">${mq.java.naming.security.principal}</prop> <prop key="java.naming.security.credentials">${mq.java.naming.security.credentials}</prop> <prop key="userName">${mq.java.naming.security.principal}</prop> <prop key="password">${mq.java.naming.security.credentials}</prop> </props> </property> </bean> </beans>
注意:其中order屬性代表其加載順序,而ignoreUnresolvablePlaceholders為是否忽略不可解析的 Placeholder,如配置了多個PropertyPlaceholderConfigurer,則需設置為true。這里一定需要按照這種方式設置這兩個參數。
三、Bean中直接注入Properties配置文件中的值
應用場景:Bean中需要直接注入Properties配置文件中的值 。例如下面的代碼中需要獲取上述demo-remote.properties中的值:
public class Client() { private String ip; private String port; private String service; }
配置如下:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="<a rel="external nofollow" rel="external nofollow" >http://www.springframework.org/schema/beans</a>" xmlns:xsi="<a rel="external nofollow" >http://www.w3.org/2001/XMLSchema-instance</a>" xmlns:util="<a rel="external nofollow" rel="external nofollow" >http://www.springframework.org/schema/util</a>" xsi:schemaLocation=" <a rel="external nofollow" rel="external nofollow" >http://www.springframework.org/schema/beans</a> <a rel="external nofollow" >http://www.springframework.org/schema/beans/spring-beans-3.0.xsd</a> <a rel="external nofollow" rel="external nofollow" >http://www.springframework.org/schema/util</a> <a rel="external nofollow" >http://www.springframework.org/schema/util/spring-util-3.0.xsd</a>"> <!-- 這種加載方式可以在代碼中通過@Value注解進行注入, 可以將配置整體賦給Properties類型的類變量,也可以取出其中的一項賦值給String類型的類變量 --> <!-- <util:properties/> 標簽只能加載一個文件,當多個屬性文件需要被加載的時候,可以使用多個該標簽 --> <util:properties id="remoteSettings" location="file:/opt/demo/config/demo-remote.properties" /> <!-- <util:properties/> 標簽的實現類是PropertiesFactoryBean, 直接使用該類的bean配置,設置其locations屬性可以達到一個和上面一樣加載多個配置文件的目的 --> <bean id="settings" class="org.springframework.beans.factory.config.PropertiesFactoryBean"> <property name="locations"> <list> <value>file:/opt/rms/config/rms-mq.properties</value> <value>file:/opt/rms/config/rms-env.properties</value> </list> </property> </bean> </beans>
Client類中使用Annotation如下:
import org.springframework.beans.factory.annotation.Value; public class Client() { @Value("#{remoteSettings['remote.ip']}") private String ip; @Value("#{remoteSettings['remote.port']}") private String port; @Value("#{remoteSettings['remote.serviceName']}") private String service; }
四、Bean中存在Properties類型的類變量
應用場景:當Bean中存在Properties類型的類變量需要以注入的方式初始化
1. 配置方式:我們可以用(三)中的配置方式,只是代碼中注解修改如下
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Autowired; public class Client() { @Value("#{remoteSettings}") private Properties remoteSettings; }
2. 配置方式:也可以使用xml中聲明Bean并且注入
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"> <!-- 可以使用如下的方式聲明Properties類型的FactoryBean來加載配置文件,這種方式就只能當做Properties屬性注入,而不能獲其中具體的值 --> <bean id="remoteConfigs" class="org.springframework.beans.factory.config.PropertiesFactoryBean"> <property name="locations"> <list> <value>file:/opt/demo/config/demo-remote.properties</value> </list> </property> </bean> <!-- 遠端調用客戶端類 --> <bean id="client" class="com.demo.remote.Client"> <property name="properties" ref="remoteConfigs" /> </bean> </beans>
代碼如下:
import org.springframework.beans.factory.annotation.Autowired; public class Client() { //@Autowired也可以使用 private Properties remoteSettings; //getter setter }
五、使用通配符加載多個properties文件
<context:property-placeholder location="file:///${CONFIG_PATH}/*.properties" />
或者
<context:property-placeholder location="classpath*:/*.properties"/>
上述的各個場景在項目群中特別有用,需要靈活的使用上述各種配置方式。以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。