Spring Boot 中的 “依赖管理和自动配置” 详解透彻到底(附 + 详细代码流程)
1. 如何理解 “ 约定优于配置 ”
约定优于配置(Convention over Configuration / CoC),又称约定编程,是一种软件设计规范,本质上是对系统,类库或框架中一些东西。
一个大众化合理的默认值(缺省值)
例如在模型中存在一个名为 User 的类,那么对应到数据库会存在一个名为 user 的表,只有偏离这个约定时才需要做相关的配置(例如你想将表名命名为:t_user 等非 user 时才需要写关于这个名字的配置)
简单来说就是假如你所期待的配置 与 约定的配置 一致,那么就可以不做任何配置,约定不符合期待时,才需要对约定进行替换配置。
约定优于配置:为什么要搞一个“约定优于配置”约定其实就是一个规范,遵循了规范,那么就存在通用性。存在了通用性,那么事情就会变得相对简单 ,程序员之间的沟通成本就会降低,工作效率会提升,合作也会变得更加简单。
生活中,这样的情况,大量存在:比如:两个都是男生,你说一起去上厕所去,那么,他们两个人都是(默认,约定好的都是去男生厕所,而特意说明是:去女生厕所。)
注意:误区:默认是采用约定的,但是你配置了,还是采用你的配置的信息的。
2. Spring Boot 依赖管理 和 自动配置
2.1 Spring Boot 的依赖管理
2.1.1 什么是依赖管理
spring-boot-starter-parent 还有父项目,声明了开发中常用的依赖的版本号
并且进行 自动版本仲裁 ,即如果程序员没有指定某个 依赖的
jar
的版本,则以父项目指定的版本为准。
data:image/s3,"s3://crabby-images/1c329/1c329273f5b64d2d8e911d2bb765849d8f8d6a80" alt=""
data:image/s3,"s3://crabby-images/99f97/99f97b845ac81e927ac3bdb2016aacb98060b900" alt=""
2.1.2 修改自动仲裁 / 默认版本号
如果 Spring Boot 当中默认配置的 jar
依赖的版本,不是,我们所想要的该如何配置修改成我们自己想要的呢。
如何修改 Spring Boot 当中对应 jar。
演示: 将 SpringBoot mysql 驱动修改成 5.1.49 版本的。
首先,我们先要学会如何查看到对应我们所需的 jar
在 Spring Boot 的默认配置当中使用的是什么版本的。
在 spring-boot-dependencies\2.5.3\spring-boot-dependencies-2.5.3.pom,中我们可以找到对应的
jar
包的依赖版本,如下图所示:这里 Spring Boot 对于 MySQL 的依赖默认配置是8.0.26
的
data:image/s3,"s3://crabby-images/dc142/dc142ead580916328e18327b9a29819176370d55" alt=""
查 看 spring-boot-dependencies.pom 里 面 规 定 当前 依 赖 的 版 本 对 应 的 key , 这 里 是 mysql.version
data:image/s3,"s3://crabby-images/418e9/418e99d1034233481e11628fcdbdcdf3413dfe46" alt=""
data:image/s3,"s3://crabby-images/01478/01478a7d0328d82eca5689e86683c80f0c7c7479" alt=""
修改 Spring Boot 当中对应 jar;有两种方式:
方式一: 直接在项目的
pom.xml
文件当中直接导入,自己想要的jar
的版本即可。方式二: 和方式一是一样的,不同的是编写方式,有所不同:“方式二:是将
jar
信息和jar的版本
信息分开来编写的了”。
方式一: 修改 pom.xml 重写配置 当更新 Maven 时,就依赖到新的 ,mysql 驱动。
直接导入我们自己想要的 依赖的jar
的配置,然后,更新 Maven 即可。
data:image/s3,"s3://crabby-images/e322e/e322ea8b73c0537ead8e73aa453eea478659ad50" alt=""
然后,我们在刷新 Maven,重新加载 jar
data:image/s3,"s3://crabby-images/27422/27422b416165c9ef3494d318ab0863d0084a774a" alt=""
注意: 如果配置的依赖
jar
包时,不指明就是 version 版本的话,就会采用 SpringBoot 约定好的(也就是默认的 8.26)版本的。如下:我们将指明的版本的 version 注释掉,再次更新,看看。
data:image/s3,"s3://crabby-images/09e9c/09e9caeff94dcaa55ba6f35c6f4133802067fc2c" alt=""
完整的 pom.xml
信息。
方式二: 将依赖jar
包的配置信息,和配置版本分开来编写。
在
<properties>
标签中,配置 jar 的版本信息 ,可以配置多个不同的 jar 的版本信息。在
<dependencies>
标签中,配置 jar 的 配置坐标信息 ,可以配置多个 jar
data:image/s3,"s3://crabby-images/107f2/107f27147f60a82fc0e92116b073516b0ccfa5ac" alt=""
更新 Maven ,重新加载 jar 。
data:image/s3,"s3://crabby-images/948e9/948e93a4696766345e8d4a97009b7a97dc154a07" alt=""
完整的 pom.xml
信息。
3.1 starter 场景启动器
3.1.1 starter 场景启动器的说明介绍
开发中我们引入了相关场景的 starter,这个场景中所有的相关依赖都引入进来了,比如:我们之前学习到的 web 开发引入了,该 starter 将导入与 web 开发相关的所有包。
data:image/s3,"s3://crabby-images/93a9f/93a9ff12786a82c81788dbd647da67929802e346" alt=""
data:image/s3,"s3://crabby-images/5bff7/5bff7a1b5d0839a27398745640dd803bd0e4f3a6" alt=""
依赖树 : 可以看到 spring-boot-starter-web ,帮我们引入了 spring-web mvc,spring-web 开发模块,还引入了 spring-boot-starter-tomcat 场景,spring-boot-starter-json 场景,这些场景下面又引入了一大堆相关的包,这些依赖项可以快速启动和运行一个项目,提高开发效率.
data:image/s3,"s3://crabby-images/0ab10/0ab10b2adc36399dc032ce2ddecee3ee5873bde1" alt=""
data:image/s3,"s3://crabby-images/1297a/1297a74ac4ab9efdd2caa09e50895682ca719d87" alt=""
所有场景启动器最基本的依赖就是 spring-boot-starter
, 前面的依赖树分析可以看到,
data:image/s3,"s3://crabby-images/8ab36/8ab364872dd61f4595feb17b9cc18f4631553af4" alt=""
data:image/s3,"s3://crabby-images/3f3a6/3f3a6af2ad27053ff8e2ffe8afc527e36aae3629" alt=""
这个依赖也就是 SpringBoot 自动配置的核心依赖
data:image/s3,"s3://crabby-images/ddd60/ddd605fcb93b65ba149465086dfaa5757610f5d0" alt=""
3.1.2 Spring Boot 官方提供的 starter 场景启动器
Spring Boot 官方提供的 starter 场景启动器的介绍说明:https://docs.spring.io/spring-boot/reference/using/build-systems.html#using.build-systems.starters 。
data:image/s3,"s3://crabby-images/5923e/5923edfc08f74f8492a9c0336a1d5181445dd186" alt=""
意思就是说:在开发中我们经常会用到 spring-boot-starter-xxx ,比如 spring-boot-starter-web,该场 景是用作 web 开发,也就是说 xxx 是某种开发场景。
这时候,我们只要引入 starter,这个场景的所有常规需要的依赖我们都自动引入。
Spring Boot3 支持的所有场景如下:官方地址:https://docs.spring.io/spring-boot/reference/using/build-systems.html#using.build-systems.starters
data:image/s3,"s3://crabby-images/adb53/adb53dcc955076480d85815305af11a386f9e613" alt=""
3.1.3 Spring Boot 支持的第三方 starter 场景启动器
Spring Boot 也支持第三方 starter。
第三方 starter 不要从 spring-boot 开始,因为这是官方 spring-boot 保留的命名方式的。第三方启动程序通常以项目名称开头,例如:名“XXx”的第三方启动程序项目通常被命名为:“XXx-spring-boot-stater”。
也就是说:xxx-spring-boot-starter 是第三方为我们提供的简化开发的场景启动器
4.1 Spring Boot 的自动配置
我们是否还记得,前面学习 SSM 整合时,需要配置 Tomcat ,配置 Spring MVC,以及配置如何扫描包,配置字符过滤器,配置视图解析器,文件上传等 ✏️✏️✏️ SSM 整合(Spring + MyBatis;Spring + Spring MVC)-CSDN博客 。非常麻烦。而在 Spring Boot 中,存在自动配置 机制,提高开发效率。
简单回顾以前 SSM 整合的配置:
data:image/s3,"s3://crabby-images/9dfbc/9dfbc179e1748dc44784b961206590a83d2495d3" alt=""
data:image/s3,"s3://crabby-images/fe082/fe0820bf34c62776dd9f298b9b95de26273984b5" alt=""
4.1.1 Spring Boot 自动配置有哪些
自动配置 Tomcat
data:image/s3,"s3://crabby-images/99184/9918400c9e60176f0793d0d077aee705aee6bb98" alt=""
自动配置了 Spring MVC
data:image/s3,"s3://crabby-images/43bf5/43bf54d1564b5e64090b69cd6bbaf2bdafbc22e0" alt=""
自动配置了 Web 常用功能: 比如 字符过滤器。
我们可以通过获取到的 ioc 容器,查看容器创建的组件来验证。
data:image/s3,"s3://crabby-images/07e98/07e989b8c7d668939189c98dbc59f98952d37797" alt=""
data:image/s3,"s3://crabby-images/2f0ff/2f0ffaace9e0a1fb9f131c18fac1c42197cc4fa1" alt=""
更加直接查看的方式:我们可以通过 Debug 的方式,在 ioc 打上断点,从而查看 ioc 容器中有哪些 Bean 对象被创建了。
data:image/s3,"s3://crabby-images/87af1/87af18ccd70d85a8809407a638b3435fc241fd15" alt=""
data:image/s3,"s3://crabby-images/97fad/97fadd2501de83de9d89abcb3805118ed11a45be" alt=""
data:image/s3,"s3://crabby-images/64085/6408580cf1a03b749f0aeeef8aa7639d9ae4ee9c" alt=""
data:image/s3,"s3://crabby-images/3ab68/3ab6860c878582e47214564a08a86a170aa657a3" alt=""
data:image/s3,"s3://crabby-images/2f337/2f3372af06f7eb000000ffe660d8e544a71fe6bd" alt=""
在 Spring Boot 的自动配置中,我们不需要像 Spring MVC 中一定要配置扫描包 。Spring Boot 有默认的扫描包结构。
如下是来自 Spring Boot 官方文档说明 【https://docs.spring.io/spring-boot/reference/using/structuring-your-code.html#using.structuring-your-code.using-the-default-package】的:自动扫描的包结构。你按照该“约定/自动扫描包结构”,开发项目,就不需要配置扫描包了,直接用 Spring Boot 约定的/默认的即可。
data:image/s3,"s3://crabby-images/2f731/2f7312ea4a72a85d011e5d5e2ec33898cd645894" alt=""
data:image/s3,"s3://crabby-images/1fb78/1fb7811a2a51eb28d8ec0d393bd0a290b8a73a6c" alt=""
4.1.2 如何修改 Spring Boot 中的默认配置
演示: 要求能扫描 com.rainbowsea 包下的 HiController.java 应该如何处理 ?
首先我们先测试一下,不按照 Spring Boot 默认的包结构创建的,主程序类。会怎么样。
在 quickstartBlog\src\main\java\com\rainbowsea\目录/包下创建一个,名为 HiController.java 主程序类。 并测试, 这时是访问不到的。
data:image/s3,"s3://crabby-images/9c95d/9c95d6674dd8a04d312454384f94b2f4c26a7333" alt=""
运行主程序,打开浏览器输入:http://localhost:8080/hi 测试。
data:image/s3,"s3://crabby-images/3cec1/3cec1883444b2f1137e31424493246a82d72a97f" alt=""
原因是:hello 配置的 HelloController 是在 Spring Boot 的默认自动配置的包结构下的,而我们的 hi 配置的 HiController 并不是在,Spring Boot 的自动配置打包结构下的,而我们自己有没有配置包扫描,Spring Boot 自然找不到了。
data:image/s3,"s3://crabby-images/0349c/0349caf485952c672e93a2a65906ae51fda9c36c" alt=""
5.1 如何修改默认配置
5.1.1 如何修改默认扫描包结构
上面我们测试了,在 com.rianbowsea 包下的 HiController.java 是扫描不到了,扫描不到,也就无法加入到 ioc 容器当中被 Spring Boot 管理起来了,也就无法被访问到了。
所以想要,让 HiController.java 可以被扫描到,就解决了这个,无法访问找不到的问题了。
方法:
我们修改 MainApp.java, 增加扫描的包 。
使用 @SpringBootApplication
注解当中的 scanBasePackages
注解属性,该属性的值:就是让 Spring Boot 扫描的,包路径。
data:image/s3,"s3://crabby-images/eea5d/eea5d34dd529b9ac8ec8323991df556143be259f" alt=""
data:image/s3,"s3://crabby-images/ca980/ca98094c10beef34b3aeaf974e79e615a377c5e7" alt=""
配置好之后,我们再次重启 ,运行试试。
data:image/s3,"s3://crabby-images/adf86/adf861c77402208c5813cc1a7584748c8b777621" alt=""
5.1.2 Spring Boot 中的 resources(类路径下)\application.properties 配置大全
SpringBoot 项目最重要也是最核心的配置文件就是 application.properties,所有的框架配 置都可以在这个配置文件中说明 :Spring Boot 框架中配置文件 application.properties 当中的所有配置大全-CSDN博客
5.1.3 演示:使用一些常用的配置
在 Spring Boot 中各种配置都有默认,而想要修改配置的话, 可 以 在 resources\application.properties 文件中修改。至于application.properties
文件是需要我们手动创建的。
特别注意:该文件名必须是
application.properties
,后缀也不可以修改。强烈建议将其放到 类的根路径下(也就是resources
目录下 )其次是,注意:在
.properties
后缀的配置文件,当中编写,不要有空格,尽量不要有空格。
如下:
演示一:我们设置该服务器 Tomcat ,我们项目启动的端口,默认是 8080,这里我们设置为 9090。
data:image/s3,"s3://crabby-images/1a591/1a591bbf42ca1fb13ad1305a8ebcc40b7421976f" alt=""
编写配置:设置修改 Server 的监听窗口为 9090
data:image/s3,"s3://crabby-images/39366/3936621cb706c19c8eadb022c6c5ff494a6516e1" alt=""
编写配置好后,运行主程序,重新加载程序,看看。
data:image/s3,"s3://crabby-images/bf0fd/bf0fd92d2e4c8ce9f5506be7adcd328f5e288c55" alt=""
data:image/s3,"s3://crabby-images/6bab1/6bab1e2e07c031af140039ee9fd6ddc3a22b52ff" alt=""
演示 2: 修改文件上传的大小;
data:image/s3,"s3://crabby-images/ab074/ab074926533c461c0f8725b0b531df582be4f0e8" alt=""
这里,我们想要看到效果的话,需要 Debug,打上断点,进行 Debug 调试才可以比较清除的看到效果。
data:image/s3,"s3://crabby-images/60bb3/60bb301241ba3df6476955d734143db2a944191c" alt=""
data:image/s3,"s3://crabby-images/eafdb/eafdb34424c810bb1f6165486e69c61029c94046" alt=""
data:image/s3,"s3://crabby-images/b9bca/b9bca9c97d69c83fdbfec0e4d39702d6c0bd991a" alt=""
演示三: 配置开始的项目根的映射路径 .
data:image/s3,"s3://crabby-images/12121/1212187a395d0450df6109441739f3c774dc6fc6" alt=""
重新启动程序,测试:
data:image/s3,"s3://crabby-images/017bf/017bf9283a55a6b30addb8e1db1fa25f3d72208d" alt=""
特别说明:讲解
上述的配置文件时在哪里读取的
比如:multipart.max-file-size,属性可以指定 SpringBoot 上传文件的大小限制(体现“约定优于配置”)
默认 Spring Boot 都会将其映射到某个类上,比如:multipart.max-file-size,会映射/关联到 MultipartProperties 类。配置都会被映射到相对应的类上的。
而我们将光标放在该属性,输入 ctrl + b,或者是按住 ctrl + 点击,就可以定位这个属性是管理到哪个类(属性)
data:image/s3,"s3://crabby-images/a17af/a17afd1333df363137ad2d4ee2be4b2e359bc7b2" alt=""
5.1.4 Spring Boot 中 application.properties 自定义配置
在 Spring Boot 中,我们还可以还在 .properties
文件中自定义配置,通过 @Value("${}")
的方式来获取对应属性值。
data:image/s3,"s3://crabby-images/63993/63993534081350b49fad47c756390159e9873de2" alt=""
data:image/s3,"s3://crabby-images/f9044/f904496c7ffea0e433ddaca074210ea00edfa6d8" alt=""
运行测试:
data:image/s3,"s3://crabby-images/47246/47246a33d54685f377cc64f3f990df60a4c08161" alt=""
当然,我们也时可以 将其 配置到 Bean 对象上的,只不过,配置到 Bean 对象上的话,有更好的方式,可以用 Spring Boot 的容器管理。
6.1 Spring Boot 中在哪里配置读取 application.properties 配置文件
打开 ConfigFileApplicationListener.java , 看一下源码;
data:image/s3,"s3://crabby-images/bc1fd/bc1fdcc92b6d8b3093d94e2d26958cc9e586869c" alt=""
data:image/s3,"s3://crabby-images/ccb13/ccb13ce10b13844656262ae7551963fe8b5f218e" alt=""
7.1 自动配置,遵守按需加载原则
自动配置遵守按需加载原则:也就是说,引入了哪个场景 starter启动器
就会加载该场景关联,的 jar 包,没有引入的 starter 则不会加载其关联 jar 。
data:image/s3,"s3://crabby-images/0544f/0544fd40d55200b8b130962d77dbdff0348b4541" alt=""
SpringBoot 所有的自动配置功能都在 spring-boot-autoconfigure 包里面;
data:image/s3,"s3://crabby-images/dbdad/dbdadf3169fb704686ad096e52639b9ebcbe3c3e" alt=""
在 Spring Boot 中的自动配置包,一般是 XXxAutoConfiguration.java 对应 XXxProperties.java,如图
data:image/s3,"s3://crabby-images/125bc/125bc6f4eeb5ae017c67e0e58bb8f4e6191d0824" alt=""
3. 总结:
Spring Boot 理解其中的 “约定优于配置”,又称约定编程,是一种软件设计规范,本质上是对系统,类库或框架中一些东西。减少不必要的配置,使用约定(默认的配置)吗。
Spring Boot 当中的 jar 版本的查看,以及 修改 Spring Boot 当中的 jar 版本的为字节所需。方式一: 直接在项目的
pom.xml
文件当中直接导入,自己想要的jar
的版本即可。方式二: 和方式一是一样的,不同的是编写方式,有所不同:“方式二:是将jar
信息和jar的版本
信息分开来编写的了”。Spring Boot 当中的 starter 场景启动器,Spring Boot 官方提供的 starter 场景启动器的介绍说明:https://docs.spring.io/spring-boot/reference/using/build-systems.html#using.build-systems.starters 。
Spring Boot 自动配置,Spring Boot 默认的扫描包结构,修改配置扫描包
Spring Boot 当中核心配置文件
application.properties
的理解和使用。application.properties
的每个配置属性,都对应这 Spring Boot 当中的某个类当中的某个属性,并且加入到了 ioc 容器当中。在 Spring Boot 中的自动配置包,一般是 XXxAutoConfiguration.java 对应 XXxProperties.java
文章转载自:Rainbow-Sea
原文链接:https://www.cnblogs.com/TheMagicalRainbowSea/p/18387661
评论