1. Spring的發展
1.1. Spring1.x 時代
在Spring1.x時代,都是通過xml檔案配置bean,隨著專案的不斷擴大,需要將xml配置分放到不同的配置檔案中,需要頻繁的在java類和xml配置檔案中切換。
1.2.Spring2.x時代
隨著JDK 1.5帶來的註解支援,Spring2.x可以使用註解對Bean進行申明和注入,大大的減少了xml配置檔案,同時也大大簡化了專案的開發。
那麼,問題來了,究竟是應該使用xml還是註解呢?
最佳實踐:
1、 應用的基本配置用xml,比如:資料來源、資原始檔等;
2、 業務開發用註解,比如:Service中注入bean等;
1.3.Spring3.x到Spring4.x
從Spring3.x開始提供了Java配置方式,使用Java配置方式可以更好的理解你配置的Bean,現在我們就處於這個時代,並且Spring4.x和Spring boot都推薦使用java配置的方式
2. Spring的Java配置方式
Java配置是Spring4.x推薦的配置方式,可以完全替代xml配置
2.1、@Configuration 和 @Bean
Spring的Java配置方式是通過 @Configuration 和 @Bean 這兩個註解實現的:
1、@Configuration 作用於類上,相當於一個xml配置檔案;
2、@Bean 作用於方法上,相當於xml配置中的<bean>;
2.2、示例
* 該示例演示了通過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;
}
}複製程式碼
編寫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配置檔案,並且結構更加的清晰
3、讀取外部的資源配置檔案
通過@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;
}複製程式碼
4、Spring Boot
什麼是Spring Boot?
Spring
Boot的優缺點
5、Spring Boot
設定spring boot的parent
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.2.RELEASE</version>
</parent>複製程式碼
說明:Spring boot的專案必須要將parent設定為spring boot的parent,該parent包含了大量預設的配置,大大簡化了我們的開發
匯入spring boot的web支援
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>複製程式碼
新增Spring boot的外掛
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>複製程式碼
編寫第一個Spring Boot的應用
@Controller
@SpringBootApplication
@Configuration
public class HelloApplication {
@RequestMapping("hello")
@ResponseBody
public String hello(){
return "hello world!";
}
public static void main(String[] args) {
SpringApplication.run(HelloApplication.class, args);
}
}複製程式碼
程式碼說明:
1、@SpringBootApplication:Spring Boot專案的核心註解,主要目的是開啟自動配置。;
2、@Configuration:這是一個配置Spring的配置類;
3、@Controller:標明這是一個SpringMVC的Controller控制器;
4、main方法:在main方法中啟動一個應用,即:這個應用的入口;
啟動應用(針對eclipse)
在Spring Boot專案中,啟動的方式有兩種,一種是直接run Java Application另外一種是通過Spring Boot的Maven外掛執行
第一種:
第二種:
啟動效果:
看到如下資訊就說明啟動成功了:
INFO 6188 --- [ main] c.i.springboot.demo.HelloApplication : Started HelloApplication in 3.281 seconds (JVM running for 3.601)
測試
效果:
歡迎補充,謝謝合作!!!