Spring Boot | SpringBoo“开发入门“

news/2024/4/29 5:04:44/文章来源:https://blog.csdn.net/m0_70720417/article/details/137029158

目录 :

    • 1.SpringBoot的“介绍”
      • SpringBoot”概述” :
      • SpringBoot”简介“
      • SpringBoot的“优点”
    • 2. SpringBoot入门程序
      • 环境准备
      • 使用 “Maven”方式构建SpringBoot 项目
      • 使用“Spring Initializr”方式构建Spring Boot 项目
    • 3. “单元测试” 和“热部署”
      • 单元测试
      • 热部署
    • 4. Spring Boot”原理分析”
      • 4.1Spring Boot”依赖管理“
        • spring-boot-starter-parent 依赖
        • spring-boot-starter-web 依赖
      • Spring Boot自动配置
        • @SpringBootConfiguration
        • @EnableAutoConfiguration

作者简介 :一只大皮卡丘,计算机专业学生,正在努力学习、努力敲代码中! 让我们一起继续努力学习!

该文章参考学习教材为:
《Spring Boot企业级开发教程》 黑马程序员 / 编著
文章以课本知识点 + 代码为主线,结合自己看书学习过程中的理解和感悟 ,最终成就了该文章

文章用于本人学习使用 , 同时希望能帮助大家。
欢迎大家点赞👍 收藏⭐ 关注💖哦!!!

(侵权可联系我,进行删除,如果雷同,纯属巧合)


1.SpringBoot的“介绍”

SpringBoot”概述” :

随着互联网的兴起,Spring 势如破竹地占据了Java领域“轻量级”开发王者之位。随着 Java语言的发展以及市场开发的需求,Spring推陈出新,推出了 全新的Spring Boot 框架Spring BootSpring家族 的一个 子项目,其 设计初衷是为了 简化Spring配置,从而让用户可以轻松构建独立运行的程序,并极大提高开发率

SpringBoot”简介“

  • SpringBoot框架出现之前JavaEE开发最常用的框架是SpringSpring框架开始于2003年,它是由罗德·约翰逊(Rod Johnson)创建的一个 轻量级开源框架Spring框架是为了 解决企业应用开发的复杂性创建 的,它的出现使得开发者无须开发重量级的Enterprise JavaBean( EJB ),而是通过 控制反转(IOC)面向切面编程(AOP) 的思想进行更轻松的企业应用开发取代了 EJB 臃肿低效的开发模式
  • 虽然Spring 框架是轻量级的,但 Spring的配置却是重量级Spring早期版本专注于 XML配置,开发一个程序需要 配置各种XML 配置文件为了简化开发,在Spring 2.x版本开始 引入少量的注解 : @Component、@Service 等。由于支持的注解不是很多且功能尚不完善,所以只能辅助使用
  • 随着 实际生产中敏捷开发需要,以及Spring 注解的大量出现功能改进,到了 Spring 4.x版本基本可以脱离XML配置文件进行项目开发多数开发者也逐渐感受到了基于注解开发便利,因此,在Spring 中使用注解开发逐渐占据了主流地位。与此同时,Pivotal 团队在原有Spring框架的基础上通过注解的方式进一步简化了Spring 框架的使用并基于Spring框架开发了全新的 SpringBoot框架,于 2014 年4月正式推出了 SpringBoot1.0 版本,同时在 2018 年3月又推出了 Spring Boot 2.0 版本。Spring Boot 2.x 版本在Spring Boot 1.x版本的基础上进行了诸多功能的改进和扩展,同时进行了大量的代码重构,所以选择合适的版也是非常重要的。 Spring Boot 3.02022年 11月24日正式发布 。
  • SpringBoot框架本身不提供Spring 框架核心特性以及扩展功能,只是用于 快速敏捷地开发新一代基于 Spring 框架应用,并且在开发过程中大量使用“约定优先配置”( convention over configuration )的思想来 摆脱 Spring 框架各种复杂手动配置,同时衍生出了 Java Config ( 取代传统XML配置文件Java 配置类)这种优秀的配置方式。也就是说, Spring Boot 并不是替代 Spring 框架解决方案,而是和 Spring框架紧密结合 用于 提升Spring开发者体验工具,同时Spring Boot 还集成了大量常用的 第三方库配置 ( 例如JacksonJDBCRedisMail 等)。使用 Spring Boot 开发程序时,几乎是 开箱即用 (out-of-the-box ),大部分 Spring Boot 应用只需少量配置就能完成相应的功能,这一特性进一步 促使开发者专注于业务逻辑实现
  • Spring Boot框架的出现恰好完美地 解决了怎么快速便捷地构建一个准生产环境的Spring应用 这些问题,同时其内部还 简化了许多常用第三方库配置,使得微服务开发更加便利

SpringBoot的“优点”

相较于传统的 Spring 框架Spring Boot 框架 具有以下 优点 :

    1. 可快速构建独立Spring 应用 :
      Spring Boot 是一个
      依靠大量注解
      实现 自动化配置全新框架。在构建 Spring 应用时,我们 添加 相应的场景 依赖Spring Boot 就会根据添加的场景依赖 自动进行配置,在 无须额外手动添加配置 的情况下快速构建出一个独立的Spring 应用
    1. 直接嵌入TomcatJettyUndertow服务器 ( 无须部署WAR文件 ,无需手动打包) :
      传统的 Spring 应用部署时,通常会将应用打成WAR 包形式并部署TomcatJettyUndertow服务器 ( 传统Spring项目要手动打包,而SpringBoot开发不需要手动打包 )中。SpringBoot 框架 内嵌TomcatJettyUndertow服务器SpringBoot自动将项目打包 (不用手动打包)并在项目运行部署到服务器中
    1. 通过 “依赖启动器” 简化构建配置 :
      SpringBoot 项目构建过程中,无须准备各种独立JAR 文件,只需在构建项目时根据开发场景需求选择对应的 依赖启动器starter,在引入的依赖启动器“starter”内部已经包含了对应开发场景所需的依赖,并会自动下载拉取相关JAR包
      例如,在Web 开发时,只需在构建项目时选择对应的 Web场景依赖 启动器 spring-boot-starter-webSpring Boot项目便会 自动导入spring-webmvcspring-webspring-boot-starter-tomcat等子依赖,并自动下载获取 Web 开发需要相关JAR 包
    1. 自动化配置 Spring和第三方库 :
      SpringBoot 充分考虑到与传统Spring 框架以及其他第三方库融合场景,在提供了各种 场景依赖启动器 的基础上,内部还默认 提供了各种 自动化配置类( 例如RedisAuto Configuration )。使用 SpringBoot开发项目时,一旦 引入了某个场景依赖启动器SpringBoot内部提供默认自动化配置类就会生效,开发者无须手动配置文件中进行相关配置 ( 除非开发者需要更改默认配置),从而极大减少了开发人员工作量提高了程序的开发效率
    1. 提供生产就绪功能 :
      SpringBoot 提供了一些 用于生产环境运行时特性,例如 指标监控检查外部化配置。其中,指标监控检查可以帮助运维人员运维期间监控项目运行情况外部化配置可以使运维人员快速、方便地进行外部化配置和部署工作
    1. 极少的代码生成极少的XML配置

      SpringBoot 框架内部已经实现了与Spring以及其他常用第三方库整合连接,并提供了默认最优化整合配置使用时基本上不需要额外生成配置代码XML配置文件。在需要自定义配置的情况下,SpringBoot 更加提倡使用Java config( Java配置类) 替换传统XML配置方式,这样更加方便查看和管理。

2. SpringBoot入门程序

环境准备

  • JDK环境 :
    SpringBoot 2.0及以上版本要求的JDK版本最低Java 8
  • 项目构建工具 :需要使用 MavenGradle 。如 : SpringBoot 2.1.3 要求 Maven ( 3.3 + )
    Gradle ( 4.4+ )
  • 开发工具 : IntelliJIDEA ,其在 智能代码助手重构各类版本工具( GitSVN 等)支持等方面的功能非常不错

使用 “Maven”方式构建SpringBoot 项目

  • 第一步添加SpringBoot依赖

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.myh</groupId><artifactId>chapter_01</artifactId><version>1.0-SNAPSHOT</version><!-- "依赖启动器"的parent依赖 : 统一父类管理依赖  --><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version></parent><dependencies><!-- 引入web开发依赖 (引入“web场景依赖”)   --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency></dependencies></project>
    
  • 第二步编写主程序启动类

    package com.myh;import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;/*** "主程序类" 和有"操作代码的"包和文件要在同一个文件夹下*/
    @SpringBootApplication //标记该类为"主程序启动类"
    public class ManualChapter01Application {//主程序启动方法public static void main(String[] args) {SpringApplication.run(ManualChapter01Application.class, args);}
    }
    

    上述代码中,@SpringBootApplication注解Spring Boot 框架核心注解,该注解用于表明ManualChapter01Application类Spring boot项目主程序启动类。然后调用SpringApplication对象的 .run( )方法启动主程序类

  • 第三步、创建一个 用于Web访问的Controller

    package com.myh.controller;import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;@RestController // 组合注解 : 该注解 = @ResponseBody + @Controller
    public class HelloController {@GetMapping("/hello")public String hello() {return "hello Spring Boot";}
    }
    

    运行 主程序启动类启动成功后,此时在浏览器上访问 http://localhost:8080/hello 。

使用“Spring Initializr”方式构建Spring Boot 项目

  • 除了可以使用Maven方式构建SpringBoot 项目外,还可以通过 Spring Initializr 方式快速构建 Spring Boot 项目从本质上说SpringInitializr 是一个 Web 应用,它提供了一个基本的项目结构,能够帮助我们快速构建一个基础Spring Boot 项目
    在这里插入图片描述

  • 具体的代码文件

    Chapter02Application.java :

    package com.myh.chapter_02;import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
    public class Chapter02Application {public static void main(String[] args) {SpringApplication.run(Chapter02Application.class, args);}
    }
    

    HelloController.java

    package com.myh.chapter_02.controller;import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;@RestController // 组合注解 : 该注解 = @ResponseBody + @Controller
    public class HelloController {@GetMapping("/hello2")public String hello() {return "hello Spring Boot2";}
    }
    

    pom.xml :

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.myh</groupId><artifactId>chapter_02</artifactId><version>0.0.1-SNAPSHOT</version><name>chapter_02</name><description>Demo project for Spring Boot</description><properties><java.version>17</java.version></properties><dependencies><!--   web模块依赖启动器    --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--   测试模块启动类    --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>RELEASE</version><scope>test</scope></dependency></dependencies><!--    <build>-->
    <!--        <plugins>-->
    <!--            <plugin>-->
    <!--                <groupId>org.springframework.boot</groupId>-->
    <!--                <artifactId>spring-boot-maven-plugin</artifactId>-->
    <!--            </plugin>-->
    <!--        </plugins>-->
    <!--    </build>--></project>
    

    运行 主程序启动类启动成功后,此时在浏览器上访问 http://localhost:8080/hello2 。

3. “单元测试” 和“热部署”

单元测试

  • 实际开发中,每当 完成一个功能接口业务方法编写后,通常都会借助 单元测试 验证该功能是否正确Spring Boot 对项目的单元测试提供了很好的支持,在使用时,需要提前在项目的 pom.xml 文件中添加 spring-boot-starter-test 测试依赖启动器,可以通过相关注解 实现单元测试

     <!--   测试依赖启动器   -->
    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope>
    </dependency>
    
  • 在项目中添 加测试依赖启动器后,可以编写SpringBoot项目相关方法对应的单元测试。如果是使用Spring Initializr 方式搭建的 Spring Boot 项目,会在src.test.java 测试目录自动创建项目主程序启动类对应的 单元测试类。例如,chapter2 项目的 Chapter02ApplicationTests 是自动生成的“单元测试类” :

    在这里插入图片描述

  • Chapter02Application.java :

    package com.myh.chapter_02;import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
    public class Chapter02Application {public static void main(String[] args) {SpringApplication.run(Chapter02Application.class, args);}
    }
    

    pom.xml :

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.myh</groupId><artifactId>chapter_02</artifactId><version>0.0.1-SNAPSHOT</version><name>chapter_02</name><description>Demo project for Spring Boot</description><properties><java.version>17</java.version></properties><dependencies><!--   web模块依赖启动器    --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--   测试依赖启动器   --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>RELEASE</version><scope>test</scope></dependency></dependencies><!--   Maven打包工具插件   --><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

    HelloController.java :

    package com.myh.chapter_02.controller;import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;@RestController // 组合注解 : 该注解 = @ResponseBody + @Controller
    public class HelloController {@GetMapping("/hello2")public String hello() {return "hello Spring Boot(单元测试)";}
    }

    Chapter02ApplicationTests.java :

    package com.myh.chapter_02;import com.myh.chapter_02.controller.HelloController;
    import org.junit.jupiter.api.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.boot.test.context.SpringBootTest;
    import org.springframework.test.context.junit4.SpringRunner;@RunWith(SpringRunner.class) //测试运行器,并加载SpringBoot测试注解
    @SpringBootTest //标记为类为"单元测试类",并加载项目的上下文环境ApplicationContext
    class Chapter02ApplicationTests {@Autowiredprivate HelloController helloController;/*** 使用"单元测试"运行方法*/@Test //单元测试方法public void helloController() {String hello = helloController.hello();System.out.println(hello);}//自动创建爱你的单元测试方法示例@Testvoid contextLoads() {}}

热部署

  • 开发过程中,通常会 一段业务代码不断地修改测试,在 修改之后往往 需要 重启服务,有些服务需要加载很久才能启动成功,这种不必要的重复操作极大降低了程序开发效率。为此,Spring Boot 框架专门提供了进行热部署依赖启动器,用于进行项目热部署,而 无须开发人员手动重启项目

  • 第一步导入“热部署依赖启动器 :

     <!--   “热部署”依赖启动器   --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId></dependency>
  • 第二步IDEA工具热部署设置

    在这里插入图片描述

    在这里插入图片描述

    然后
    任意页面使用 组合键 : Ctrl + Shift + Alt + / 打开 Maintenance选择框,选中并打开 Registry页面如下图所示
    在这里插入图片描述

    在这里插入图片描述

  • 第三步热部署效果测试
    启动 chapter01项目,通过 浏览器访问“http://localhost:8080/hello”,具体如下图所示
    在这里插入图片描述

    页面原始输出 的内容是“hello Spring Boot”。

    为了测试配置的热部署是否有效,接下来在不关闭当前项目的情况下,将 HelloController类 中的 请求处理方法hello( )返回值修改为“ 你好,Spring Boot ”并保存,查看控制台信息会发现项目能够自动构建和编译,说明项目热部署生效。此时,关闭重新打开浏览器访问 :“http://localhost:8080/hello”,此时
    效果如下图 所示 :
    在这里插入图片描述

4. Spring Boot”原理分析”

  • 传统的Spring 框架实现一个Web 服务需要导入各种依赖JAR包,然后 编写对应的XML配置文件等;相较而言Spring Boot 显得更加方便快捷高效
  • 下面将分别针对 SpringBoot 框架依赖管理自动配置执行流程 进行 深入分析和讲解

4.1Spring Boot”依赖管理“

  • Spring Boot 入门程序中,项目 pom.xml 文件 有两个核心依赖,分别是 spring-boot-starter-parent ( 父项目依赖管理“启动器” ) 和 spring-boot-starter-web ( web场景依赖“启动器” )
spring-boot-starter-parent 依赖
<!-- 父项目依赖管理"启动器" : Spring Boot父项目依赖管理  -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
</parent>

上述代码中,将 spring-boot-starter-parent依赖 作为Spring Boot项目统一父项目依赖管理 ,并将项目 版本号统一为2.1.3.RELEASE,该版本号根据实际开发需求可以修改的。

进入并查看spring-boot-starter-parent底层源文件可以发现 spring-boot-starter-parent底层有一个父依赖 : spring-boot-dependencies核心代码如下

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.1.3.RELEASE</version><relativePath>../../spring-boot-dependencies</relativePath>
</parent>
.....

继续查看 spring-boot-dependencies 底层源文件核心代码 如下 :

<properties><activemq.version>5.15.8</activemq.version>    ...<solr.version>7.4.0</solr.version><spring.version>5.1.5.RELEASE</spring.version><spring-amqp.version>2.1.4.RELEASE</spring-amqp.version><spring-batch.version>4.1.1.RELEASE</spring-batch.version><spring-cloud-connectors.version>2.0.4.RELEASE</spring-cloud-connectors.version><spring-data-releasetrain.version>Lovelace-SR5</spring-data-releasetrain.version><spring-framework.version>${spring.version}</spring-framework.version><spring-hateoas.version>0.25.1.RELEASE</spring-hateoas.version><spring-integration.version>5.1.3.RELEASE</spring-integration.version><spring-kafka.version>2.2.4.RELEASE</spring-kafka.version><spring-ldap.version>2.3.2.RELEASE</spring-ldap.version><spring-plugin.version>1.2.0.RELEASE</spring-plugin.version><spring-restdocs.version>2.0.3.RELEASE</spring-restdocs.version><spring-retry.version>1.2.4.RELEASE</spring-retrdy.version><spring-security.version>5.1.4.RELEASE</spring-security.version><spring-session-bom.version>Bean-SR3</spring-session-bom.version><spring-ws.version>3.0.6.RELEASE</spring-ws.version><sqlite-jdbc.version>3.25.2</sqlite-jdbc.version><statsd-client.version>3.1.0</statsd-client.version><sun-mail.version>${javax-mail.version}</sun-mail.version><thymeleaf.version>3.0.11.RELEASE</thymeleaf.version> <tomcat.version>9.0.16</tomcat.version> <unboundid-ldapsdk.version>4.0.9</unboundid-ldapsdk.version><undertow.version>2.0.17.Final</undertow.version><versions-maven-plugin.version>2.7</versions-maven-plugin.version><webjars-hal-browser.version>3325375</webjars-hal-browser.version><webjars-locator-core.version>0.35</webjars-locator-core.version>
</properties>

spring-boot-dependencies底层源文件可以看出,该文件通过 <properties>标签 对一些常用技术框架的依赖文件进行了 统一版本号管理,例如activemqspringtomcat 等,都有与 SpringBoot 2.1.3 版本相匹配版本,这也是pom.xml引入依赖文件 不需要标注依赖文件版本号原因

需要说明的是,如果pom.xml 引入的依赖文件不是spring-boot-starter-parent 管理的,那么在 pom.xml 引入依赖文件时,需要使用 <version>标签指定依赖文件版本号

spring-boot-starter-web 依赖
  • spring-boot-starter-parent父依赖启动器的主要作用是进行版本统一管理

    <!--   web模块依赖启动器    -->
    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
    </dependency>
  • 查看 spring-boot-starter-web 依赖文件源码核心代码如下

    <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><version>2.1.3.RELEASE</version><scope>compile</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-json</artifactId><version>2.1.3.RELEASE</version><scope>compile</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId><version>2.1.3.RELEASE</version><scope>compile</scope></dependency><dependency><groupId>org.hibernate.validator</groupId><artifactId>hibernate-validator</artifactId><version>6.0.14.Final</version><scope>compile</scope></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.1.5.RELEASE</version><scope>compile</scope></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.1.5.RELEASE</version><scope>compile</scope></dependency></dependencies>

    上述代码可以发现,spring-boot-starter-web依赖启动器 的主要作用是 提供Web开发场景所需底层所有依赖文件,它对Web开发场景所需的依赖文件进行了统一管理

    正是如此,在pom.xml 中引入spring-boot-starter-web依赖启动器时,就可以实现Web场景开发,而 不需要额外导入Tomcat服务器以及其他 Web 依赖文件 等。当然,这些引入的依赖文件的版本号还是由spring-boot-starter-parent父依赖进行统一管理

  • 需要说明
    的是,Spring Boot 官方 并不是 针对所有场景开发的技术框架 都提供了依赖启动器,例如数据库操作框 : MyBatis阿里巴巴的Druid 数据源等,Spring Boot 官方没有提供对应的依赖启动器。为了充分利用Spring Boot 框架的优势,在Spring Boot官方没有整合这些技术框架的情况下,MyBatis、Druid等技术框架所在的开发团队主动与Spring Boot框架进行了整合,实现了各自的依赖启动器,例如 mybatis-spring-boot-starterdruid-spring-boot-starter 等。我们 在pom.xml 文件中引入这些第三方的依赖启动器时,切记要配置对应的版本号

Spring Boot自动配置

  • Spring Boot应用启动入口@SpringBootApplication注解 标注类 中的main( )方法@SpringBootApplication 能够扫描 Spring组件自动配置Spring Boot

  • @SpringBootApplication内部源码 分析

    @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 { ...
    }

    上述源码可以看出,@SpringBootApplication注解 是一个 组合注解 ,包含 @SpringBootConfiguration
    @EnableAutoConfiguration@ComponentScan3个核心注解

@SpringBootConfiguration
  • @SpringBootConfiguration注解表示SpringBoot配置类 ,查看其源码核心代码 如下 :

    @Target({ElementType.TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    @Configuration
    public @interface SpringBootConfiguration {
    }

    上述源码可以看出,@SpringBootConfiguration注解 内部有一个核心注解@Configuration
    该注解是 Spring 框架提供的,表示当前类为一个配置类(XML配置文件的注解表现形式),并
    可以被组件扫描器扫描。由此可见,@SpringBootConfiguration注解作用@Configuration注
    相同,都是标识一个可以被组件扫描器扫描配置类,只不过**@SpringBootConfiguration** 是被
    Spring Boot 进行了重新封装命名而已。

@EnableAutoConfiguration
  • @EnableAutoConfiguration注解表示 开启自动配置功能,该注解是Spring Boot框架 最重要
    的注解
    ,也是实现自动化配置注解。同样该注解的核心代码如下

    @Target(ElementType.TYPE)
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    @Inherited
    @AutoConfigurationPackage
    @Import(AutoConfigurationImportSelector.class)
    public @interface EnableAutoConfiguration {String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";/*** Exclude specific auto-configuration classes such that they will never be applied.* @return the classes to exclude*/Class<?>[] exclude() default {};/*** Exclude specific auto-configuration class names such that they will never be* applied.* @return the class names to exclude* @since 1.3.0*/String[] excludeName() default {};}

    上述源码可以看出,@EnableAutoConfiguration 注解是一个 组合注解,它主要包括有
    @AutoConfigurationPackage@lmport两个核心注解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_1028247.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SUSE 15 SP5 一键安装 Oracle 19C(19.22)单机版

前言 Oracle 一键安装脚本&#xff0c;演示 SUSE 15 SP5 一键安装 Oracle 19C&#xff08;19.22&#xff09;单机版过程&#xff08;全程无需人工干预&#xff09;&#xff1a;&#xff08;脚本包括 ORALCE PSU/OJVM 等补丁自动安装&#xff09; ⭐️ 脚本下载地址&#xff1…

54、Qt/对话框、事件机制相关学习20240325

一、完善对话框&#xff0c;点击登录按钮&#xff0c;如果账号和密码匹配&#xff0c;则弹出信息对话框&#xff0c;给出提示”登录成功“&#xff0c;提供一个Ok按钮&#xff0c;用户点击Ok后&#xff0c;关闭登录界面&#xff0c;跳转到其他界面 如果账号和密码不匹配&#…

【计算机网络篇】数据链路层(4.2)可靠传输的实现机制

文章目录 &#x1f354;可靠传输的实现机制⭐停止 - 等待协议&#x1f5d2;️注意 &#x1f50e;停止 - 等待协议的信道利用率&#x1f5c3;️练习题 ⭐回退N帧协议&#x1f388;回退N帧协议的基本工作流程&#x1f50e;无传输差错的情况&#x1f50e;超时重传的情况&#x1f5…

Linux vim用法

在命令模式下&#xff0c;点i 进入输入模式 输入模式下&#xff1a;通过箭头可以实现左右上下移动 o是从新起下一行开始写 O是新起上一行开始写 $是到此行的末尾 0是到此行的开头 gg是到第一行 yy是复制此行&#xff0c;p是粘贴 dd是删除此行 u是撤销 Ctrl r是反向撤…

边缘计算网关在机械制造企业的应用效果和价值-天拓四方

随着智能制造行业的飞速发展&#xff0c;数据量的激增和实时性要求的提高&#xff0c;传统的数据处理方式已经难以满足生产需求。而边缘计算网关的出现&#xff0c;为智能制造行业带来了革命性的变化。下面&#xff0c;我们将通过一个具体案例展示边缘计算网关在智能制造行业的…

pycharm使用远程服务器的jupyter环境

1、确保服务器上安装了jupyter,如果没有&#xff0c;执行下面命令安装 pip install jupyter2、启动jupyter notebook服务 jupyter notebook --no-browser --port8888 --ip0.0.0.0 --allow-root表明在服务器的8888 端口上启动 Jupyter Notebook&#xff0c;并允许从任何 IP 地…

手动实现一个扩散模型DDPM

扩散模型是目前大部分AIGC生图模型的基座&#xff0c;其本质是用神经网络学习从高斯噪声逐步恢复图像的过程&#xff0c;本文用python代码从零开始构建了一个简单的扩散模型。 理论部分 DDPM(Denoising Diffusion Probabilistic Models) 是一种在生成对抗网络等技术的基础上发展…

阿里云OSS存储的视频如何加水印

OSS是不能进行视频添加水印的&#xff0c;可以图片添加水印。 您可以在视频点播中进行配置&#xff1a; https://help.aliyun.com/zh/vod/user-guide/video-watermarks?spma2c4g.11186623.0.i2 原来的业务代码都是使用python 对oss的 视频进行上传 的,上传的视频路径已经保存到…

小米汽车正式发布:开启智能电动新篇章

随着科技的不断进步&#xff0c;汽车产业正经历着前所未有的变革。智能电动汽车作为这一变革的重要方向&#xff0c;正吸引着越来越多的目光。在这个充满机遇和挑战的时代&#xff0c;小米汽车凭借其卓越的技术实力和深厚的市场底蕴&#xff0c;终于迈出了坚实的一步。今天&…

计算机网络:传输控制协议(Transmission Control Protocol-TCP协议

计算机网络&#xff1a;传输控制协议&#xff08;Transmission Control Protocol-TCP协议&#xff09; 本文目的前置知识点TCP协议简介主要特性通信流程1. 建立连接的过程(三次握手&#xff0c;243)1.1 为什么要三次握手&#xff0c;两次不行吗&#xff1f; 2. 释放连接的过程(…

Java基础语法(二)

前言 Hello&#xff0c;大家好&#xff01;很开心与你们在这里相遇&#xff0c;我是一个喜欢文字、喜欢有趣的灵魂、喜欢探索一切有趣事物的女孩&#xff0c;想与你们共同学习、探索关于IT的相关知识&#xff0c;希望我们可以一路陪伴~ 1. 类型转换 1.1 自动类型转换 什么是自…

RabbitMQ3.x之三_RabbitMQ新建用户及开启远程访问

RabbitMQ3.x之三_RabbitMQ新建用户及开启远程访问 文章目录 RabbitMQ3.x之三_RabbitMQ新建用户及开启远程访问1. guest不能远程访问2. 创建专有用户远程访问RabbitMQ1. 创建用户2. 给用户分配tag(角色)3. 开启远程访问 3. 新用户远程登录 1. guest不能远程访问 在 RabbitMQ 中&…

网络爬虫框架Scrapy的入门使用

Scrapy的入门使用 Scrapy概述引擎&#xff08;Engine&#xff09;调度器&#xff08;Scheduler&#xff09;下载器&#xff08;Downloader&#xff09;SpiderItem Pipeline 基本使用安装scrapy创建项目定义Item数据模型对象创建爬虫(Spider)管道pipeline来保存数据启动爬虫 其他…

利用lidar生成深度图

前言 目前&#xff0c;深度图像的获取方法有&#xff1a;激光雷达深度成像法、计算机立体视觉成像、坐标测量机法、莫尔条纹法、结构光法等。针对深度图像的研究重点主要集中在以下几个方面&#xff1a;深度图像的分割技术&#xff0c;深度图像的边缘检测技术&#xff0c;基于…

python的神奇bug2

今天测试出一个很诡异的bug&#xff0c; 这个错误还真的很难发现 测试1 a [1,10,100] for i in a:print(i)if(i10):a[20,30,-1]一般来说我们在进行迭代时&#xff0c;a这个值时不能改动的&#xff0c;但是现在的问题时如果我不小心给改动了呢&#xff0c;结果如下 也就是说…

文本文件操作

大家好&#xff1a; 衷心希望各位点赞。 您的问题请留在评论区&#xff0c;我会及时回答。 文件操作 程序运行时&#xff0c;产生的数据都是临时数据&#xff0c;程序一旦运行结束都会被释放。通过文件可以将数据持久化。 C中对文件进行操作需要包含头文件<fstream> 文件…

关于深度学习的 PyTorch 项目如何上手分析?从什么地方切入?

文章目录 PyTorch 项目分析1.背景2.分析流程 PyTorch 项目分析 1.背景 当我们拿到一个 PyTorch 的深度学习项目时&#xff0c;应该怎么入手&#xff1f;怎么去查看代码&#xff1f; 2.分析流程 首先阅读对应项目的 README.md 文件。通过阅读 README.md &#xff0c;一般可以…

【Redis面试题】Redis 的大 Key 对持久化有什么影响?

目录 大 Key 对 AOF 日志的影响大 Key 对 AOF 重写和 RDB 的影响总结 Redis 的持久化方式有两种&#xff1a;AOF 日志和 RDB 快照。 所以接下来&#xff0c;针对这两种持久化方式具体分析分析。 大 Key 对 AOF 日志的影响 先说说 AOF 日志三种写回磁盘的策略 Redis 提供了 3 …

记录在项目中引用本地的npm包

1、先把需要的包下载下来&#xff0c;以Photo Sphere Viewer 为引用的npm包、项目以shpereRepo为例子 git clone https://github.com/mistic100/Photo-Sphere-Viewer2、拉下代码后修改之后执行 ./build.sh build.sh #!/usr/bin/env bashyarn run build targetDir"../sh…

HarmonyOS 应用开发之UIAbility组件间交互(设备内)

UIAbility是系统调度的最小单元。在设备内的功能模块之间跳转时&#xff0c;会涉及到启动特定的UIAbility&#xff0c;该UIAbility可以是应用内的其他UIAbility&#xff0c;也可以是其他应用的UIAbility&#xff08;例如启动三方支付UIAbility&#xff09;。 本文将从如下场景…