Spring Doc 生成OPEN API 3文档

点击上方蓝色“程序猿DD”,选择“设为星标”

回复“资源”获取独家整理的学习资料!

作者 | developlee

来源 | 公众号「锅外的大佬」

1. 概述

公司正好最近在整理项目的文档,且文档对于构建REST API来说是至关重要的。在这篇文章中,我将介绍Spring Doc , 一个基于OpenAPI 3规范简化了Spring Boot 1.x2.x应用程序的API文档的生成和维护的工具。

2. 设置springdoc-openapi

如果想让 springdoc-openapi 为我们的API生成标准的 OpenAPI 3 文档, 只需要添加 [springdoc-openapi-core](https://search.maven.org/search?q=g:org.springdoc AND a:springdoc-openapi-core&core=gav) 依赖到 pom.xml:

    org.springdoc    springdoc-openapi-core    1.1.45

添加完成后,启动应用程序,即可访问默认路径/v3/api-docs 查看文档,如下所示:

http://localhost:8080/v3/api-docs/

如果想要自定义路径,可在 application.properties 文件中指定 :

springdoc.api-docs.path=/api-docs

这样,文档的访问路径就变成 :

http://localhost:8080/api-docs/

Spring Doc 生成OPEN API 3文档_第1张图片

openapi3

OpenAPI 默认定义为JSON 格式。对于 yaml 格式,可以访问下面的路径获取 :

http://localhost:8080/api-docs.yaml

3.整合springdoc-openapi 和Swagger UI

除了自己生成OpenAPI 3规范外,我们还可以将springdoc-openapiSwagger UI集成在一起,以便可以与我们的API规范进行交互并测试端点。

3.1. Maven 依赖

要整合springdoc-openapi 和 Swagger UI , 唯一要做的就是添加springdoc-openapi-ui依赖到项目pom.xml文件中。

    org.springdoc    springdoc-openapi-ui    1.1.45

访问swagger-ui页面:

http://localhost:8080/swagger-ui.html

当然也可以像上面一样,自定义访问路径:

springdoc.swagger-ui.path=/swagger-ui-custom.html

3.2. 举个栗子

假设有个球(国足令人伤心,所以需要个球啊!!)的controller。

@RestController@RequestMapping("/api/ball")public class BallController {     @Autowired    private BallRepository repository;     @GetMapping("/{id}")    public Ball findById(@PathVariable long id) {        return repository.findById(id)            .orElseThrow(() -> new BallNotFoundException());    }     @GetMapping("/")    public Collection findBooks() {        return repository.getBooks();    }     @PutMapping("/{id}")    @ResponseStatus(HttpStatus.OK)    public Book updateBook(@PathVariable("id") final String id, @RequestBody final Book book) {        return book;    }}

启动项目,在浏览器中访问地址:

http://localhost:8080/swagger-ui-custom.html

swagger-ui的界面:

Spring Doc 生成OPEN API 3文档_第2张图片

swagger-ui

4. springdoc-openapi 与Spring WebFlux集成

我们可以在Spring WebFlux 项目中通过添加依赖:springdoc-openapi-webflux-uispringdoc-openapi and Swagger UI 集成:

    org.springdoc    springdoc-openapi-webflux-ui    1.1.45

然后,浏览器访问地址

http://localhost:8080/swagger-ui.html

同样的,可以通过添加 springdoc.swagger-ui.path 配置项到 application.properties文件来自定义文档访问路径。

5. 使用springdoc-openapi Maven 插件

springdoc-openapi 库提供了 springdoc-openapi-maven-plugin插件,用来生成JSON或者yaml格式的Open API 描述。

springdoc-openapi-maven-plugin 依赖于 spring-boot-maven 插件. Maven在集成测试阶段运行openapi插件。

那么,如何在pom.xml中配置插件呢?请看下面的代码:

    org.springframework.boot    spring-boot-maven-plugin    2.1.8.RELEASE                        pre-integration-test                            start                                        post-integration-test                            stop                            org.springdoc    springdoc-openapi-maven-plugin    0.2                        integration-test                            generate                        

当然, 也可以用自定义值来配置插件:

            .........                 http://localhost:8080/v3/api-docs         openapi.json         ${project.build.directory}     

仔细看看我们在插件中配置的几个参数:

  • apiDocsUrl – 访问json格式文档的URL, 默认路径:http://localhost:8080/v3/api-docs

  • outputFileName – 存放定义的路径, 默认为:openapi.json

  • outputDir – 文档存放的绝对路径–默认为:${project.build.directory}

6. 使用 JSR-303 Bean Validation 自动生成文档

当我们在模型中使用 JSR-303 bean validation 注解, 诸如 @NotNull@NotBlank@Size@Min@Max等, springdoc-openapi 会为这些bean生成相应的约束。

举个栗子:

public class Ball {     private long id;     @NotBlank    @Size(min = 0, max = 20)    private String title;     @NotBlank    @Size(min = 0, max = 30)    private String author; }

Ball bean生成的文档内容更为丰富:

Spring Doc 生成OPEN API 3文档_第3张图片

7. 使用 @ControllerAdvice和@ResponseStatus生成文档

在*@RestControllerAdvice注解的类中,在方法上使用@ResponseStatus会自动生成带有返回状态码的文档。如以下被@ControllerAdvice注解的类中,@ResponseStatus*修饰的两个方法:

@RestControllerAdvicepublic class GlobalControllerExceptionHandler {     @ExceptionHandler(ConversionFailedException.class)    @ResponseStatus(HttpStatus.BAD_REQUEST)    public ResponseEntity handleConnversion(RuntimeException ex) {        return new ResponseEntity<>(ex.getMessage(), HttpStatus.BAD_REQUEST);    }         @ExceptionHandler(BallNotFoundException.class)    @ResponseStatus(HttpStatus.NOT_FOUND)    public ResponseEntity handleBallNotFound(RuntimeException ex) {        return new ResponseEntity<>(ex.getMessage(), HttpStatus.NOT_FOUND);    }}

现在我们可以在文档中看到返回状态码为400和404。

Spring Doc 生成OPEN API 3文档_第4张图片

8. 小结

Spring Boot 2.2.x版本目前可能不支持,因此使用时最好使用2.1.x ,本文所使用Spring Boot版本 2.1.8.RELEASE。

有兴趣的朋友可以自己动手试一下,以上代码可在我的github中找到, over on GitHub.

本文通过OpenWrite的Markdown转换工具发布

关注我,回复“加群加入各种主题讨论群

  • 使用 LocalDateTime 而不是 Date

  • 深入解读阿里云Redis开发规范:不要只会set&get

  • 在服务器上排除问题的头 5 分钟

  • 多个Java版本如何灵活切换和管理?

  • Spring 体系常用项目一览

  • 阿里规定超过三张表禁止JOIN,为啥?

朕已阅 

你可能感兴趣的:(Spring Doc 生成OPEN API 3文档)