构建系统
依赖管理
-
spring boot 项目默认提供了很多依赖库,所以在我们的应用依赖一些库的时候不用提供版本号,比如添加 mysql 驱动(这里并没有添加版本号)
- 怎么判断依赖是否已经添加进来(按住ctrl,将鼠标放到依赖上面去,会出现库的路径)
-
parent 项目里面的依赖
Starters
- starter 是spring boot 里面的概念,它能很方便的描述依赖,比如如果我们需要开发web,web 开发其实是需要依赖很多东西的(spring mvc,spring web ,validator之类的),但是在spring boot 里面只需要依赖一个web starter 就可以了
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
-
通过IDEA的Maven Projects面板可以查看 每个starter究竟依赖了些什么库(starter里面还可以依赖starter 这是个树结构)
- spring boot 支持的starter列表
代码结构
-
将入口文件放到根包下面,类似(这样默认就会扫描到子包里面的组件)
入口文件需要一个main方法,并用@SpringBootApplication标记入口类
@SpringBootApplication
public class App {
public static void main(String[] args){
SpringApplication.run(App.class,args);
}
}
配置信息
- 推荐使用java来配置,注解是@Configuration,如果需要配置一个Bean,可以使用类似以下的代码
@Configuration
public class DataSourceConfig {
@Bean
public DataSource dataSource(){
return new MysqlDataSource();
}
}
- spring boot 的自动配置,spring boot默认给我们提供了很多配置好的 bean 。这些配置都在 spring-boot-autoconfigure项目里面,我们可以打开依赖看看(里面分了不同的模块 注册了各种 bean)
- 不使用默认的配置(有些时候不想使用 spring boot 配置后的bean,我们也可以自己配置),这些bean的配置使用的是@EnableAutoConfiguration来驱动的,而以前我们使用的@SpringBootApplication注解默认就已经使用了EnableAutoConfiguration,所以我们可以使用类似以下的代码了去掉默认配置的bean
@Configuration
@EnableAutoConfiguration(exclude = WebMvcAutoConfiguration.class)
public class App {
public static void main(String[] args){
SpringApplication.run(App.class,args);
}
}
-
这里贴以下SpringBootApplication注解的源码,可以看到注解里面还使用了注解。从源码就可以看出来这个注解提供了什么功能,开启了自动配置,开启了组件扫描(这里就很清楚 为什么入口类需要放到根包下面了)。
Bean扫描和依赖
- 可以使用任何标准的spring方法去注入bean,和扫描bean(@ComponentScan)
End