springboot自动配置原理详解,springboot手动配置

  springboot自动配置原理详解,springboot手动配置

  00-1010如何实施新Spring Boot协议?依赖性管理特性1。父项目2。场景发射器2。自动配置1。自动配置组件2。默认包装结构3。各种配置都有默认值4。按需加载所有自动配置项目3。摘要

  00-1010在前面的helloworld示例中,我已经初步认识到springboot自动导入依赖项并完成配置。

  那么,springboot是如何实现的呢?

  00-1010我们先来看看前面内容示例中的pom.xml:

  !-导入父项目-父groupIdorg.springframework.boot/groupId artifactId spring-boot-starter-parent/artifactId version2.3.4.RELEASE/version/父依赖项依赖项groupIdorg.springframework.boot/groupId artifactId spring-boot-starter-web/artifactId/dependency/Dependencies在此添加了一个父项目,并且只导入了一个依赖于spring-boot-starter-web的依赖项。最后,我们所有的相关包都进来了。

  在整个过程中,不需要关心包装导向。

  00-1010每个springboot项目都有一个父项目,一般用于依赖管理。

  父项目中可能会声明很多依赖项,所以只要子项目继承了父项目,以后添加依赖项时就不需要添加版本号了。

  以上面为例,父项目使用的是springboot版本2.3.4.RELEASE,下面添加的依赖项就不需要写版本号了。

  (1)如何管理父项目的版本?

  你可以按住ctrl,然后点击这个父项来了解一下。

  我进来的时候发现他还有一个母项目spring-boot-dependencies。

  父groupIdorg.springframework.boot/groupId工件spring-boot-dependencies/工件version2.3.4.RELEASE/version/Parent继续进入Spring-Boot-Dependencies,您可以在下面看到一个属性选项卡:

  我们可能在开发中使用的几乎所有版本的jar包都在这里声明。

  继续看具体的dependencyManagement依赖管理,这里引用了properties中陈述的版本。

  例如:

  我看到左边有一个包是logback的,于是我搜索了一下,发现这里定义的版本是1.2.3。

  所以父项目的主要功能是依赖项管理,几乎声明了开发中常用的依赖项的版本号。

  (2)使用指定的版本。

  如果不使用自动仲裁版本,可以使用指定版本。

  比如mysql版本,自动仲裁的结果是8.0.21,但我只想用5.1.43版本。

  添加一个属性选项卡,并在其中声明版本。

  properties MySQL . version 5 . 1 . 43/MySQL . version/properties再看一下导入的依赖,已经变成指定版本了。

  >

2. 场景启动器

再来看下最开始导入的一个依赖spring-boot-starter-web:

 

  

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>

后续会见到更多的以spring-boot-starter命名的启动器。在官方文档里也有详细的说明

 

  

 

  什么是 starter?

  starter 一组需要依赖的集合描述,也就是通常我们只需要引入一个 starter,那么对应的整个开发场景就会引入了。

  比如想开始使用 Spring 和 JPA 进行数据库访问,那么就在项目中引入spring-boot-starter-data-jpa依赖项。

  另外,注意这里spring-boot-starter-*开头的是官方的启动器命名方式。

  这么说还有非官方的?是的,如果你觉得官方给你的 starter 场景还是不能满足你的使用需要,那么你可以自定义 starter。

  但是官方推荐自定义的命名方式使用thirdpartyproject-spring-boot-starter。

  至于为什么只导入一个 starter 就可以导入整个场景的依赖,其实还是跟上面父项目一样,maven 的依赖特性。

  进入到spring-boot-starter-web,往下翻,就可以看到开发 web 场景所用到的依赖了。

  

 

  所以,以后需要开发哪个场景,只要参考官方文档导入对应的启动器即可。

  

 

  

二、自动配置

这里再回顾一下之前的 helloworld 项目中,springboot 自动配置好了哪些东西:

 

  自动配好 tomcat自动配好 springMVC自动配好 web 常见功能,比如:字符编码问题默认的包结构:主程序所在包以及下面所有子包里的组件都会被默认扫描各种配置拥有默认值按需加载所有自动配置项......

 

  

1. 自动配置组件

不管自动配置好什么,步骤都是:先引入、再配置。

 

  比如 tomcat,那么前提是先引入了 tomcat 依赖,这就由上面第一部分内容所讲的依赖管理完成,在引入了 web starter 后,自动引入场景。

  自动引入了场景,也就引入了这个场景下所用到的各种 jar 包,接下来就是要配置这些内容,比如 tomcat、springMVC 等等。

  拿 springMVC 举例,在之前要使用 springMVC,肯定要配置DispatcherServlet,帮我们拦截所有请求。

  

<servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springMVC.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet>

现在看下之前的 helloworld 应用中,springboot 是在哪里帮我们做好配置的。

 

  先看主程序类:

  

// 标记这是一个 springboot应用,这个类是主程序类,所有启动的入口@SpringBootApplicationpublic class MainApplication { public static void main(String[] args) { SpringApplication.run(MainApplication.class, args); }}

可以创建个本地变量(alt+enter),可以看到这个是个ConfigurableApplicationContext类型。

 

  

 

  

@SpringBootApplicationpublic class MainApplication { public static void main(String[] args) { ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args); }}

可以使用getBeanDefinitionNames()方法,查看里面包含了哪些容器,遍历打印出来。

 

  

@SpringBootApplicationpublic class MainApplication { public static void main(String[] args) { // 返回IOC容器 final ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args); // 查看容器里的组件 final String[] beanDefinitionNames = run.getBeanDefinitionNames(); for (String name: beanDefinitionNames) { System.out.println(name); } }}

接下来启动应用,看下控制台输出。

 

  

 

  在控制台输出里ctrl+F搜索下DispatcherServlet:

  

 

  发现 IOC 容器中已经有了对应的组件。

  

 

  

2. 默认的包结构

主程序所在包以及下面所有子包里的组件都会被默认扫描,所以我们不需要配置开启组件扫描,也可以正常使用。

 

  但是要注意这里的范围:

  

 

  示例中就是com.pingguo.boot包下以及所有子包都可以自动扫描。

  如果你就是要放到外面,还希望被扫描到,怎么办?

  那么可以使用主程序类中@SpringBootApplication注解中的一个属性scanBasePackages,扩大包的范围即可:

  

@SpringBootApplication(scanBasePackages = "com.pingguo")public class MainApplication { public static void main(String[] args) {... ...

 

  

3. 各种配置拥有默认值

比如 tomcat端口,在application.properties配置文件里使用 idea 输入的时候,就可以看到带有默认值8080:

 

  

 

  点击进去可看到后面都是绑定了对应的 java 类。

  

 

  配置文件的值最终会绑定在对应的类上,这个类会在容器中创建对象。

  

 

  

4. 按需加载所有自动配置项

比如应用中只引入了spring-boot-starter-web,那么就只有web场景的自动配置才会开启。

 

  springboot 中的所有自动配置,都在这里:

  

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-autoconfigure</artifactId> <version>2.3.4.RELEASE</version> <scope>compile</scope> </dependency>

点击spring-boot-starter-web可以找到spring-boot-starter,再进入其中就可以看到spring-boot-autoconfigure。

 

  

 

  

三、小结

经过上面的步骤,我们开发应用就基本可以做到 0 配置,既方便又快捷。

 

  我理解是,springboot 通过各种巧妙的封装,把你可能要用到的场景下的一切都准备好,你需要用直接申明一下(引入场景)就好。

  帮助我们彻底摆脱配置地狱,专注于业务。

  以上就是SpringBoot自动配置实现详细过程的详细内容,更多关于SpringBoot自动配置过程的资料请关注盛行IT其它相关文章!

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: