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

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav