SpringBoot从0到实战3:了解依赖管理、自动配置

2024-06-06 21:43:49 浏览数 (2)

依赖管理

  • 父项目做依赖管理: 依赖管理:声明了所有开发中常用的依赖的版本号,自动版本仲裁机制。(依赖传递性原则)
代码语言:javascript复制
依赖管理(在入门的项目中使用下面这一段代码即可,starter是一组开发依赖的集合)
<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.4.RELEASE</version>
</parent>

他的父项目
 <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-dependencies</artifactId>
    <version>2.3.4.RELEASE</version>
  </parent>

声明了所有开发中常用的依赖的版本号,自动版本仲裁机制。 如果有一天对仲裁的版本不满意,那么在xml文件中写一段把自己想要的版本放入代码中即可,可以自定义修改版本号。 修改版本号步骤: 查看spring-boot-dependencies里面规定的当前依赖的版本用的key。 然后在项目里面重写配置即可。如下面代码所示修改了mysql的版本号。

代码语言:javascript复制
<properties>
        <mysql.version>5.1.43</mysql.version>
    </properties>
  • 开发导入starter场景启动器

1、见到很多 spring-boot-starter-* : *就是代表某种场景 例如:spring-boot-starter-web等。

2、只要引入starter,这个场景的所有常规需要的依赖我们都自动引入。

3、SpringBoot所有支持的场景,可以参考springboot的官方文档,除此之外还有第三方starter,如果还有其他场景可以使用自己创建的starter或第三方starter等。

代码语言:javascript复制
https://docs.spring.io/spring-boot/docs/current/reference/html/using-spring-boot.html#using-boot-starter

4、见到的 *-spring-boot-starter: 一般这样的写法是第三方为我们提供的简化开发的场景启动器。

5、对于所有的starter场景启动器最底层的依赖,这个就是springboot最核心的底层依赖。

代码语言:javascript复制
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter</artifactId>
  <version>2.3.4.RELEASE</version>
  <scope>compile</scope>
</dependency>
  • 以后引用默认依赖可以不写版本号。
  • 但引入非版本仲裁的jar需要写清楚依赖的版本号。

自动配置

SpringBoot自动配置:

  • 自动配置好Tomcat 1、引入Tomcat依赖。 2、配置Tomcat。
  • 自动配置好SpringMVC开发的全套组件 1、引入SpringMVC全套组件。 2、自动配好SpringMVC常用组件(功能) 在以前web.xml中以前要自己配置很多SpringMVC的东西。
  • 自动配置好Web的常见使用功能,例如字符编码的问题 1、配置好了Web开发的常见场景功能。
  • 默认的包结构 1、主程序所在包及其下面的所有子包里面的组件都会被默认扫描进来,无需以前的包扫描配置 2、想要改变扫描路径 @SpringBootApplication(scanBasePackages=“com.atguigu”) 或者@ComponentScan 指定扫描路径,这个时候可以改变包的扫描路径,主程序外的包也可以运行了。 同时注意到:
代码语言:javascript复制
@SpringBootApplication
等同于以下三个
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan("com.atguigu.boot")
  • 各种配置拥有默认值 1、默认配置最终都是映射到某个类上如:MultipartProperties 2、配置文件的值最终会绑定每个类上,这个类会在容器中创建对象
  • 按需加载所有自动配置项 1、非常多的starter,但是只会打开引入哪个场景所对应的配置,在starter中有一个包叫做autoconfigure,所有的场景配置都写在里面了。

0 人点赞