SpringBoot學習記錄(一)
阿新 • • 發佈:2018-08-02
not website snap 對象 mpi method oid pom pid
1. Spring的Java配置方式
Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置。
1.1. @Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個註解實現的:
1、@Configuration 作用於類上,相當於一個xml配置文件;
2、@Bean 作用於方法上,相當於xml配置中的<bean>;
1.2. 示例
該示例演示了通過Java配置的方式進行配置Spring,並且實現了Spring IOC功能。
1.2.1. 創建工程以及導入依賴
<?xml version="1.0" encoding="UTF-8"?> <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>com.javaweb</groupId> <artifactId>springboot</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>springboot Maven Webapp</name> <!-- FIXME change it to the project‘s website --> <url>http://www.example.com</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> </properties> <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>
1.2.2. 編寫User對象
package com.javaweb.springboot.javaconfig; 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; } }
1.2.3. 編寫UserDAO 用於模擬與數據庫的交互
package com.javaweb.springboot.javaconfig; import java.util.ArrayList; import java.util.List; 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; } }
1.2.4. 編寫UserService 用於實現User數據操作業務邏輯
package com.javaweb.springboot.javaconfig; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.List; @Service public class UserService { @Autowired // 註入Spring容器中的bean對象 private UserDAO userDAO; public List<User> queryUserList() { // 調用userDAO中的方法進行查詢 return this.userDAO.queryUserList(); } }
1.2.5. 編寫SpringConfig 用於實例化Spring容器
package com.javaweb.springboot.javaconfig; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; @Configuration //通過該註解來表明該類是一個Spring的配置,相當於一個xml文件 @ComponentScan(basePackages = "com.javaweb.springboot.javaconfig") //配置掃描包 public class SpringConfig { @Bean // 通過該註解來表明是一個Bean對象,相當於xml中的<bean> public UserDAO getUserDAO(){ return new UserDAO(); // 直接new對象做演示 } }
1.2.6. 編寫測試方法 用於啟動Spring容器
package com.javaweb.springboot.javaconfig; import org.springframework.context.annotation.AnnotationConfigApplicationContext; import java.util.List; 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(); } }
1.2.7. 測試效果
1.2.8. 小結
從以上的示例中可以看出,使用Java代碼就完美的替代xml配置文件,並且結構更加的清晰。
1.3. 實戰
1.3.1. 讀取外部的資源配置文件
通過@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.3.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; }
SpringBoot學習記錄(一)