springboot入門之路(二)
- 繼springboot入門之路(一)連續(xù)的學(xué)習(xí)漸進(jìn)之路费变。
閱讀springboot入門之路(一)點(diǎn)擊:springboot入門之路(一)
3.springboot配置及注意事項(xiàng)
3.1繼承starter parent
- 想配置你的項(xiàng)目繼承 spring-boot-starter-parent 只需要簡單地設(shè)置 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>
- 注:你應(yīng)該只需要在該依賴上指定Spring Boot版本谴忧。如果導(dǎo)入其他的starters胖眷,你可以放心的省略版本號忘嫉。
3.2使用沒有父POM的Spring Boot
不是每個人都喜歡繼承 spring-boot-starter-parent POM鞭光。你可能需要使用公司標(biāo)準(zhǔn)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 選擇相當(dāng)保守的Java兼容策略。如果你遵循我們的建議幌陕,使用最新的Java版本诵姜,你可以添加一
個 java.version 屬性:
<properties>
<java.version>1.8</java.version>
</properties>
3.4使用"default"包
- 當(dāng)類沒有包含 package 聲明時,它被認(rèn)為處于 default package 下搏熄。通常不推薦使用 default package 棚唆,并應(yīng)該避免使用它。因
為對于使用 @ComponentScan 搬卒, @EntityScan 或 @SpringBootApplication 注解的Spring Boot應(yīng)用來說瑟俭,來自每個jar的類都會被讀
取,這會造成一定的問題契邀。
3.5 定位main應(yīng)用類
- 我們通常建議你將main應(yīng)用類放在位于其他類上面的根包(root package)中摆寄。通常使用 @EnableAutoConfiguration 注解你的
main類,并且暗地里為某些項(xiàng)定義了一個基礎(chǔ)“search package”坯门。例如微饥,如果你正在編寫一個JPA應(yīng)用,
被 @EnableAutoConfiguration 注解的類所在包將被用來搜索 @Entity 項(xiàng)古戴。
使用根包允許你使用 @ComponentScan 注解而不需要定義一個 basePackage 屬性欠橘。如果main類位于根包中,你也可以使
用 @SpringBootApplication 注解
下面是一個典型的結(jié)構(gòu):
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放進(jìn)一個單獨(dú)的類。 @Import 注解可以用來導(dǎo)入其他配置類叉袍。另外始锚,你也可以使用 @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)嘗試根據(jù)你添加的jar依賴自動配置你的Spring應(yīng)用瞧捌。例如,如果你的classpath下
存在 HSQLDB 润文,并且你沒有手動配置任何數(shù)據(jù)庫連接beans姐呐,那么我們將自動配置一個內(nèi)存型(in-memory)數(shù)據(jù)庫。
你可以通過將 @EnableAutoConfiguration 或 @SpringBootApplication 注解添加到一個 @Configuration 類上來選擇自動配置典蝌。 - 注:你只需要添加一個 @EnableAutoConfiguration 注解曙砂。我們建議你將它添加到主 @Configuration 類上。
- 禁用特定的自動配置
如果發(fā)現(xiàn)應(yīng)用了你不想要的特定自動配置類骏掀,你可以使用 @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和依賴注入
- 你可以自由地使用任何標(biāo)準(zhǔn)的Spring框架技術(shù)去定義beans和它們注入的依賴乔夯。簡單起見,我們經(jīng)常使用 @ComponentScan 注解
搜索beans款侵,并結(jié)合 @Autowired 構(gòu)造器注入末荐。 - 如果使用上面建議的結(jié)構(gòu)組織代碼(將應(yīng)用類放到根包下),你可以添加 @ComponentScan 注解而不需要任何參數(shù)新锈。你的所有
應(yīng)用程序組件( @Component , @Service , @Repository , @Controller 等)將被自動注冊為Spring Beans甲脏。
下面是一個 @Service Bean的示例,它使用構(gòu)建器注入獲取一個需要的 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;
}
// ...
}
注:注意如何使用構(gòu)建器注入來允許 riskAssessor 字段被標(biāo)記為 final 块请,這意味著 riskAssessor 后續(xù)是不能改變的。
3.8 @SpringBootApplication注解的解釋
/**
很多Spring Boot開發(fā)者總是使用 @Configuration 拳缠, @EnableAutoConfiguration 和 @ComponentScan 注解他們的main類墩新。由于這些
注解被如此頻繁地一塊使用(特別是你遵循以上最佳實(shí)踐時),Spring Boot提供一個方便的 @SpringBootApplication 選擇窟坐。
該 @SpringBootApplication 注解等價于以默認(rèn)屬性使用 @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);
}
}
努力更新中......