Swagger API 文档 | SpringBoot 3.x 集成 SpringDoc

2024-04-15 07:36

本文主要是介绍Swagger API 文档 | SpringBoot 3.x 集成 SpringDoc,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 常规方式
    • 第 1 步:添加依赖
    • 第 2 步:配置 API 信息及全局参数
      • 配置 OpenAPI 文档
        • 配置单个 OpenAPI 文档 - 方式 1
        • 配置单个 OpenAPI 文档 - 方式 2
        • 配置多个 OpenAPI 文档
      • 其它 SpringDoc 及 Swagger-UI 配置
    • 第 3 步:添加 Swagger3 注解
      • Swagger2 和 Swagger3 注解对应关系
      • Swagger3 注解案例
        • Feign 客户端及其实现 Controller
        • 通用 Response 与 Account 实体类
        • 界面效果
  • 特殊方式 1:从 JavaDoc 生成 API 定义
    • 第 1 步:添加依赖
    • 第 2 步:编译项目
    • 第 3 步:添加 JavaDoc 注释
    • 第 4 步:最终效果
  • 特殊方式 2:构建时生成 JSON/YAML
  • 相关博文

😎 本节目标: SpringBoot 3.x 集成 SpringDoc(含 SpringFox 升级 SpringDoc)

  • 常规方式:添加注解方式,然后生成 API 文档及 Swagger UI 界面
  • 特殊方式 1:从 JavaDoc 读取 API 定义
  • 特殊方式 2:maven 集成测试阶段生成 API 定义

👉 版本说明

  • JDK 17
  • SpringBoot 3.2.1
  • SpringDoc 2.3.0

🚀 官方 demo:springdoc-openapi-demos-2.x.zip

常规方式

第 1 步:添加依赖

移除 SpringFox 和 Swagger2 的相关依赖,并添加 springdoc-openapi-starter-webmvc-ui 依赖:

<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-starter-webmvc-ui</artifactId><version>2.3.0</version>
</dependency>

添加上述依赖后,即可访问 SwaggerUI 界面及 OpenAPI 文档。
Swagger-UI 访问效果:http://server:port/context-path/swagger-ui.html
image.png
OpenAPI 访问效果:

  • JSON 格式: http://server:port/context-path/v3/api-docs
  • YAML 格式:http://server:port/context-path/v3/api-docs.yaml

image.png

第 2 步:配置 API 信息及全局参数

上述 Swagger UI 界面中,使用的是默认的 API 信息。下面我们来自定义:

  • 添加 API 信息,比如标题、描述等
  • 添加全局请求 Token

下面有几种方式,可按需选择。

配置 OpenAPI 文档

配置单个 OpenAPI 文档 - 方式 1

在配置前,我们先了解一个特性:Swagger 中的有些注解,支持 Spring 配置解析。

  • @Info: title * description * version * termsOfService
  • @Info.license: name * url
  • @Info.contact: name * email * url
  • @Operation: description * summary
  • @Parameter: description * name
  • @ApiResponse: description
  • @OAuthFlow: openIdConnectUrl * authorizationUrl * refreshUrl * tokenUrl
  • @Schema: name * title * description,但需要设置 springdoc.api-docs.resolve-schema-properties=true

利用这个特性,我们使用如下配置文件进行自定义 API 信息及全局配置:

@OpenAPIDefinition(info = @Info(title = "${openapi.title: ${spring.application.name}} API文档",version = "${openapi.version: 0.0.1}",description = "${openapi.description:}",termsOfService = "${openapi.termsOfService:}",license = @License(name = "${openapi.license.name:}",url = "${openapi.license.url:}"),contact = @Contact(name = "${openapi.contact.name:}",email = "${openapi.contact.email:}",url = "${openapi.contact.url:}")),security = @SecurityRequirement(name = "JWT")
)
@SecurityScheme(type = SecuritySchemeType.HTTP, name = "JWT", scheme = "Bearer", in = SecuritySchemeIn.HEADER)
@Configuration
public class SpringDocConfig {}

这样,我们可以使用 openapi.title 定义 API 标题,使用 openapi.version 定义 API 版本。比如:

openapi:title: 业务服务version: v1.0.0

页面效果:
image.png此外,前面定义了安全配置,即每个请求需要在请求头中加 Bearer token。在上述页面中,显示了 Authorize 按钮,可以输入 Token 值。
image.png
后续请求,就会自动带着这个 Bearer Token:
image.png

配置单个 OpenAPI 文档 - 方式 2

换个方式,一样可以实现。可以直接构造 OpenAPI 这个对象,而不是使用注解来定义。
思路和之前一样:

  • 先定义安全 Schema:@SecurityScheme -> addSecuritySchemes
  • 然后使用组件:security = xxx -> .addSecurityItem
@Configuration
public class SpringDocConfig {@Beanpublic OpenAPI customOpenAPI(@Value("${springdoc.version:1.0.0}") String appVersion) {return new OpenAPI()// 定义组件.components(new Components().addSecuritySchemes("JWT", new SecurityScheme().in(SecurityScheme.In.HEADER).type(SecurityScheme.Type.HTTP)

这篇关于Swagger API 文档 | SpringBoot 3.x 集成 SpringDoc的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/905219

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依