星光下的赶路人star的个人主页
年轻人仍然所见有极限,又迷失在太多讯息中–讯息不等于眼界
环境&工具 | 版本(or later) |
---|---|
SpringBoot | 3.0.5+ |
IDEA | 2021.2.1+ |
java | 17+ |
Maven | 3.5+ |
Tomcat | 10.0+ |
Servlet | 5.0+ |
GraaIVM | 22.3+ |
Native Build Tools | 0.9.19+ |
SpringBoot帮我们简单、快速的创建一个独立、生产级别的Spring应用(说明:SpringBoot底层是Spring)
大多是SpringBoot应用只需要编写少量配置即可快速整合Spring平台以及第三方技术
特性:
总结:简化开发、简化配置、简化整合、简化部署、简化监控、简化运维。
场景:浏览器发生/hello请求,返回“hello zhm,this is Springboot3”
1、创建项目(Maven项目)
<parent>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-parentartifactId>
<version>3.0.5version>
parent>
2、导入场景
<dependencies>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-webartifactId>
dependency>
dependencies>
3、主程序
@SpringBootApplication //这是一个SpringBoot应用
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
4、业务
@RestController
public class HelloController {
@GetMapping("/hello")
public String hello(){
return "hello zhm,this is Springboot3";
}
}
5、测试
默认启动访问:localhost:8080
6、打包
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
mvn clean package把项目打成可执行的jar包
java -jar demo.jar启动项目
然后访问的效果是一样的
1、简化整合
导入相关的场景,拥有相关的功能。场景启动器
默认支持的所以场景:https://docs.spring.io/spring-boot/docs/current/reference/html/using.html#using.build-systems.starters
场景一导入,万物皆就绪
2、简化开发
无需编写任何配置,直接开发业务
3、简化配置
application.properties:
4、简化部署
打包为可执行的jar包
Linux服务器上有java环境
5、简化运维
修改配置(外部放一个application.properties文件)、监控、监控检查。
思考:
1、为什么导入starter-web所有相关依赖都导入进来?
2、为什么版本号都不用写?
3、自定义版本号
4、第三方的jar包
<dependency>
<groupId>com.alibabagroupId>
<artifactId>druidartifactId>
<version>1.2.16version>
dependency>
1、初步理解
public static void main(String[] args) {
//java10: 局部变量类型的自动推断
var ioc = SpringApplication.run(MainApplication.class, args);
//1、获取容器中所有组件的名字
String[] names = ioc.getBeanDefinitionNames();
//2、挨个遍历:
// dispatcherServlet、beanNameViewResolver、characterEncodingFilter、multipartResolver
// SpringBoot把以前配置的核心组件现在都给我们自动配置好了。
for (String name : names) {
System.out.println(name);
}
}
总结:导入场景启动器,触发spring-boot-autoconfigure这个包的自动配置生效、容器中就会具有相关场景的功能。
2、完整流程
自动配置流程细节梳理:
1、导入starter-web:导入了web开发场景
(1)创建启动器导入了相关场景的所以依赖:starter-json、starter-tomcat、springmvc
(2)每个场景启动器都引入了一个spring-boot-starter,核心场景启动器
(3)核心场景启动器引入了spring-boot-autoconfigure包
(4)spring-boot-autoconfigure里面囊括了所以场景的所有配置
(5)只要这个包下的所有类都能生效,那么相当于SpringBoot官方写好的整合功能就能生效了
(6)SpringBoot默认却扫描不到spring-boot-autoconfigure下写好的所有配置类(这些配置类给我们做了整合操作),默认值扫描主程序所在的包。
2、主程序:@SpringBootApplication
(1)@SpringBootApplication由三个注解组成@SpringBootConfiguration、@EnableAutoConfiguration、@ComponentScan
(2)SpringBoot默认只能扫描自己主程序所在的包以及下面的子包,扫描不到spring-boot-autoconfigure包中官方写好的配置类
(3)@EnableAutoConfiguration:SpringBoot开启自动配置的核心
3、xxxxAutoConfiguration自动配置类
4、写业务,全程无效关心各种整合(底层这些整合写好了,而且也生效了)
核心流程总结:
1、导入starter,就会导入autoconfigure包
2、autoconfigure包里有一个文件META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports,里面指定的所有启动要加载的自动配置类
3、@EnableAutoConfiguration 会自动的把上面文件里面写的所有自动配置类都导入进来。
xxxAutoConfiguration是有条件注解进行按需加载的
4、xxxAutoConfiguration给容器中导入一堆组件,组件都是从xxxProperties中提前属性值
5、xxxProperties又是和配置文件进行了绑定
效果:导入starter、修改配置文件、就能修改底层行为。
3、如何学好SpringBoot
框架的框架、底层属于Spring。能调整每一个场景的底层行为。100%项目一定会用到底层自定义
摄影举例:
普通开发:导入starter,Controller、Service、Mapper、偶尔修改配置文件
高级开发:自定义组件、自定义配置、自定义starter
核心:
最佳实战:
整合Redis:
您的支持是我创作的无限动力
希望我能为您的未来尽绵薄之力
如有错误,谢谢指正;若有收获,谢谢赞美