【SpringBoot2】 SpringBoot2核心技术 基础
写在前面
1 SpringBoot2核心技术 基础
1.1 Spring与SpringBoot
SpringBoot是一个高层框架
1.2 项目创建
1.2.1 创建POM
①导入spring-boot-starter-parent父工程
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.2</version>
</parent>
②添加依赖spring-boot-starter-webSpringBootWeb场景启动器,会自动进行导入web场景所用的jar包

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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.hikaru</groupId>
<artifactId>SpringBoot_HelloWorld</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.2</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
1.2.2 创建主程序
@SpringBootApplication
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class, args);
}
}
MainApplication为主程序类,@SpringBootApplication注解表明这是一个SpringBoot应用。
1.2.3 编写业务
主程序类MainApplication默认只会访问同一包下的文件,所以编写的业务类应该和主程序类放在同一个包下!
@RestController
public class HelloController {
@RequestMapping("/")
public String hello() {
return "Hello,boot!";
}
}
@ RestController注解为 @ ResponseBody 和 @ Controller 的合体
1.2.4 /resources/Application.properties指定Tomcat服务器端口号
application.properties
server.port=8081
SpringBoot内置了Tomcat服务器,不再需要手动进行配置
文件名固定且区分大小写,否则IDEA中能够读取(但是文件中变量为灰色表示没有被用到)但是打成的jar包无法读取配置信息
1.3 项目部署
以前部署的做法,是将项目打包成war,然后在服务器安装tomcat,再将war部署到tomcat服务器。而现在,SpringBoot可以通过引入一个spring-boot-maven-plugin插件将项目打包成为一个可以执行的jar包。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.7.2</version>
</plugin>
</plugins>
</build>
1.4 项目配置的原理
依赖管理spring-boot-starter-parent中
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.2</version>
</parent>
它的父项目spring-boot-dependencies几乎声明了开发中常用的依赖版本号,因此在开发中引入依赖无需关注版本号,即自动仲裁。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.7.2</version>
</parent>
而且也可以根据开发中的需求进行修改版本号:首先在spring-boot-dependencies查看依赖的版本定义,然后在spring-boot-starter-parent中进行修改。
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<mysql-version>5.1.43</mysql-version>
</properties>
1.5 场景启动器
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
形如spring-boot-starter-***,即为Spring-boot场景启动器,只要引入starter,这个场景的所有常规需要的依赖我们都自动引入,Spring Boot所有支持的场景:

可以在项目pom.xml下右键生成分析依赖树:

场景启动器最底层的依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<version>2.7.2</version>
<scope>compile</scope>
</dependency>
1.6 自动配置
1.6.1 自动配置tomcat
①引入tomcat依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<version>2.7.2</version>
<scope>compile</scope>
</dependency>
1.6.2 自动配置Spring-MVC
①引入MVC全套组件
如DispatcherServlet用于拦截所有请求、字符编码拦截器CharacterEncodingFilter用于解决返回响应中文乱码问题、viewResolver视图解析器、文件上传解析器multipartResolve
②自动配置好SpringMVC常用组件(功能)
1.6.3 自动配置web常见功能
如上面说的字符编码问题
1.6.4 默认的包结构
主程序所在的包及其下面的包里面的组件都会被默认扫描出来,无需配置以前的包扫描。同时也可以自行指定扫描的包。
①通过SpringBootApplication注解的属性值scanBasePackages指定
@SpringBootApplication(scanBasePackages = "com.hikaru.boot")
②通过使用ComponentScan包扫描注解
③通过三个混合注解,等同于SpringBootApplication+属性值的方式
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan
1.6.5 配置的默认值
默认配置都会最终映射到一个配置文件,如spring.servlet.multipart.max-file-size即上传文件的文件最大值设定最终会映射MultipartProperties。
然后配置文件的值会映射到对应的类中,如MultipartProperties类,最终带着配置信息在IOC容器中创建对象。
1.6.6 按需加载所有的自动配置项
引入哪些场景,那些场景的自动配置才会进行。SpringBoot的所有自动配置功能都在spring-boot-autoconfigure中。如spring-boot-starter-web场景依赖spring-boot-starter,spring-boot-autoconfigure包就存在于其中。
2 容器注解
2.1 @Configuration注解
@Configuration注解 + @Bean的方式进行组件注册,详细可以参照之前的博文:【Spring注解驱动】(一)IOC容器 - Tod4 - 博客园
@Bean注册的组件默认是单实例的(@Bean的单例、多例可以由@Scope注解进行控制),@Configuration的配置类也是一个组件,而且这个组件默认是一个代理对象,即这个对象负责进行其他组件的实例化。
2.1.1 Lite 模式
而在SpringBoot中,@Configuration进行了部分修改,增加了属性proxyBeanMethods,属性值为true时,表示经过代理对象创建的组件默认为单实例,为false则为多实例。
@Configuration(proxyBeanMethods = true)
public class MyConfig {
@Bean
public User user() {
return new User(1, "ryuu", "123");
}
@Bean
public Pet tomCat() {
return new Pet("Tom");
}
}
进行测试,第一个为true,第二个为false,这是因为:第二个是通过代理对象调用方法,创建的因此需要服从proxyBeanMethods参数的设定,SpringBoot在方法执行的时候总会先行检查IOC容器中是否存在该组件,如果存在则直接返回而不会去重新创建,以此实现单例模式;而第一个不用,而且此时输出bean则会显示:com.hikaru.boot.config.MyConfig$$EnhancerBySpringCGLIB$$14aea548@4565a70a,表明这个是一个代理对象
@SpringBootApplication(scanBasePackages = "com.hikaru.boot")
public class MainApplication {
public static void main(String[] args) {
// 返回IOC容器
ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args);
User user1 = (User) run.getBean("user");
User user2 = (User) run.getBean("user");
System.out.println(user1 == user2);
MyConfig bean = run.getBean(MyConfig.class);
User user3 = bean.user();
User user4 = bean.user();
System.out.println(user3 == user4);
}
}
Lite模式的应用场景大多是在组件依赖中,即一个类中包含着子类,实例化的时候能够保证子类的实例化对象和IOC容器中的是同一个。
2.1.2 Full 模式
若将参数改为false(默认为true),则输出bean为com.hikaru.boot.config.MyConfig@378bd86d是一个真正的对象,而不需要进行代理,创建的对象自然也不是单例的。
2.2 @Conditional注解实现按条件注册
正常的使用方法是声明一个Condition的实现类作为注解的value值,并实现其matches方法在其中写好条件逻辑,以判断注解所在的类是否满足条件注册,这里不再赘述。
SpringBoot则在此基础上新增了大量不同场景的注解,如@ConditionalBean表示容器存在其他Bean则注册此Bean。
2.3 @ImportSource导入原生配置文件
为了防止原生的配置文件如xml手动转换为注解方式过于繁琐,可以在相关配置类上添加@ImportSource注解即可将配置Bean导入配置类。
2.4 ConfigurationProperties配置绑定
回忆一下之前Property配置文件绑定的方法,是通过
在类上添加 @PropertySource 注解,然后通过 @Value('${环境变量名}') 的方式
或者直接在容器中:
ConfigurableEnvironment environment = context.getEnvironment();
String property = environment.getProperty("环境变量名");
2.4.1 @ConfigurationProperties 绑定组件和配置文件
而在SpringBoot中,则可以使用下面的方式,使得组件可以从SpringBoot配置文件application.properties中绑定以mycar为开头的变量,并在容器自动装配的时候进行属性赋值。
@ConfigurationProperties(prefix = "mycar")
@Component
public class Car
application.properties
server.port=8080
mycar.carName = BYD
mycar.carPrice = 1000000
这种方式只能适用于容器中的组件
2.4.2 @EnableConfigurationProperties
也可以使用下面的方式进行配置绑定,@EnableConfigurationProperties有两个功能:
开启组件的配置绑定
在容器中注册该组件
简而言之,@EnableConfigurationProperties + @ConfigurationProperties = @ConfigurationProperties + @Component
@Configuration(proxyBeanMethods = false)
@EnableConfigurationProperties(Car.class)
public class MyConfig
3 自动配置原理入门
源码先略过了。。
3.1 引导加载自动配置类
3.1.1 SpringBootConfiguration
4 最佳实践
4.1 SpringBoot如何编写
引入场景依赖
查看自动配置了哪些(选做)
自己分析:引入场景依赖中有xxxAutoConfiguration表示自动配置
开启debug模式:在application.properties中设置debug=true,然后
是否需要修改配置
自定义加入或替换组件:@Bean @Component 和 自定义器xxxxCustomer
如设置Spring启动的banner图,直接在application.properties添加
spring.banner.image.location = classpath:banner.png
4.1 Lombok简化JavaBean开发
- 引入lombok依赖,SpringBoot对其自动版本仲裁,在spring-boot-dependencies中可以看到信息。
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
搜索安装lombok插件,新版idea已经自动集成了
在Bean上添加
@Data注解,即可在编译的时候自动生成getter、setter方法在 Bean上添加
@toString注解,即可在编译的时候自动生成toString方法在 Bean上添加
AllArgsConstructor注解,即可在编译的时候自动生成有参构造器在 Bean上添加
NoArgsConstructor注解,即可在编译的时候自动生成无参构造器在类上添加
@Slf4j注解,然后可以在类方法中使用log打印日志信息
4.2 devtools热部署
引入devtools依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
ctrl+f9,如果是对静态文件的修改可以不经过重启服务器直接run,否则会进行服务器重启
4.3 SpringInitializer
可以在创建的时候选择场景启动器和版本,生成配置文件和容器启动器。使得我们只需要关注业务逻辑的编写。
【SpringBoot2】 SpringBoot2核心技术 基础的更多相关文章
- 【01】SpringBoot2核心技术-基础入门
SpringBoot 2 1. SpringBoot2核心技术-基础入门 01 Spring与SpringBoot 1.Spring 能做什么 1.1 Spring的能力 微服务:将一个应用的所有功能 ...
- 一、搭建SpringBoot2.0.0M4基础Web项目
本次开发环境为: 系统:Linux Mint 18 JDK:1.8 开发工具:IntelliJ IDEA 2017.2.4 1.启动IDEA工具,开始创建一个基础项目.点击Create New Pro ...
- Java基础巩固——《Java核心技术基础·卷一:基础知识》
阅读记录追踪:前言部分 阅读前先看:简介.目录和勘误! Java编程语言是一种多用途.并发的.基于类的.面向对象的编程语言:编译时通常包括将持续转化成机器无关的字节码表示.运行时活动包括加载和链接执行 ...
- 【读书笔记】Java核心技术-基础知识-反射
在网页中运行Java程序称为applet. 反射 这项功能被大量地应用于JavaBeans中,它是Java组件的体系结构. 能够分析类能力的程序称为反射(reflective).反射机制的功能及其强大 ...
- 十倍效能提升——Web 基础研发体系的建立
1 导读 web 基础研发体系指的是, web 研发中一线工程师所直接操作的技术.工具,以及所属组织架构的总和.在过去提升企业研发效能的讨论中,围绕的主题基本都是——”通过云计算.云存储等方式将底层核 ...
- springboot mybatis 使用多数据源
SpringBoot系列博客目录,含1.5.X版本和2.X版本 springboot2.0正式版发布之后,很多的组件集成需要变更了,这次将多数据源的使用踩的坑给大家填一填.当前多数据源的主要为主从库, ...
- 2014年7月份第1周51Aspx源码发布详情
QF万能视频播放器源码 2014-6-30 [VS2010]本源码是一个万能视频播放器源码.可实现各种格式的影片播放功能. 1.点击[开始]按钮,弹出窗口,选择影片路径,确定后即可播放.可拖拽滚 ...
- Web 程序的建立
1 导读 web 基础研发体系指的是, web 研发中一线工程师所直接操作的技术.工具,以及所属组织架构的总和.在过去提升企业研发效能的讨论中,围绕的主题基本都是——”通过云计算.云存储等方式将底层核 ...
- 新零售下的 AI智能货柜
公司有个智能货柜,通过微信扫码开门,拿货,自动扣款,挺智能的.还不错.研究一下原理,网上查了一下. 文章简介: 目前新零售风刮的蛮大,笔者进入该领域近一年,负责过无人便利店.智能货柜.智慧商超等产品, ...
- (六)SpringBoot2.0基础篇- Redis整合(JedisCluster集群连接)
一.环境 Redis:4.0.9 SpringBoot:2.0.1 Redis安装:Linux(Redhat)安装Redis 二.SpringBoot整合Redis 1.项目基本搭建: 我们基于(五) ...
随机推荐
- C语言II—作业03
1.作业头 这个作业属于哪个课程 https://edu.cnblogs.com/campus/zswxy/SE2020-3 这个作业要求在哪里 https://edu.cnblogs.com/cam ...
- 【.NET】Swagger 允许接口重名
问题: Swagger Failed to load API definition. 相信用过swagger的小伙伴 一定经历过这样的错误,问题点很简单,是接口重名了. 我百度了一下,找不到答案. 谷 ...
- pintia 3-7-5 逆波兰表达式求值 (20 分)
3-7-5 逆波兰表达式求值 (20 分) 逆波兰表示法是一种将运算符(operator)写在操作数(operand)后面 的描述程序(算式)的方法.举个例子,我们平常用中缀表示法描述的算式(1 + ...
- 如何确保获取的输入为整数-C语言基础
这一篇探讨的是如何确保你输入的数据是一个整数.虽然标题用的是这个,但我其实真正想要探讨的内容是 "在程序调试的过程中,需要注意把输入缓存区中的上一次输入的残留信息清理干净,以免影响下一次的输 ...
- CentOS7带图形界面不能扫描网卡。
CentOS7在带有图形界面,在配置/sysconfig/network-script/ifcfg-ens*后不能识别到网卡,有可能是NetworkManager打开导致,可以使用systemctl ...
- 使用selemium被反爬解决方法
使用selenium进行自动化的时候,如csdn登录时可能会遇到检测反爬,从而需要验证 1. 反爬 有时候,我们利用 Selenium 自动化爬取某些网站时,极有可能会遭遇反爬. 实际上, ...
- JSTL常用便签choose和JSTL常用便签foreach
2. choose :相当于 java 代码的 switch 语句 1.使用 choose 标签声明 相当于switch 2.使用 when 标签做判断 相当于case 3,使用 other ...
- getopt函数使用说明
一.查询linux命令手册: #include<unistd.h> #include<getopt.h> /*所在头文件 */ int getopt(intargc, char ...
- 快速乘_c/c++
快速乘的使用主要是这种情形:要计算(a * b) % p时,发现a * b爆 long long 了,而a, b, p没有爆 long long 快速乘的原理: 比如当我们需要要计算3 * 2 ...
- 2021SWPUCTF-WEB(二)
ez_unserialize 不知道在哪,御剑扫叭 有一个robots.txt 一道反序列化好像是 分析代码应该是admin=admin.passwd=ctf即可输出flag < ...