Spring 的Java配置方式
接著上週的知識繼續衍生,主要講解spring 及springboot 的內容。
Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置。
-
- @Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個註解實現的:
1、@Configuration 作用於類上,相當於一個xml配置檔案;
2、@Bean 作用於方法上,相當於xml配置中的<bean>;
-
- 示例
該示例演示了通過Java配置的方式進行配置Spring,並且實現了Spring IOC功能。
-
-
- 建立工程以及匯入依賴
-
<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>
-
-
- 編寫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;
}
}
-
-
- 編寫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;
}
}
-
-
- 編寫UserService 用於實現User資料操作業務邏輯
-
@Service
public class UserService {
@Autowired // 注入Spring容器中的bean物件
private UserDAO userDAO;
public List<User> queryUserList() {
// 呼叫userDAO中的方法進行查詢
return this.userDAO.queryUserList();
}
}
-
-
- 編寫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物件做演示
}
}
-
-
- 編寫測試方法 用於啟動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();
}
}
- 測試效果
-
-
- 小結
-
從以上的示例中可以看出,使用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物件做演示
}
}
思考:
- 如何配置多個配置檔案?
- 如果配置的配置檔案不存在會怎麼樣?
-
- 配置資料庫連線池
-
匯入依賴:
<!-- 連線池 -->
<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;
}
接下來我們會將關於springboot的知識,望對讀者會有些用處,獻醜。