2.1 Spring 的配置
阿新 • • 發佈:2018-12-03
Spring 的配置
一、Spring的發展
Spring1.x
全部通過xml檔案配置bean,隨著專案的不斷擴大,需要將xml配置分放到不同的配置檔案中,需要頻繁的在java類和xml配置檔案中切換。
Spring2.x
隨著JDK 1.5帶來的註解支援,Spring2.x可以使用註解對Bean進行聲名和注入,大大的減少了xml配置檔案,同時也大大簡化了專案的開發。
最佳實踐:
1、 應用的基本配置用xml,比如:資料來源、資原始檔等;
2、 業務開發用註解,比如:Service中注入bean等;
Spring3.x
從Spring3.x開始提供了Java配置方式,使用Java配置方式可以更好的理解你配置的Bean。
Spring4.x +
Spring4.x和Spring boot都推薦使用java配置的方式,可以完全替代xml配置。
二、Spring的Java配置方式
@Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個註解實現的:
1、@Configuration 作用於類上,相當於一個xml配置檔案;
2、@Bean 作用於方法上,相當於xml配置中的;
示例
該示例演示了通過Java配置的方式進行配置Spring,並且實現了Spring IOC功能。
1. 建立Maven工程以及匯入依賴
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.itcast.springboot</groupId>
<artifactId >itcast-springboot</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.3.7.RELEASE</version>
</dependency>
<!-- 連線池 -->
<dependency>
<groupId>com.jolbox</groupId>
<artifactId>bonecp-spring</artifactId>
<version>0.8.0.RELEASE</version>
</dependency>
</dependencies>
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<!-- 資原始檔拷貝外掛 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<!-- java編譯外掛 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
</plugins>
<pluginManagement>
<plugins>
<!-- 配置Tomcat外掛 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
2.編寫User物件
public class User {
private String username;
private String password;
private Integer age;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
3.編寫UserDAO,模擬操作資料庫
public class UserDAO {
public List<User> queryUserList(){
List<User> result = new ArrayList<User>();
// 模擬資料庫的查詢
for (int i = 0; i < 10; i++) {
User user = new User();
user.setUsername("username_" + i);
user.setPassword("password_" + i);
user.setAge(i + 1);
result.add(user);
}
return result;
}
}
4.編寫UserService
@Service
public class UserService {
@Autowired // 注入Spring容器中的bean物件
private UserDAO userDAO;
public List<User> queryUserList() {
// 呼叫userDAO中的方法進行查詢
return this.userDAO.queryUserList();
}
}
5.編寫SpringConfig 用於例項化Spring容器
@Configuration //通過該註解來表明該類是一個Spring的配置,相當於一個xml檔案
@ComponentScan(basePackages = "cn.itcast.springboot.javaconfig") //配置掃描包
public class SpringConfig {
@Bean // 通過該註解來表明是一個Bean物件,相當於xml中的<bean>
public UserDAO getUserDAO(){
return new UserDAO(); // 直接new物件做演示
}
}
6.編寫測試方法 用於啟動Spring容器
public class Main {
public static void main(String[] args) {
// 通過Java配置來例項化Spring容器
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
// 在Spring容器中獲取Bean物件
UserService userService = context.getBean(UserService.class);
// 呼叫物件中的方法
List<User> list = userService.queryUserList();
for (User user : list) {
System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword());
}
// 銷燬該容器
context.destroy();
}
}
7.測試效果
8.小結
從以上的示例中可以看出,使用Java程式碼就完美的替代xml配置檔案,並且結構更加的清晰。
實戰
讀取外部的資源配置檔案
通過@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物件?