黑马程序员java web学习笔记--后端进阶(二)SpringBoot原理

目录

1 配置优先级

2 Bean的管理

2.1 Bean的作用域

2.2 第三方Bean

3 SpringBoot原理

3.1 起步依赖

3.2 自动配置

3.2.1 实现方案

3.2.2 原理分析

3.2.3 自定义starter


1 配置优先级

SpringBoot项目当中支持的三类配置文件:

  • application.properties
  • application.yml ❤
  • application.yaml

配置文件优先级排名(从高到低):properties配置文件 > yml配置文件 > yaml配置文件

虽然springboot支持多种格式配置文件,但是在项目开发时,推荐统一使用一种格式的配置。(yml是主流)

2 Bean的管理

2.1 Bean的作用域

IOC容器当中,默认bean对象是单例的 (只有一个实例对象),可以借助Spring中的@Scope注解来进行配置作用域。

作用域说明
singleton容器内同名称的bean只有一个实例(单例)(默认)
prototype每次使用该bean时会创建新的实例(非单例)
  • 默认singleton的bean,在容器启动时被创建,可以使用@Lazy注解来延迟初始化(延迟到第一次使用时)
  • prototype的bean,每一次使用该bean的时候都会创建一个新的实例。
  • 实际开发当中,绝大部分的bean是单例的,也就是说绝大部分bean不需要配置scope属性。
面试题 1:Spring 容器的 bean 是单例的还是多例的?单例的 bean 是什么时候实例化的?默认是单例的单例的 bean,默认是项目启动时实例化的(通过 @Lazy 可以延迟初始化)

面试题 2:Spring 容器的 bean 是线程安全的吗?bean 的线程安全取决于 bean 的状态及 bean 的作用域单例 bean:如果是无状态的 bean,内部不保存任何状态信息,则是线程安全的。单例 bean:如果是有状态的 bean,内部会保存状态信息,多个线程会同时操作该 bean 时,可能会出现数据不一致的问题,这样的 bean 则是线程不安全的。

2.2 第三方Bean

之前我们所配置的bean,像controller、service,dao三层体系下编写的类,这些类都是我们在项目当中自己定义的类(自定义类)。当我们要声明这些bean,也非常简单,我们只需要在类上加上@Component以及它的这三个衍生注解(@Controller@Service@Repository),就可以来声明这个bean对象了。

但是在我们项目开发当中,还有一种情况就是这个类它不是我们自己编写的,而是我们引入的第三方依赖当中提供的,那么此时我们是无法使用 @Component 及其衍生注解来声明bean的,此时就需要使用@Bean注解来声明bean 了。

若要管理的第三方 bean 对象,建议对这些bean进行集中分类配置,可以通过 @Configuration 注解声明一个配置类。【推荐】

package com.itheima.config; import com.itheima.utils.AliyunOSSOperator; import com.itheima.utils.AliyunOSSProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class OSSConfig { @Bean public AliyunOSSOperator aliyunOSSOperator(AliyunOSSProperties ossProperties) { return new AliyunOSSOperator(ossProperties); } }

3 SpringBoot原理

3.1 起步依赖

起步依赖的原理就是Maven的依赖传递。

  • 在SpringBoot给我们提供的这些起步依赖当中,已提供了当前程序开发所需要的所有的常见依赖(官网地址:https://docs.spring.io/spring-boot/docs/2.7.7/reference/htmlsingle/#using.build-systems.starters)。
  • 比如:springboot-starter-web,这是web开发的起步依赖,在web开发的起步依赖当中,就集成了web开发中常见的依赖:json、web、webmvc、tomcat等。我们只需要引入这一个起步依赖,其他的依赖都会自动的通过Maven的依赖传递进来。

3.2 自动配置

3.2.1 实现方案

方案一:思考:引入进来的第三方依赖当中的bean以及配置类为什么没有生效?

  • 原因在我们之前讲解IOC的时候有提到过,在类上添加@Component注解来声明bean对象时,还需要保证@Component注解能被Spring的组件扫描到。
  • SpringBoot项目中启动类的@SpringBootApplication注解,具有包扫描的作用,但是它只会扫描启动类所在的当前包以及子包。
  • 当前包:com.itheima, 第三方依赖中提供的包:com.example(扫描不到)

那么如何解决以上问题的呢?

  • 方案1:@ComponentScan 组件扫描(繁琐、性能低)
  • 方案2:@Import 导入(使用@Import 导入的类会被Spring加载到IOC容器中)❤

方案二:@Import导入,主要有以下几种:

  • 导入普通类
  • 导入配置类
  • 导入ImportSelector接口实现类

如果基于以上方式完成自动配置,当要引入一个第三方依赖时,是不是还要知道第三方依赖中有哪些配置类和哪些Bean对象?答案:是的。 (对程序员来讲,很不友好,而且比较繁琐)

结论:我们不用自己指定要导入哪些bean对象和配置类了,让第三方依赖它自己来指定。

怎么让第三方依赖自己指定bean对象和配置类?

答案:比较常见的方案就是第三方依赖给我们提供一个注解,这个注解一般都以@EnableXxxx开头的注解,注解中封装的就是@Import注解

  • 使用第三方依赖提供的 @EnableXxxxx注解(方便 优雅)❤

3.2.2 原理分析

在@SpringBootApplication注解中包含了:

1.元注解(不再解释)

2.@SpringBootConfiguration

该改注解上使用了@Configuration,表明SpringBoot启动类就是一个配置类

3.@EnableAutoConfiguration(自动配置核心注解)

  • 封装了@Import注解(Import注解中指定了一个ImportSelector接口的实现类)。
  • 在实现类重写的selectImports()方法,读取当前项目下所有依赖jar包中META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports两个文件里面定义的配置类(配置类中定义了@Bean注解标识的方法)。
  • 当SpringBoot程序启动时,就会加载配置文件当中所定义的配置类,并将这些配置类信息(类的全限定名)封装到String类型的数组中,最终通过@Import注解将这些配置类全部加载到Spring的IOC容器中,交给IOC容器管理。

4.@ComponentScan

用来进行组件扫描的,扫描启动类所在的包及其子包下所有被@Component及其衍生注解声明的类。

问题:在 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports 文件中定义的配置类非常多,而且每个配置类中又可以定义很多的bean,那这些bean都会注册到Spring的IOC容器中吗?
答案:并不是。 在声明bean对象时,上面有加一个以 @Conditional 开头的注解,这种注解的作用就是按照条件进行装配,只有满足条件之后,才会将bean注册到Spring的IOC容器中。

3.2.3 自定义starter

所谓starter指的就是SpringBoot当中的起步依赖。在SpringBoot当中已经给我们提供了很多的起步依赖了,我们为什么还需要自定义 starter 起步依赖?

这是因为在实际的项目开发当中,我们可能会用到很多第三方的技术,并不是所有的第三方的技术官方都给我们提供了与SpringBoot整合的starter起步依赖,但是这些技术又非常的通用,在很多项目组当中都在使用。

业务场景:

  • 我们前面案例当中所使用的阿里云OSS对象存储服务,现在阿里云的官方是没有给我们提供对应的起步依赖的,这个时候使用起来就会比较繁琐,我们需要引入对应的依赖。我们还需要在配置文件当中进行配置,还需要基于官方SDK示例来改造对应的工具类,我们在项目当中才可以进行使用。
  • 大家想在我们当前项目当中使用了阿里云OSS,我们需要进行这么多步的操作。在别的项目组当中要想使用阿里云OSS,是不是也需要进行这么多步的操作,所以这个时候我们就可以自定义一些公共组件,在这些公共组件当中,我就可以提前把需要配置的bean都提前配置好。将来在项目当中,我要想使用这个技术,我直接将组件对应的坐标直接引入进来,就已经自动配置好了,就可以直接使用了。我们也可以把公共组件提供给别的项目组进行使用,这样就可以大大的简化我们的开发。

在SpringBoot项目中,一般都会将这些公共组件封装为SpringBoot当中的starter,也就是我们所说的起步依赖。

而在springboot中,官方提供的起步依赖 或 第三方提供的起步依赖,基本都会包含两个模块,如下所示:

其中,spring-boot-starter  或  xxx-spring-boot-starter 这个模块主要是依赖管理的功能。 而 spring-boot-autoconfigure 或 xxxx-spring-boot-autoconfigure 主要是起到自动配置的作用,自动配置的核心代码就在这个模块中编写。

SpringBoot官方starter命名: spring-boot-starter-xxxx

第三组织提供的starter命名: xxxx-spring-boot-starter

而自动配置模块的核心,就是编写自动配置的核心代码,然后将自动配置的核心类,配置在核心的配置文件 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports 中。

Read more

PicoServer介绍:一款 .NET 生态的 轻量级 Web 请求胶水库,主打 “集成至上、灵活嵌入”,无需依赖 IIS、Kestrel 这类传统 Web 服务器

PicoServer介绍:一款 .NET 生态的 轻量级 Web 请求胶水库,主打 “集成至上、灵活嵌入”,无需依赖 IIS、Kestrel 这类传统 Web 服务器

最近发现一款新库 PicoServer ,用起来还不错,很有特色。 🛠️ PicoServer 是什么? PicoServer 是一款 .NET 生态的 轻量级 Web 请求胶水库,主打 “集成至上、灵活嵌入”,哪里需要 Web 能力,就粘哪里。 它无需依赖 IIS、Kestrel 这类传统 Web 服务器,可直接嵌入任意 .NET 应用快速搭建 Web API;开箱即用零配置,无需修改原有业务代码,无论是轻量级 Web API、WebSocket 实时通信、边缘计算 Web 服务,还是轻量流媒体服务器,用它都恰到好处。 C# 一行代码实现WebAPI MyAPI.AddRoute("/hello"

前端编程三剑客HTML、CSS、JavaScript 三者的关系详解

前端编程三剑客HTML、CSS、JavaScript 三者的关系详解

作为程序员,如果你是想单纯学习HTML,JavaScript或者CSS,其实它们是一家的三兄弟。你了解 HTML、CSS、JavaScript三者的关系吗,我们可以用“网页的三层架构”来通俗理解,三者分工明确、协同工作,共同构建出完整且交互丰富的网页。         精美的网页如果比作是一栋功能完备的房屋,那么 HTML 就是这栋房子坚实的砖混框架与墙体结构,它划定了房间的格局、门窗的位置,是房屋能立起来的基础骨架;CSS 是房屋的装修装饰 —— 从墙面的乳胶漆、地板的材质,到家具的风格、软装的搭配,让房屋拥有美观的样貌和舒适的视觉体验;而 JavaScript,就是让这栋房屋真正 “活” 起来的水电系统、智能设备与安防设施,是控制灯光的开关、调节温度的空调、感应开合的门窗,让房屋不再是冰冷的建筑,而是能响应需求、具备交互功能的宜居空间。         下面从核心定位、分工对比、协同关系三个维度详细讲解。         文章最后,举例说明了三者结合实现一个表格的功能,你能分清程序中哪个部分是CSS吗? 一、三者定位 把网页比作一座“房

StructBERT WebUI定制:情感分析仪表盘开发

StructBERT WebUI定制:情感分析仪表盘开发 1. 背景与需求:中文情感分析的现实挑战 在社交媒体、电商评论、客服对话等场景中,用户生成内容(UGC)呈爆炸式增长。如何从海量中文文本中快速识别公众情绪倾向,已成为企业舆情监控、产品反馈分析和客户服务优化的关键能力。 传统的情感分析方法依赖于词典匹配或浅层机器学习模型,存在语义理解不深、上下文感知弱、泛化能力差等问题。尤其面对中文复杂的语言结构——如否定句、反讽表达、多义词等——准确率往往难以满足实际业务需求。 随着预训练语言模型的发展,基于 StructBERT 的中文情感分类方案应运而生。它不仅继承了 BERT 强大的语义建模能力,还通过结构化预测任务进一步增强了对中文语法和语义关系的理解。然而,大多数开源实现仅提供命令行接口或 API 示例,缺乏直观易用的交互界面,限制了非技术用户的使用效率。 因此,构建一个集 WebUI 可视化操作 + RESTful API 接口服务 + CPU 轻量化部署 于一体的中文情感分析系统,具有极高的工程落地价值。 2.

自学高级 Web 安全全栈学习路线,从零基础到精通,收藏这篇就够了!

自学高级 Web 安全全栈学习路线,从零基础到精通,收藏这篇就够了!

自学高级 Web 安全全栈学习路线 高级 Web 安全全栈学习路线,深入了解 Web 安全的各个方面,从攻击到防御,逐步提升你的能力。 学习目标: * 精通 Web 应用的安全漏洞,攻击手段及防御机制 * 掌握常见的渗透测试工具,能够进行实战级的安全审计 * 理解 Web 安全架构和最佳实践,能够进行安全设计和安全代码审计 * 熟悉安全开发生命周期,确保开发过程中的安全性 学习时间:约 3 个月(每天 4-6 小时) 第1-2周:复习基础与 Web 安全概念 第1天-第3天:基础复习 * 操作系统安全:Linux、Windows命令行操作;文件权限管理,进程管理,系统日志分析等 * 计算机网络基础:深入理解 TCP/IP,HTTP、HTTPS,DNS,