Spring Boot pom.xml
1.pom文件版本仲裁
1.父项目spring-boot-starter的parent
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
|
当前文件的父项目 以2.0.5.RELEASE 为例子 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.5.RELEASE</version> </parent> spring-boot-starter-parent的父项目 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.0.5.RELEASE</version> <relativePath>../../spring-boot-dependencies</relativePath> </parent>
这里面的依赖是来真正管理Spring Boot应用里面的所有依赖版本; <properties> <activemq.version>5.15.6</activemq.version> <antlr2.version>2.7.7</antlr2.version> <appengine-sdk.version>1.9.64</appengine-sdk.version> <artemis.version>2.4.0</artemis.version> <aspectj.version>1.8.13</aspectj.version> <assertj.version>3.9.1</assertj.version> <atomikos.version>4.0.6</atomikos.version> <bitronix.version>2.1.4</bitronix.version> .... <wsdl4j.version>1.6.3</wsdl4j.version> <xml-apis.version>1.4.01</xml-apis.version> <xml-maven-plugin.version>1.0.2</xml-maven-plugin.version> <xmlunit2.version>2.5.1</xmlunit2.version> </properties>
|
这是Spring的版本仲裁中心,以后导入的包不需要写版本号的,当然如果不在这里面的包,要写版本号
2.启动器 spring-boot-starter的web模块
1 2 3 4 5 6
|
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
|
这里导入了web模块正常运行所依赖的场景组件
spring-boot-starter: spring boot 的场景启动器,
spring boot将所有的功能场景抽取出来,做成一个个的starter(启动器),只需要在项目里面引入这些starter
相关场景的所有依赖都会导入进来,如果需要用什么场景,就导入什么场景的启动器
更多启动器
2.主程序类
1 2 3 4 5 6 7 8 9 10 11
|
public class {
public static void main(String[] args) { SpringApplication.run(HelloWorldMainApp.class,args); } }
|
==这里后面的我不是很清楚,需要再看<<07、尚硅谷_springboot_入门-helloworld细节-自动配置.avi>> 以及Spring 注解版==
由@SpringBootApplication标注的类,表明这个个类是SpringBoot的主配置类,Spring boot 就知道应该运行这个类的main方法来启动SpringBoot应用;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
|
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan( excludeFilters = {@Filter( type = FilterType.CUSTOM, classes = {TypeExcludeFilter.class} ), @Filter( type = FilterType.CUSTOM, classes = {AutoConfigurationExcludeFilter.class} )} ) public @interface SpringBootApplication {
|
@SpringBootConfiguration :Spring Boot的配置类;
标注在某个类上,表示这是一个Spring Boot的配置类;
@Configuration:配置类上来标注这个注解;
配置类 ——- 配置文件;配置类也是容器中的一个组件;@Component
@EnableAutoConfiguration:开启自动配置功能;
以前我们需要配置的东西,Spring Boot帮我们自动配置;@EnableAutoConfiguration告诉SpringBoot开启自动配置功能;这样自动配置才能生效;
1 2 3
|
@AutoConfigurationPackage @Import(EnableAutoConfigurationImportSelector.class) public @interface EnableAutoConfiguration {
|
@AutoConfigurationPackage:自动配置包
@Import(AutoConfigurationPackages.Registrar.class):
Spring的底层注解@Import,给容器中导入一个组件;导入的组件由
AutoConfigurationPackages.Registrar.class;
==将主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件扫描到Spring容器;==
@Import(EnableAutoConfigurationImportSelector.class);
给容器中导入组件?
EnableAutoConfigurationImportSelector:导入哪些组件的选择器;
将所有需要导入的组件以全类名的方式返回;这些组件就会被添加到容器中;
会给容器中导入非常多的自动配置类(xxxAutoConfiguration);就是给容器中导入这个场景需要的所有组件,
并配置好这些组件;
==Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将==
==这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;==以前我们需要自己配置的东
西,自动配置类都帮我们;
J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-1.5.9.RELEASE.jar;
==Spring注解版(谷粒学院)==
近期评论