一、SpringBoot
1.概念:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程,该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置,通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者
SpringBoot是在Spring的基础之上产生的(准确的说是在Spring4.0)的版本的基础之上,其中“Boot”的意思就是“引导”,意在简化开发模式,是开发者能够快速的开发出基于Spring的应用,SpringBoot含有一个内嵌的web容器,我们开发的web应用不需要作为war包部署到web容器中,而是作为一个jar包,在启动时根据web服务器的配置进行加载
2.SpringBoot特点:
•SpringBoot 设计目的是用来简化新 Spring 应用的初始搭建以及开发过程。
• 嵌入的Tomcat,无需部署 WAR 文件
• SpringBoot 并不是对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方 式。
Spring Boot的核心策略:开箱即用,约定大于配置
3.Spring启动器:所谓的启动器其实就是一些jar包的集合,SpringBoot一共提供44种启动器(目前),常见的有:
4.1 spring-boot-starter-web支持全栈式的 web开发,包括了 Tomcat 和 springMVC 等jar
4.2spring-boot-starter-jdbc 支持 spring 以jdbc 方式操作数据库的 jar 包的集合
4.3 spring-boot-starter-redis 支持 redis 键值存储的数据库操作
4.编写HelloWorld测试SpringBoot
a.首先创建Maven项目,添加Web启动器的坐标,修改JDK的版本
b.编写Controller,编写启动类
如何编写启动类:
a.新建Java类,添加注解:@SpringBootApplication
b.编写启动方法,调用SpringApplication.run(“类名.class”,参数);
启动类和启动器的区别:
启动类表示项目的启动入口
启动器表示 jar 包的坐标
注意:启动类要放在控制器的相同包或父包,不能放在控制器的同级目录或子目录中,因为@SpringBootApplication会扫描同包或者子包下的控制器。
SpringBoot的自动加载原理:
SpringBoot工作原理:
1、 springboot的项目启动注解是@SpringBootApplication 本质上是由 3 个注解组成,分别是@Configuration、@EnableAutoConfiguration、@ComponentScan
2、其中@EnableAutoConfiguration是实现自动配置的入口,该注解又通过@Import注解导入了AutoConfigurationImportSelector,
3、在该类中加载meta-info/spring.factories的配置信息,然后筛选出以EnableAutoConfiguration为key的数据,加载到ioc容器,实现自动配置功能
springboot starter启动时工作原理
1、springboot在启动的时候会按照约定去读取Springboot starter的配置文件spring.factories,然后根据文件中的jar包去扫描项目所依赖的jar
2、然后根据spring.factorie配置加载AutoConfigure类
3、然后根据注解@Conditional注解的条件,进行自动配置,并将bean注入到springContext
总结来说:其实就是Springboot在启动时,按照约定去寻找starter的配置信息,再根据配置信息对资源进行初始化,并注入到spring容器中
这样springboot在启动完成之后,就准备好了一切资源,使用过程中直接注入bean就好了
二、SpringBoot整合Servlet、Filter、Listener
1.SpringBoot整合Servlet:
a.通过注解扫描完成Servlet组件的注册:
在Servlet中通过注解@WebServlet指定映射名和路径,然后在启动器中通过@ServletComponentScan注解扫描@WebServlet注解
b.通过方法完成Servlet组件的注册:
在Servlet种不使用注解,在启动类中编写方法,返回值为ServletRegistrationBean,在方法上添加@Bean注解,方法中添加要映射的路径即可
2.SpringBoot整合Filter
a.通过注解扫描完成Filter组件的注册:
在Filter中通过注解@WebFilter指定映射名和路径,然后在启动器中通过@FilterComponentScan注解扫描@WebFilter注解
b.通过方法完成Filter组件的注册:
在Filter中不使用注解,在启动类中编写方法,返回值为FilterRegistrationBean,在方法上添加@Bean注解,方法中添加要过滤的路径即可
3.SpringBoot整合Listener
a.通过注解扫描完成Listener组件的注册:
在Listener中通过注解@WebListener注册组件,然后在启动器中通过@ListenerComponentScan注解扫描@WebListener注解
b.通过方法完成Listener组件的注册:
在Listener中不使用注解,在启动类中编写方法,返回值为ListenerRegistrationBean,在方法上添加@Bean注解
三、SpringBoot框架访问静态资源+简单的文件上传
注意:访问静态资源 classpath/static的 目录 优先级 高于 ServletContext 根目录
可以修改访问位置,classpath有两个含义,
a.编译前:指Resources目录的根
b.编译后:指Classes目录
文件上传需要注意的细节:
SpringBoot中通过在application.properties/application.yml文件中配置上传文件大小,推荐使用application.yml文件
yml配置文件:是SpringBoot中新增的一种配置文件格式
特点:具备天然的树状结构
语法要求:
1.在 properties 文件中是以“.”进行分割,在 yml 中使用“:”进行分割
2.yml 的数据格式和 json 的格式很像,都是 K-V 结构的。并且是通过“:”赋值
3.在 yml 中缩进一定不能使用 TAB 件,否则会报错。
4.每个 K 的冒号后面一定要加一个空格
配置文件可以存放的四个位置:
当前项目根目录中
当前项目根目录下的一个/config 子目录中
项目的 resources 即 classpath 根路径中
项目的 resources 即 classpath 根路径下的/config 目录
所有同级的目录config中的配置文件大于直接同级的配置文件
SpringBoot1.5版本和2.0版本的配置稍微不同
SpringBoot 1.5.x版本配置上传文件大小的控制
spring.http.multipart.maxFileSize=200MB
spring.http.multipart.maxRequestSize=200MB
SpringBoot 2.1.x版本配置上传件大小的控制
spring.servlet.multipart.maxFileSize=200MB
spring.servlet.multipart.maxRequestSize=200MB
优先级:application.properties > application.yml
四、SpringBoot整合模板引擎
1.整合Jsp:在POM文件中添加jsp依赖的GAV坐标即可
<!-- jstl -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>。
<!-- jasper -->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>
然后在application文件中配置视图解析器
其他跟原来一样,展示项目结构
2.整合Freemarker
Freemarker概念:FreeMarker 是一款模板引擎: 即一种基于模板和要改变的数据,并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。
常用指令:if指令
list指令
a.首先创建项目,添加Freemarker依赖的GAV坐标
<!-- freemarker启动器的坐标 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
b.在Resource目录下新建templates目录存放模板引擎
3.SpringBoot整合Thymeleaf简单入门(官方推荐方式)
概念简介:Thymeleaf是一个用于Web和独立Java环境的模板引擎,能够处理HTML、XML、JavaScript、CSS甚至纯文本。能轻易的与Spring MVC等Web框架进行集成作为Web应用的模板引擎。与其它模板引擎(比如FreeMaker)相比,Thymeleaf最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个Web应用(更加方便前后端分离,比如方便类似VUE前端设计页面),抛弃JSP吧。
Thymeleaf 3.0是一个完全彻底重构的模板引擎(官网原文:Thymeleaf 3.0 builds around a completely new template processing engine),极大的减少内存占用和提升性能和并发性,避免v2.1版因大量的输出标记的集合产生的资源占用。
Thymeleaf 3.0放弃了大多数面向DOM的处理机制,变成了一个基于事件的模板处理器,它通过处理模板标记或文本并立即生成其输出,甚至在新事件之前响应模板解析器/缓存事件。Thymeleaf是Spring Boot官方的推荐使用模板。
Thymeleaf核心特点:Thymeleaf是通过它特定的语法对HTML的标记做渲染
整合步骤
1.创建Maven工程,添加Thymeleaf依赖的GAV坐标
<!-- springBoot的启动器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency><!-- thymeleaf的启动器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
2.使用Thymeleaf视图:需要在Resources目录下新建template目录存放Thymeleaf视图文件,一般借用Html技术来实现Thymeleaf视图
使用Thymeleaf时页面出现的异常:
原因:HTML标签结构不严谨
解决方案:
1.补全结构
2.更改Thymeleaf为更高版本,忽略HTML标记结严谨性检查
再次访问页面已经正常