SpringBoot基础(一):快速入门

SpringBoot基础系列文章

SpringBoot基础(一):快速入门


一、SpringBoot简介

  • SpringBoot可以简单快速地创建一个独立的、生产级别的Spring应用(说明:SpringBoot底层是Spring)
  • 大多数SpringBoot应用只需要编写少量配置即可快速整合Spring平台以及第三方技术

SpringBoot特性

  • 快速创建独立Spring应用
    • 以前的SSM框架,需要导包、写配置、启动运行
  • 直接嵌入Tomcat、Jetty or Undertow,不再需要部署war包
  • 提供可选的场景启动器(starter),简化应用整合
    • 为每一种场景准备一个依赖,如:spring-boot-starter-web、mybatis-plus-boot-starter
    • 以前需要导包,控制版本
  • 按需自动配置Spring以及第三方库
    • 约定大于配置:每个场景都有很多基本的默认配置

总结:简化整合、配置、开发、部署

二、快速入门

pom.xml

  • 所有springboot项目pom文件都必须继承spring-boot-starter-parent
  • web场景启动器spring-boot-starter-web包含了web开发的所有依赖
<?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>
    <!-- 所有springboot项目都必须继承自 spring-boot-starter-parent -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.11</version>
        <relativePath/>
    </parent>

    <artifactId>springboot</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>


    <dependencies>
        <!-- web开发的场景启动器 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>

    <!-- 
         SpringBoot应用打包插件
		 mvn clean package把项目打成可执行的jar包
		 java -jar demo.jar启动项目
	-->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

核心启动类

// 这是一个SpringBoot应用
@SpringBootApplication 
public class SpringBootMainApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringBootMainApplication.class,args);
    }
}

Controller测试类

@RestController
public class HelloController {
    @GetMapping("/hello")
    public String hello(){
        return "Hello,Spring Boot !";
    }
}

访问路径:http://localhost:8080/hello

在这里插入图片描述

三、SpringBoot核心组件

1、parent

  之前传统框架对依赖版本的选择具有固定的搭配格式,并且这些依赖版本的选择还不能乱搭配。于是SpringBoot将所有的技术版本的常见使用方案(parent版本)都整理出来,以后开发者直接使用它提供的方案(parent版本)即可,就不用担心冲突问题了。

1.1、spring-boot-starter-parent

parent版本即为SpringBoot项目pom文件的父工程坐标

  • parent有很多版本,每个parent版本包含了几百种技术的版本号
  • parent只负责进行版本管理不会导入坐标
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.7.11</version>
</parent>

spring-boot-starter-parent坐标内容

  • 核心内容spring-boot-dependencies依赖管理,下面讲
  • 设置默认的java编译版本以及编码方式
  • 管理打包插件的版本,这也是SpringBoot的pom文件中打包插件不用写版本号的原因

在这里插入图片描述

1.2、spring-boot-dependencies

  • 这里将常用的框架之间适配的版本号已配置好
  • 只管理依赖版本,而不导入依赖
  • <dependencyManagement>依赖管理标签内,则表示只是引入申明,只有在子pom中使用<dependencies>(不用写版本号)依赖才会导入

在这里插入图片描述

  • 如果想导入依赖则需要在SpringBoot的pom文件中配置,如导入activemq
<dependency>
  <groupId>org.apache.activemq</groupId>
  <artifactId>activemq-amqp</artifactId>
</dependency>
  • 如果想要修改版本号,可以在SpringBoot的pom文件中配置
<properties>
  <activemq.version>5.7.0</activemq.version>
</properties>

# 或者直接修改版本,maven就近原则

<dependency>
  <groupId>org.apache.activemq</groupId>
  <artifactId>activemq-amqp</artifactId>
  <version>5.7.0</version>
</dependency>

2、starter

  • starter定义了使用某种技术时对于依赖的固定搭配格式,可以帮助开发者减少依赖配置
    • 官方提供的场景:命名为:spring-boot-starter-*
    • 第三方提供场景:命名为:*-spring-boot-starter

2.1、spring-boot-starter-web

  • 项目中的pom.xml没有写SpringMVC的坐标,而只添加spring-boot-starter-web的依赖
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
  • spring-boot-starter-web中定义了若干个具体依赖的坐标

在这里插入图片描述

  • 简单看下spring-boot-starter-jsonspring-boot-starter-tomcat的内容

在这里插入图片描述

2.2、spring-boot-starter

  • 这里会导入spring的依赖

在这里插入图片描述

  • 核心依赖spring-boot-autoconfigurejar
  • 这些类会通过条件组件给spring容器导入bean对象(如:导入redis依赖,就会导入StringRedisTemplate对象,服务中我们就可以直接注入使用了)
  • 具体内容后面源码章节详解

在这里插入图片描述

2.3、parent和starter的区别

  • parent是定义了几百种依赖版本号
    • 以前写依赖需要自己手工控制版本,现在由SpringBoot统一管理,这样就不存在版本冲突了
    • 用来减少依赖冲突的
  • starter是一个坐标中定了若干个坐标
    • 以前写多个的,现在写一个
    • 用来减少依赖配置的书写量

3、启动类

  • Spring程序运行的基础是需要创建自己的Spring容器对象(IoC容器)
  • 将所有的对象交给Spring的容器管理,也就是一个一个的Bean
  • 当前这个类运行后就会产生一个Spring容器对象,通过容器对象可以直接操作Bean
  • 默认扫描包为启动类所在包及其子包
@SpringBootApplication
public class SpringBootMainApplication {
    public static void main(String[] args) {
        //获取ioc容器
        ConfigurableApplicationContext context = SpringApplication.run(SpringBootMainApplication.class, args);
        //获取组件
        User user = context.getBean(User.class);
        System.out.println(user);
    }
}

4、内嵌Tomcat运行原理

  • 从上面说到的内嵌tomcat的spring-boot-starter-tomcat说起
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-tomcat</artifactId>
  <version>2.7.11</version>
  <scope>compile</scope>
</dependency>
  • 这里导入了很多tomcat相关依赖

在这里插入图片描述

  从上面说到的spring-boot-autoconfigurejar包里的配置类,找到ServletWebServerFactoryAutoConfigurationServletWeb服务器工厂自动配置

  Tomcat类来自于tomcat-embed-core-9.0.74.jar,由于导入这个jar,才能创建Tomcat容器工厂类,后续才能创建Tomcat容器并启动。

在这里插入图片描述

  • 这里简单截图说下tomcat启动流程

创建Tomcat

在这里插入图片描述

启动Tomcat

在这里插入图片描述

挂起Tomcat,这也就是启动类main函数不会执行结束的原因

在这里插入图片描述

  • 这里只是简单介绍下,后续关于tomcat的源码章节详解
  • 36
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 49
    评论
评论 49
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冬天vs不冷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值