SpringBoot(一) – SpringBoot 初识
1、创建SpringBoot项目
1.1 使用Spring Initializr 的 Web页面创建项目
创建网址:https://start.spring.io/
1.2 使用IDEA创建
省略;
2、第一个hello
2.1 代码
在 xxxApplication(项目名+Application 自动生成) 的启动类的同级下创建一个controller包,并创建一个控制类
@Controller
public class SpringBootPrimerController {
/**
* @author : huayu
* @date : 10/10/2022
* @param : [msg]
* @return : java.lang.String
* @description : 接收前端请求helloSbt,返回响应字符串
*/
@RequestMapping("/helloSbt")
@ResponseBody
public String hello(@RequestParam(value = "msg") String msg){
return String.format("Hello %s",msg);
}
}
application.properties 指定服务端口
# 服务端口
server.port=8080 # 默认时8080
2.2 测试
2.3 新增的注解
@RestController //组合注解,相当于 @Controller + @ResponseBody
@GetMapping("/helloSbt")//相当于 @RequestMapping( method = {RequestMethod.GET} )
3、打 jar 包运行
3.1 打包
3.1.1 pom.xml
<!-- 指定打包方式,默认方式是jar,还可以是war -->
<packaging>jar</packaging>
3.1.2 点击 maven 的 package
3.2 运行jar 包
cmd 到 项目jar包的目录下
java -jar 项目的 jar包
运行结果
3.3 jar 包运行时 指定 参数
3.3.1 java -jar 项目jar包名 –key=value
3.3.2 java -jar -Dkey=value 项目jar包名
4、启动器
<!-- starter 启动器:SpringBoot 框架将各个场景单独抽离出来,做成一个个启动器 -->
<!-- 一旦项目中添加了对应的启动器,自动将对应启动器中多有的依赖导入到项目中,直接进行添加配置开发即可,无需手动添加依赖 -->
<!-- 实际开发中,使用什么功能,就直接添加对应的启动器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
5、版本控制器 版本仲裁中心:spring-boot-dependencies
5.1 版本控制器
<!-- 为什么SpringBoot 项目添加依赖有的不需要指定版本(比如fastjson,添加必须指定版本号) -->
<!-- 原因:SpringBoot 框架提供了一个版本控制器(又叫:版本仲裁中心:spring-boot-dependencies) 定义了Springboot的依赖版本 -->
<!-- 好处:开发人员添加依赖不需要知道版本号,且不需要自己单独维护项目中的各个版本依赖,有防止版本之间的冲突 -->
5.2 找到版本控制器
1、点击 pom.xml中的启动器依赖
2.点击 spring-boot-starter-web 中的依赖 spring-boot-starters
3.点击 spring-boot-starters 中的依赖 spring-boot-parent
4.点击 spring-boot-parent 中的依赖 spring-boot-dependencies
5、在 spring-boot-dependencies 中可以看到 springboot对一些依赖的版本进行了版本控制,和冲突处理
6、SpringBoot应用的maven 插件
<!--
SpringBoot应用的maven 插件,可以将当前SpringBoot 项目直接打包成一个可以执行的jar包,区别与普通jar包(里面没有源码),不能被依赖(比如fastjson依赖jar等)
即:可以直接通过java -jar 项目指定jar包 命令快速启动项目
-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
7、SpringBootApplication 注解详情
此注解,就是SpringBoot应用的核心启动类;
7.1 @SpringBootConfiguration 注解
标注的类就是SpringBoot的核心配置类,是SpringBoot的专属注解,实际上跟 @Configuration 注解一致(等同于以前的核心配置文件),在SpringBoot应用启动时,会自动加载;
@SpringBootConfiguration 实际上跟 @Configuration 注解一致;
7.2 @EnableAutoConfiguration 注解
开启自动配置注解,以前都是手动创建xml核心配置文件,文件中增加核心配置,现在都交给SpringBoot框架自动配置;
7.2.1 子注解 1 @AutoConfigurationPackage 子注解
- 开启自动配置包,实际上就是开启spring的自动扫描功能;
7.2.1.1 子注解 1 的子注解 @Import(AutoConfigurationPackages.Registrar.class)
@Import(AutoConfigurationPackages.Registrar.class)将springBoot核心启动类所在的父包及子包中所有的组件,自动添加到容器中
- 找到 springBoot核心启动类所在的父包 加载的位置
1、点击进入 @Import(AutoConfigurationPackages.Registrar.class)
2、点击 Evalute Expression
3、执行Evalute
可以看出是将springBoot核心启动类所在的父包及子包中所有的组件,自动添加到容器中
7.2.2 子注解 2 @Import({EnableAutoConfigurationImportSelector.class})
- 开启自动配置将springboot框架下MET-INF/spring/spring.factories资源文件中,属性值 org.springframework.boot.autoconfigure.EnableAutoConfiguration 指定的96个自动配置类,导入到容器中,实现自动配置,省去开发人员手动添加组件到容器中,减少开发的工作量,重心都放在核心业务开发中,不是配置上;
- 96个自动配置类
1、进入 @Import(EnableAutoConfigurationImportSelector.class)
2、再进入 AutoConfigurationImportSelector
3、跳到 getCandidateConfigurations 方法
可以看到96个configuration 应该在 META-INF/spring.factories中
4、我找到 META-INF/spring.factories
5、在 spring.factories 找到 96个 configuration
7.2.3 子注解 3 @ComponentScan 注解
- 指定组件扫描,相当于spring核心配置xml文件中<context:component-scan></context:component-scan> 作用;
- 可以指定一个自定义的包路径(或者多个),执行组件扫描;
- 注意:如果核心启动类上,增加此注解,会导致默认的自动配置包失败,以指定的为准,实际应用时,要避免此种情况出现;
8、banner
在 resources 下 创建文件 banner.txt ,网上复制图案;
banner图网址:https://www.bootschool.net/ascii