Spring Boot的基本操作
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的應用
@[email protected]@Configurationpublic 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)
測試
效果:
歡迎補充,謝謝合作!!!