1. 程式人生 > >Java配置方式讀取外部的資源配置文件

Java配置方式讀取外部的資源配置文件

eba hsi ptp vlt uwp img dbm woe fsp

通過@PropertySource可以指定讀取的配置文件,通過@Value註解獲取值,具體用法:

package cn.qlq;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;

@Configuration 
// 通過該註解來表明該類是一個Spring的配置,相當於一個xml文件 @ComponentScan(basePackages = "cn.qlq") // 配置掃描包 @PropertySource(value = { "classpath:jdbc.properties", "xxxxx", "yyyyy" }, ignoreResourceNotFound = true) public class SpringConfig { @Bean // 通過該註解來表明是一個Bean對象,相當於xml中的<bean> public UserDao getUserDAO() {
return new UserDao(); // 直接new對象做演示 } }

問題:

1.讀取多個配置文件:

技術分享圖片

2.如果文件不存在忽略錯誤:

技術分享圖片

打開@PropertySource註解源碼可以看到:

技術分享圖片

-------------------- 配置數據庫連接池例子-------------

導入依賴:

<!-- 連接池 -->
        <dependency>
            <groupId>com.jolbox</groupId>
            <
artifactId>bonecp-spring</artifactId> <version>0.8.0.RELEASE</version> </dependency>

之前的Spring xml配置連接池:

 <!-- 定義數據源 -->
    <bean id="dataSource" class="com.jolbox.bonecp.BoneCPDataSource"
        destroy-method="close">
        <!-- 數據庫驅動 -->
        <property name="driverClass" value="${jdbc.driverClassName}" />
        <!-- 相應驅動的jdbcUrl -->
        <property name="jdbcUrl" value="${jdbc.url}" />
        <!-- 數據庫的用戶名 -->
        <property name="username" value="${jdbc.username}" />
        <!-- 數據庫的密碼 -->
        <property name="password" value="${jdbc.password}" />
        <!-- 檢查數據庫連接池中空閑連接的間隔時間,單位是分,默認值:240,如果要取消則設置為0 -->
        <property name="idleConnectionTestPeriod" value="60" />
        <!-- 連接池中未使用的鏈接最大存活時間,單位是分,默認值:60,如果要永遠存活設置為0 -->
        <property name="idleMaxAge" value="30" />
        <!-- 每個分區最大的連接數 -->
        <!-- 
            判斷依據:請求並發數
         -->
        <property name="maxConnectionsPerPartition" value="100" />
        <!-- 每個分區最小的連接數 -->
        <property name="minConnectionsPerPartition" value="5" />
    </bean>

參考xml配置改造成java配置方式:

 @Value("${jdbc.url}")
    private String jdbcUrl;

    @Value("${jdbc.driverClassName}")
    private String jdbcDriverClassName;

    @Value("${jdbc.username}")
    private String jdbcUsername;

    @Value("${jdbc.password}")
    private String jdbcPassword;

    @Bean(destroyMethod = "close")
    public DataSource dataSource() {
        BoneCPDataSource boneCPDataSource = new BoneCPDataSource();
        // 數據庫驅動
        boneCPDataSource.setDriverClass(jdbcDriverClassName);
        // 相應驅動的jdbcUrl
        boneCPDataSource.setJdbcUrl(jdbcUrl);
        // 數據庫的用戶名
        boneCPDataSource.setUsername(jdbcUsername);
        // 數據庫的密碼
        boneCPDataSource.setPassword(jdbcUsername);
        // 檢查數據庫連接池中空閑連接的間隔時間,單位是分,默認值:240,如果要取消則設置為0
        boneCPDataSource.setIdleConnectionTestPeriodInMinutes(60);
        // 連接池中未使用的鏈接最大存活時間,單位是分,默認值:60,如果要永遠存活設置為0
        boneCPDataSource.setIdleMaxAgeInMinutes(30);
        // 每個分區最大的連接數
        boneCPDataSource.setMaxConnectionsPerPartition(100);
        // 每個分區最小的連接數    
        boneCPDataSource.setMinConnectionsPerPartition(5);
        return boneCPDataSource;
}

思考: 如何使用該DataSource對象?

  放入spring中,使用方法類似於平時的使用方法。

Java配置方式讀取外部的資源配置文件