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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来