(四)Spring Boot官网文档学习
关于默认包的问题
在 java 中,如果我们把一个 java 类,不放到特定包里面,则默认放到 默认包 里面,在使用 Spring Boot 的时候,要避免这样做,因为这样做,会导致使用 @ComponentScan, @EntityScan, or @SpringBootApplication 注解出现一些问题;
加载启动类
Spring Boot 建议我们将,启动类,放在所有类之上,根包下面,因为启动类上面的 @SpringBootApplication 注解,有个隐式的扫描包的动作,它会扫描他所在包下面的所以包,这样就省去我们使用 @ComponentScan 注解进行手动扫描了;
官网建议我们包格式如下:
com
+- example
+- myapplication
+- Application.java
|
+- customer
| +- Customer.java
| +- CustomerController.java
| +- CustomerService.java
| +- CustomerRepository.java
|
+- order
+- Order.java
+- OrderController.java
+- OrderService.java
+- OrderRepository.java
可以看到启动类 Application.java 在所有类的上面;
如果不想使用 @SpringBootApplication 可以使用 @EnableAutoConfiguration and @ComponentScan 两个注解替换,完成一样的效果;
@EnableAutoConfiguration
@ComponentScan(value = "hello")
// @SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
配置
-
基于
java类在
Spring Boot里面,推荐使用基于java类的配置,而不去使用基于xml的配置,杜绝任何xml文件的产生;官网建议的做法是:创建一个单例的
java类,使用@Configuration标识为配置类,该类里面进行各种配置,因为Spring Boot支持基于java的配置 ;但是不需要将所有的配置,都放在一个
java里面,可以使用@Import注解导入其他配置类,或者使用@ComponentScan注解,扫描所有的类,这样也就自动的导入了配置类; -
导入
xml文件如果项目必须使用到
xml文件,官方依然建议先创建一个配置类,进行其他配置,然后使用注解@ImportResource导入xml文件的配置 ; -
自动配置(
Auto-configuration)Spring Boot会自动配置依赖,根据你在pom文件里面配置的依赖,你只需要将注解@EnableAutoConfiguration或@SpringBootApplication配置到任何一个配置类上,即可获得Auto-configuration的功能 ;自动配置是非侵入性的;比如你添加了数据源的依赖,则自动配置,会在你没有配置数据源实例的时候,进行自动配置,一旦你自己配置了,则自动配置将取消之前的配置;
还可以禁止某些配置的自动配置,在配置上使用注解
@EnableAutoConfigurationimport org.springframework.boot.autoconfigure.*; import org.springframework.boot.autoconfigure.jdbc.*; import org.springframework.context.annotation.*; @Configuration @EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class}) public class MyConfiguration { }如果要禁止的类不在类路径下面,则使用
excludeName值为类的全限定名来替换掉exclude:
Bean管理和依赖注入
官方建议使用 @ComponentScan 扫描 beans,然后使用 @Autowired 进行属性的注入 ;
如果我们按照上面我说的 加载启动类 那样做。则我们可以直接使用不带参数的@ComponentScan 所有应用程序组件(@ Component,@ Service,@ Repository,@ Controller等),注册 Beans ;
就像下面这样,直接使用 @Service 创建一个 service 层 的 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;
}
// ...
}
如果 bean 只有一个构造器,则 @Autowired 可以被省略:
@Service
public class DatabaseAccountService implements AccountService {
private final RiskAssessor riskAssessor;
public DatabaseAccountService(RiskAssessor riskAssessor) {
this.riskAssessor = riskAssessor;
}
// ...
}
@SpringBootApplication
一个 @SpringBootApplication 相当于下面三个注解:
@EnableAutoConfiguration根据依赖项自动配置项目@ComponentScan可以扫描本身所在包及其子包@Configuration配置类
Developer Tools
开发者工具;Spring Boot 还提供了一额外的工具包,提供一些开发时可能需要的功能,可以添加到 Maven 依赖里面:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
上述配置中的 optional 置为 true ,使得开发者工具,仅仅在开发环境中可以使用,也就是打成 jar 包的时候,将自动的被禁用;
关于 Developer Tools 的一些细节
-
缓存问题
Sping Boot支持一些库使用缓存功能;比如:模板引擎,会缓存已经编译过的模板,以避免重复解析模板文件;SpringMvc提供静态资源的时候,可以设置Http缓存头 ;但是缓存功能,可能会导致新的页面无法里面被访问,因此,
spring-boot-devtools工具包,默认禁用缓存选项;缓存配置(包括下面的配置),通常在
application.properties文件里面配置,spring-boot-devtools不需要手动去设置这些属性,只会自适应application.properties等配置文件的配置 ; -
日志级别
还可以打印出
Web请求的详细信息,只需要将spring.http.log-request-details置为true,否则默认是不打印详细信息的; -
自动重启
使用了工具包以后,将会监测类路径上的文件,一旦有文件发生改变,则自动重启项目,以及时得到修改反馈,在
IDEA中,更改完资源以后,需要build一下,以更新类路径下文件,触发自动重启 ;当决定类路径上的条目是否应该在更改时触发重新启动时,
DevTools会自动忽略名为spring-boot,spring-boot-devtools,spring-boot-autoconfigure,spring-boot-actuator和spring-boot-starter的项目。 -
排除资源
一些资源改动,我们整个项目重启,比如只是改变了模板元素这些,我们更希望的是,仅仅重新加载我们改动的,其他的不要重新加载 ;
默认情况下
/META-INF/maven,/META-INF/resources,/resources,/static,/public,或 /templates下面的资源改动,不会引起重启,只会引起局部重新加载;如果要自定义这些排除项,这样默认的排除项就没了:
spring.devtools.restart.exclude=static/**,public/**如果想保留默认的排除项,再继续添加新的排除项,使用:
spring.devtools.restart.additional-exclude=static/**,public/** -
其他触发重启路径
使用注解
spring.devtools.restart.additional-paths配置; -
禁用重启
如果想禁用重启,则配置
spring.devtools.restart.enabled为false,但是这样做,还是会初始化重新启动的类加载器,只是不会监视文件更改;在某些情况下,需要完全禁用,让它得不到加载,因为某些库不能与重新加载的类加载器一起使用,这时候需要这样做:
public static void main(String[] args) { System.setProperty("spring.devtools.restart.enabled", "false"); SpringApplication.run(MyApp.class, args); } -
使用触发器文件
仅针对特定文件的修改,才触发重启;使用
spring.devtools.restart.trigger-file配置下特定文件的路径地址 ;实现了序列化接口对象的改动,不会触发重启 ;

浙公网安备 33010602011771号