SpringBoot从繁至简的框架基础教程

SpringBoot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置

前言

整理完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即可,就像这样

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

然后我们更换上Jetty服务器的依赖即可完成boot项目服务器切换

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jetty</artifactId>
        </dependency>

四.多环境开发

多环境开发配置也是必会的一项操作,以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 接口上使用 @MapperBookDao 接口改进为

@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 依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.16</version>
</dependency>

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框架内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!

本文标题为:SpringBoot从繁至简的框架基础教程

基础教程推荐