Spring 如何讀取properties文件內容

Spring中config屬性文件的讀取與使用 PropertyPlaceholderConfigurer 註解@Componentjava

1.配置文件:/WEB-INF/configInfo.properties
配置文件內容:
email.host = www.94gleaner.com
email.port = xxx
email.username = gleaner
email.password = xxx
email.sendFrom = 94gleaner@94gleaner.commysql

2.Spring容器啓動時,使用內置bean對屬性文件信息進行加載,在bean.xml中添加以下:spring

<!– spring的屬性加載器,加載properties文件中的屬性   方案①-->
<bean id=」propertyConfigurer」 class=」org.springframework.beans.factory.config.PropertyPlaceholderConfigurer」>
property name=」location」>
<value>/WEB-INF/configInfo.properties</value>
</property>
<property name=」fileEncoding」 value=」utf-8″ />
</bean>

<!--或者經過以下方式加載       方案②-->
<context:property-placeholder location="classpath:ldap.properties" ignore-unresolvable="true"/>



    <!-- 將多個配置文件讀取到容器中,交給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>

3.其它bean中引用,例:sql

<property name="host">
       <value>${email.host}</value>
</property>
<property name=」port」>
       <value>${email.port}</value>
</property>

4.JAVA代碼中獲取方法:建立ConfigInfo.java數據庫

@Component("configInfo")
public class ConfigInfo {
@Value("${email.host}")
private String host;
@Value("${email.port}")
private String port;
public String getHost() {
return host;
}
public String getPort() {
return port;
}
}

5.代碼中調用apache

@Autowired
private ConfigInfo configInfo;
public byte[] Test(HttpServletResponse response) {
string host = configInfo.getHost();
}

 

 

 

config.properties配置文件信息mybatis

Properties代碼  收藏代碼oracle

##數據庫(mysql|mssql|oracle...)  app

environment=mysql  url

jdbc.driver=com.mysql.jdbc.Driver  

jdbc.url=jdbc:mysql://127.0.0.1:3306/portal?useUnicode=true&characterEncoding=utf8  

jdbc.user=root  

jdbc.password=root  

#初始化鏈接(根據實際訪問量設置大小)  

jdbc.initialSize=10  

#最大空閒鏈接(根據實際訪問量設置大小)  

jdbc.maxIdle=50  

#最小空閒鏈接(根據實際訪問量設置大小)  

jdbc.minIdle=10  

#最大鏈接數量(根據實際訪問量設置大小)  

jdbc.maxActive=200  

 Spring配置信息(截取部分)

Xml代碼  收藏代碼

<context:property-placeholder location="classpath:config.properties" />  

  <!--建立jdbc數據源 -->  

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  

  <property name="driverClassName" value="${jdbc.driver}"/>  

 <property name="url" value="${jdbc.url}"/>  

<property name="username" value="${jdbc.user}"/>  

 <property name="password" value="${jdbc.password}"/>  

 <property name="initialSize" value="${jdbc.initialSize}"/>  

<property name="maxIdle" value="${jdbc.maxIdle}"/>  

 <property name="minIdle" value="${jdbc.minIdle}"/>  

<property name="maxActive" value="${jdbc.maxActive}"/>  

 <property name="removeAbandoned" value="true"/>    

  <property name="removeAbandonedTimeout" value="120"/>  

  <property name="maxWait" value="3000"/>  

</bean>  

<!-- 建立SqlSessionFactory,同時指定數據源 -->  

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  

   <property name="dataSource" ref="dataSource"/>  

  <property name="configLocation" value="classpath:mybatis-config.xml"/>  

  <property name="mapperLocations" value="classpath*:com.anly.portal.*.mapper/*Mapper.xml" />   

</bean>  

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  

  <!-- 此處掃描的是Mapper接口 -->  

 <property name="basePackage" value="com.anly.portal.*.mapper"/>  

<property name="sqlSessionFactory" ref="sqlSessionFactory"/>  

</bean>  

 此時,啓動會報異常,${jdbc.driver}這樣的表達式獲取不到properties裏面的值,由於MapperScannerConigurer實際是在解析加載bean定義階段的,這個時候要是設置sqlSessionFactory的話,會致使提早初始化一些類,這個時候,PropertyPlaceholderConfigurer還沒來得及替換定義中的變量,致使把表達式看成字符串複製了,解決的辦法以下:

 

方法一:

修改<property name="sqlSessionFactory" ref="sqlSessionFactory"/>爲<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>

原理:使用sqlSessionFactoryBeanName注入,不會當即初始化sqlSessionFactory, 因此不會引起提早初始化問題。

 

方法二:

直接刪掉<property name="sqlSessionFactory" ref="sqlSessionFactory"/>

注意:在沒有配置這一行時,必須配置一個以sqlSessionFactory命名的org.mybatis.spring.SqlSessionFactoryBean。

相關文章
相關標籤/搜索