前言
整理完SSM的零零碎碎,也是按部就班开启了SpringBoot之旅,Boot的引入加速了传统的SSM开发,给我最深的一个印象就是它的内部自动集成了Tomcat,当我们运行Application类时,资源就被自动部署到了Tomcat中,其次,是起步依赖的引入,也极大的简化了SSM文件繁琐的配置工程。
以前说过,从繁至简是贯彻框架学习的原始真解,Boot的出现更是这一真理的进一步论证!
一.SpringBoot
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
按下这个按钮,一切仿佛都被加速,相比于曾经的SSM开发
我们通过一个经典的MVC案例来好好感受一下Boot带给我们的极速体验吧
1.还是老套路,类头上写上注解配置请求路径,编写一个GET请求,并且return做出反馈
@RestController @RequestMapping("/books") public class BootController { @GetMapping("/{id}") public String getById(@PathVariable Integer id){ System.out.println("id ==> "+id); return "hello , spring boot!"; } }
2.启动项目的引导类
3.启动SpringBoot项目过后的运行窗口
4.我们利用Postman来进行一个简单的接口测试,测试一下项目功能是否健全
二.起步依赖的引入
为了解决因插件版本不同而导致的冲突问题,boot为我们事先配置好了许多不同版本的插件,当我们使用时,选择既定的boot版本即可自动匹配一套完美契合的插件,极大提高了配置难度。
曾经,懒羊羊刚学习Javaweb时,就因为忽略了tomcat和servlet—api的版本一致问题导致MVC的项目无论如何也运行不成功,可以说是走了很多弯路啊~
不过现在看来SpringBoot的出现,提高开发效率的同时也为我们屏蔽掉了大量不必要的麻烦
三.服务器切换
我们都知道boot内置了tomcat,每当创建好一个web项目,默认都是他,如何更改内置的服务器呢?
这需要用到maven中的排除依赖,找到web插件所在的依赖,排除掉Tomcat即可,就像这样
org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-tomcat
然后我们更换上Jetty服务器的依赖即可完成boot项目服务器切换
org.springframework.boot spring-boot-starter-jetty
四.多环境开发
多环境开发配置也是必会的一项操作,以yaml格式的配置文件为例,分别对生产环境、测试环境、开发环境三者之间进行切换
#设置启用的环境
spring:
profiles:
active: ${profile.active}---
#开发环境
spring:
profiles: dev
server:
port: 55
---
#生产环境
spring:
profiles: pro
server:
port: 66
---
#测试环境
spring:
profiles: test
server:
port: 77
---
五.整合Junit
在SSM的基础上Spring boot整合junit就变得非常简单,注入测试的类,写上@Test注解即可
@SpringBootTest(classes = SpringbootTestApplication.class) class SpringbootTestApplicationTests { @Autowired private BookService bookService; @Test public void save() { bookService.save(); } }
为何会如此简便?
那是因为我们的boot引导类充当了配置类,@SpringBootApplication中封装了包扫描的注解(追源码还是会发现@Configuration注解),引导类所在位置的包会全部被扫描
所以说boot在这方面并没有带来什么新颖的功能,而是进一步封装了SSM的配置
六.整合Mybatis
6.1定义实体类
在 com.yu7daily.domain
包下定义实体类 Book
,内容如下
public class Book { private Integer id; private String name; private String type; private String description; //setter and getter //toString }
6.2定义dao接口
在 com.yu7daily.dao
包下定义 BookDao
接口,内容如下
public interface BookDao { @Select("select * from ssm_db where id = #{id}") public Book getById(Integer id); }
6.3定义测试类
在 test/java
下定义包 com.yu7daily
,在该包下测试类,内容如下
@SpringBootTest class SpringbootMybatisApplicationTests { @Autowired private BookDao bookDao; @Test void testGetById() { Book book = bookDao.getById(1); System.out.println(book); } }
6.4编写配置
我们代码中并没有指定连接哪儿个数据库,用户名是什么,密码是什么。所以这部分需要在 SpringBoot
的配置文件中进行配合。
在 application.yml
配置文件中配置如下内容
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm_db
username: root
password: root
6.5测试
运行测试方法,我们会看到如下错误信息
org.springframework.beans .factory.UnsatisfiedDependencyException: Error creating bean with name
错误信息显示在 Spring
容器中没有 BookDao
类型的 bean
。为什么会出现这种情况呢?
MyBatis是通过扫描接口利用自动代理创建对象交给Spring的IOC来集中管理,我们从始至终好像没有定义扫描的接口,所以我们需要指出扫描的接口!而我们要解决这个问题需要在BookDao
接口上使用 @Mapper
,BookDao
接口改进为
@Mapper public interface BookDao { @Select("select * from ssm_db where id = #{id}") public Book getById(Integer id); }
注意:
SpringBoot
版本低于2.4.3(不含),Mysql驱动版本大于8.0时,需要在url连接串中配置时区 jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
,或在MySQL数据库端配置时区解决此问题
6.6使用Druid数据源
现在我们并没有指定数据源,SpringBoot
有默认的数据源,我们也可以指定使用 Druid
数据源,按照以下步骤实现
导入 Druid
依赖
com.alibaba druid 1.1.16
在 application.yml
配置文件配置
可以通过 spring.datasource.type
来配置使用什么数据源。配置文件内容可以改进为
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
username: root
password: 284650
type: com.alibaba.druid.pool.DruidDataSource
到此这篇关于SpringBoot从繁至简的框架基础教程的文章就介绍到这了,更多相关SpringBoot框架内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!