springboot入門之路(二)
- 繼springboot入門之路(一)連續的學習漸進之路。
閱讀springboot入門之路(一)點擊:springboot入門之路(一)
3.springboot配置及注意事項
3.1繼承starter parent
- 想配置你的項目繼承 spring-boot-starter-parent 只需要簡單地設置 parent 為:
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.9.RELEASE</version>
<type>pom</type>
</parent>
- 注:你應該只需要在該依賴上指定Spring Boot版本。如果導入其他的starters,你可以放心的省略版本號。
3.2使用沒有父POM的Spring Boot
不是每個人都喜歡繼承 spring-boot-starter-parent POM。你可能需要使用公司標準parent,或你可能傾向于顯式聲明所有
Maven配置。如果你不使用 spring-boot-starter-parent ,通過使用一個 scope=import 的依賴,你仍能獲取到依賴管理的好處:
<dependencyManagement>
<dependencies>
<dependency>
<!-- Import dependency management from Spring Boot -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>1.3.0.BUILD-SNAPSHOT</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
3.3配置java的編譯的版本
spring-boot-starter-parent 選擇相當保守的Java兼容策略。如果你遵循我們的建議,使用最新的Java版本,你可以添加一
個 java.version 屬性:
<properties>
<java.version>1.8</java.version>
</properties>
3.4使用"default"包
- 當類沒有包含 package 聲明時,它被認為處于 default package 下。通常不推薦使用 default package ,并應該避免使用它。因
為對于使用 @ComponentScan , @EntityScan 或 @SpringBootApplication 注解的Spring Boot應用來說,來自每個jar的類都會被讀
取,這會造成一定的問題。
3.5 定位main應用類
- 我們通常建議你將main應用類放在位于其他類上面的根包(root package)中。通常使用 @EnableAutoConfiguration 注解你的
main類,并且暗地里為某些項定義了一個基礎“search package”。例如,如果你正在編寫一個JPA應用,
被 @EnableAutoConfiguration 注解的類所在包將被用來搜索 @Entity 項。
使用根包允許你使用 @ComponentScan 注解而不需要定義一個 basePackage 屬性。如果main類位于根包中,你也可以使
用 @SpringBootApplication 注解
下面是一個典型的結構:
com
+- example
+- myproject
+- Application.java
|
+- domain
| +- Customer.java
| +- CustomerRepository.java
|
+- service
| +- CustomerService.java
|
+- web
+- CustomerController.java
Application.java 文件將聲明 main 方法,還有基本的 @Configuration 。
package com.example.myproject;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
//你不需要將所有的 @Configuration放進一個單獨的類。 @Import 注解可以用來導入其他配置類。另外,你也可以使用 @ComponentScan注解自動收集所有的Spring組件,包括 @Configuration 類。
@Configuration
@EnableAutoConfiguration
@ComponentScan
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
3.6 自動配置
- Spring Boot自動配置(auto-configuration)嘗試根據你添加的jar依賴自動配置你的Spring應用。例如,如果你的classpath下
存在 HSQLDB ,并且你沒有手動配置任何數據庫連接beans,那么我們將自動配置一個內存型(in-memory)數據庫。
你可以通過將 @EnableAutoConfiguration 或 @SpringBootApplication 注解添加到一個 @Configuration 類上來選擇自動配置。 - 注:你只需要添加一個 @EnableAutoConfiguration 注解。我們建議你將它添加到主 @Configuration 類上。
- 禁用特定的自動配置
如果發現應用了你不想要的特定自動配置類,你可以使用 @EnableAutoConfiguration 注解的排除屬性來禁用它們。
import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
import org.springframework.context.annotation.*;
@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}
3.7 Spring Beans和依賴注入
- 你可以自由地使用任何標準的Spring框架技術去定義beans和它們注入的依賴。簡單起見,我們經常使用 @ComponentScan 注解
搜索beans,并結合 @Autowired 構造器注入。 - 如果使用上面建議的結構組織代碼(將應用類放到根包下),你可以添加 @ComponentScan 注解而不需要任何參數。你的所有
應用程序組件( @Component , @Service , @Repository , @Controller 等)將被自動注冊為Spring Beans。
下面是一個 @Service Bean的示例,它使用構建器注入獲取一個需要的 RiskAssessor bean。
package com.example.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class DatabaseAccountService implements AccountService {
private final RiskAssessor riskAssessor;
@Autowired
public DatabaseAccountService(RiskAssessor riskAssessor) {
this.riskAssessor = riskAssessor;
}
// ...
}
注:注意如何使用構建器注入來允許 riskAssessor 字段被標記為 final ,這意味著 riskAssessor 后續是不能改變的。
3.8 @SpringBootApplication注解的解釋
/**
很多Spring Boot開發者總是使用 @Configuration , @EnableAutoConfiguration 和 @ComponentScan 注解他們的main類。由于這些
注解被如此頻繁地一塊使用(特別是你遵循以上最佳實踐時),Spring Boot提供一個方便的 @SpringBootApplication 選擇。
該 @SpringBootApplication 注解等價于以默認屬性使用 @Configuration , @EnableAutoConfiguration 和 @ComponentScan 。
*/
package com.test;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import com.test.controller.SpringbootDemo;
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootDemo.class, args);
}
}
努力更新中......