最新版Swagger 3升级指南和新功能体验!

image

Swagger 3.0 发布已经有一段时间了,它于 2020.7 月 发布,但目前市面上使用的主流版本仍是 Swagger 2.X 版本和少许的 1.X 版本,然而做为一名合格的程序员怎么能不折腾新技术呢?因此本期就你们带来一篇最新版 Swagger 的内容,本文会带你们看最新版 Swagger 有哪些改变?又是如何将老版本 Swagger 升级到新版的?html

Swagger 是什么?

Swagger 是一个用于生成、描述和调用 RESTful 接口的 Web 服务。通俗的来说,Swagger 就是将项目中全部(想要暴露的)接口展示在页面上,而且能够进行接口调用和测试的服务。前端

PS:Swagger 遵循了 OpenAPI 规范,OpenAPI 是 Linux 基金会的一个项目,试图经过定义一种用来描述 API 格式或 API 定义的语言,来规范 RESTful 服务开发过程。

Swagger 官网地址:https://swagger.io/java

Swagger 有什么用?

从上述 Swagger 定义咱们不难看出 Swagger 有如下 3 个重要的做用:程序员

  1. 将项目中全部的接口展示在页面上,这样后端程序员就不须要专门为前端使用者编写专门的接口文档;
  2. 当接口更新以后,只须要修改代码中的 Swagger 描述就能够实时生成新的接口文档了,从而规避了接口文档老旧不能使用的问题
  3. 经过 Swagger 页面,咱们能够直接进行接口调用,下降了项目开发阶段的调试成本

image.png

Swagger 旧版本使用

Swagger 旧版本也就是目前市面上主流的 V2 版本是 Swagger 2.9.2,在讲新版本以前,咱们先来回顾一下 Swagger 2.9.2 是如何使用的。web

Swagger 2.9.2 的使用分为如下 4 步:spring

  1. 添加依赖
  2. 开启 Swagger 功能
  3. 配置 Swagger 文档摘要信息
  4. 调用接口访问

下面咱们分别来看。后端

1.添加依赖

首先,咱们要去 mvnrepository 查询 Swagger 的依赖,搜索“springfox”关键字,获得结果的前两条依赖信息,就是咱们想要的结果,以下图所示:
image.png
将这两个依赖添加带项目中:api

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger2</artifactId>
    <version>2.9.2</version>
</dependency>

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.9.2</version>
</dependency>

为何是“springfox”?

问:咱们要使用的是 Swagger,为何要搜索“springfox”?测试

答:Swagger 能够看做是一个遵循了 OpenAPI 规范的一项技术,而 springfox 则是这项技术的具体实现。 就比如 Spring 中的 AOP 和 DI 同样,前者是思想,然后者是实现。ui

2.开启Swagger

在 Spring Boot 的启动类或配置类中添加 @EnableSwagger2 注释,开启 Swagger,部分核心代码以下:

@EnableSwagger2
@SpringBootApplication
public class Application {...

3.配置摘要信息

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@Configuration
public class SwaggerConfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2) // 1.SWAGGER_2
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.example.swaggerv2.controller")) // 2.设置扫描路径
                .build();
    }
}

4.访问Swagger

项目正常启动以后使用“http://localhost:8080/swagger-ui.html”访问Swagger页面,以下图所示:
image.png

Swagger 最新版使用

Swagger 最新版的配置步骤和旧版本是同样,只是每一个具体的配置项又略有不一样,具体步骤以下。

1.添加依赖

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-boot-starter -->
<dependency>
  <groupId>io.springfox</groupId>
  <artifactId>springfox-boot-starter</artifactId>
  <version>3.0.0</version>
</dependency>

从上述配置能够看出,Swagger 新版本的依赖项只有一个,而旧版本的依赖项有两个,相比来讲也简洁了不少。

2.开启Swagger

在 Spring Boot 的启动类或配置类中添加 @EnableOpenApi 注释,开启 Swagger,部分核心代码以下:

@EnableOpenApi
@SpringBootApplication
public class Application {...

3.配置摘要信息

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.oas.annotations.EnableOpenApi;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

@Configuration
public class SwaggerConfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.OAS_30) // v2 不一样
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.example.swaggerv3.controller")) // 设置扫描路径
                .build();
    }
}

从上述代码能够看出 Docket 的配置中只有文档的类型设置新老版本是不一样的,新版本的配置是 OAS_30 而旧版本的配置是 SWAGGER_2

PS:OAS 是 OpenAPI Specification 的简称,翻译成中文就是 OpenAPI 说明书。

4.访问Swagger

新版本的 Swagger 访问地址和老版本的地址是不一样的,新版版的访问地址是“localhost:8080/swagger-ui/””,以下图所示:
image.png

新版本 VS 老版本

新版本和老版本的区别主要体如今如下 4 个方面:

  1. 依赖项的添加不一样:新版本只须要添加一项,而老版本须要添加两项;
  2. 启动 Swagger 的注解不一样:新版本使用的是 @EnableOpenApi,而老版本是 @EnableSwagger2
  3. Docket(文档摘要信息)的文件类型配置不一样:新版本配置的是 OAS_3,而老版本是 SWAGGER_2
  4. Swagger UI 访问地址不一样:新版本访问地址是“http://localhost:8080/swagger-ui/”,而老版本访问地址是“http://localhost:8080/swagger-ui.html”。

总结

Swagger 新版本让人印象深入的优势有两个:第一,配置变得简单了,好比依赖项配置减小了 50%,第二,新版 Swagger 页面设计风格有了不小的改变,新版的页面让人感受更加现代化也更加具备科技感了,整体来讲美观了很多。

值得一提的是 Swagger 的整个升级过程很平滑,从老版本升级到新版本,只须要简单的配置便可,那些用于描述接口的注解仍是延续了老版本的用法,这样就能够在不修改大部分主要代码的状况下,能够成功到最新版本啦。

关注公号「Java中文社群」查看本文(Swagger 3)视频版内容。