如何讀取外部的資源配置文件?
通過@PropertySource可以指定讀取的配置文件,通過@Value註解獲取值,具體用法:
@Configuration //通過該註解來表明該類是一個Spring的配置,相當於一個xml文件
@ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置掃描包
@PropertySource(value= {"classpath:jdbc.properties"})
public class SpringConfig {
@Value("${jdbc.url}")
private String jdbcUrl;
@Bean // 通過該註解來表明是一個Bean對象,相當於xml中的<bean>
public UserDAO getUserDAO(){
return new UserDAO(); // 直接new對象做演示
}
}
1、如何配置多個配置文件?
2、如果配置的配置文件不存在會怎麼樣?
配置數據庫連接池
導入依賴:
<!-- 連接池 -->
<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對象?