1、spring-boot-dependencies 、spring-cloud-dependencies
定义了一堆版本依赖关系(只定义,不导入),可以通过CTRL + 点击来查看对应的pom文件
添加dependency的时候,如果依赖在spring-boot-dependencies中定义,则不需要写版本号
如果定义的版本号和spring-boot-dependencies定义的版本号不一致,则用新定义的
2、启动器 spring-boot-starter-*
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
如上就会自动导入web环境的依赖,可以通过CTRL + 点击来查看对应的pom文件
3、主程序
@SpringBootApplication 和main方法中加入 SpringApplication.run()
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
// 标注是SpringBoot启动类
@SpringBootApplication
public class MyApplication{
public static void main(String[] args) {
// 启动SpringBoot
SpringApplication.run(MyApplication.class, args);
}
}
为什么这么配置注解就能启动了springboot
1、查看@SpringBootApplication注解源码
@SpringBootConfiguration // SpringBoot配置类,启动类下的所有资源被导入
// 点进去是 @Configuration, 配置类
// 再点进去是 @Component 组件
@EnableAutoConfiguration // 自动导入配置,
// 点进去是@AutoConfigurationPackage 自动配置包
// 再点进去 @Import(AutoConfigurationPackages.Registrar.class) 导入注册类
// 再点Registrar进去 实现了ImportBeanDefinitionRegistrar(注册metadata), DeterminableImports
//@Import(AutoConfigurationImportSelector.class) 导入选择器(自动导入pom依赖)
//List<String> getCandidateConfigurations 获取候选配置
// 从哪里获取配置,从@EnableAutoConfiguration注解的类导入
// 找 META-INF/spring.factories 在依赖包 org.springframework.boot.spring-boot-autoconfigure/META-INF/spring.factories
//是否导入通过注解@ConditionalOnClass(判断条件) 来判断
// 配置了对应的spring-boot-starter-*,则@ConditionalOnClass 生效,则加入候选
// 扫描当前主启动类同级的包
@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })