springdoc-openapi Java 库有助于使用 Spring Boot 项目自动生成 API 文档。springdoc-openapi 通过在运行时检查应用程序来根据 Spring 配置、类结构和各种注释推断 API 语义。
该库会自动生成 JSON/YAML 和 HTML 格式的页面文档。生成的文档可以使用swagger-api注释进行补充。
github地址 官网
1. 项目依赖版本
- Spring-Boot: 3.1.0
2. 引入依赖
<dependency>
<groupId>org.springdoc</groupId>
<artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
<version>2.3.0</version>
</dependency>
3. 配置
package com.omni.admin.swagger;
import io.swagger.v3.oas.models.Components;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.security.SecurityRequirement;
import io.swagger.v3.oas.models.security.SecurityScheme;
import jakarta.annotation.Resource;
import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* SpringDoc配置
**/
@Configuration
@ConditionalOnExpression("${springdoc.api-docs.enabled:true}")
public class SwaggerDocConfig {
@Resource
private SwaggerDocProperties springDocProperties;
@Bean
public OpenAPI openAPI() {
return new OpenAPI().info(new Info().title(springDocProperties.getTitle()).version(springDocProperties.getApplicationVersion()))
.addSecurityItem(new SecurityRequirement().addList(springDocProperties.getTokenName()))
.components(new Components().addSecuritySchemes(springDocProperties.getTokenName(),getSecurityScheme()));
}
private SecurityScheme getSecurityScheme(){
return new SecurityScheme().name(springDocProperties.getTokenName()).in(SecurityScheme.In.HEADER).type(SecurityScheme.Type.APIKEY).scheme("basic");
}
}
package com.omni.admin.swagger;
import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
import java.util.List;
/**
* swagger配置类
**/
@Data
@Configuration
@ConfigurationProperties(prefix = "springdoc")
@ConditionalOnExpression("${springdoc.api-docs.enabled:true}")
public class SwaggerDocProperties {
/**
* 项目应用名
*/
@Value("${spring.application.name:接口文档}")
private String applicationName;
/**
* 项目名称
*/
private String title = "Omni-Admin后台管理系统接口文档";
/**
* 项目版本信息
*/
private String applicationVersion = "1.0.0";
/**
* 项目描述信息
*/
private String applicationDescription;
/**
* 认证token的名称
*/
private String tokenName = "X-Access-Token";
/**
* 文档组配置
*/
private List<Group> groups;
@Data
public static class Group{
private String modelName;
/**
* 组名称
*/
private String name;
/**
* 组所属的包
*/
private String packageName;
}
}
4. properties配置
这里需要做一些说明:其中配置了排序相关和分模块。还有默认访问是全部文档是展开的,可以配置默认合并。
# springdoc接口文档配置 配置参考 springdoc.md
springdoc.api-docs.enabled=true
springdoc.swagger-ui.tags-sorter=alpha
springdoc.swagger-ui.operations-sorter=method
springdoc.group-configs[0].group=A-平台管理
springdoc.group-configs[0].packages-to-scan[0]=auth.platform.service.platform
springdoc.group-configs[1].group=B-标签管理
springdoc.group-configs[1].packages-to-scan[0]=auth.platform.service.tag
springdoc.group-configs[2].group=C-配置中心
springdoc.group-configs[2].packages-to-scan[0]=auth.platform.service.configcenter
springdoc.group-configs[3].group=D-日志管理
springdoc.group-configs[3].packages-to-scan[0]=auth.platform.service.log
springdoc.group-configs[4].group=F-监控管理
springdoc.group-configs[4].packages-to-scan[0]=auth.platform.service.monitor
springdoc.group-configs[5].group=G-文件管理
springdoc.group-configs[5].packages-to-scan[0]=auth.platform.service.file
springdoc.group-configs[6].group=H-WS消息管理
springdoc.group-configs[6].packages-to-scan[0]=auth.platform.service.websocket
# 该配置控制是否需要在界面显示过滤框
springdoc.swagger-ui.filter=true
# 该配置主要控制swagger显示是直接展开还是关闭 none 不默认展开 list 列出所有api full直接展开所有api
springdoc.swagger-ui.doc-expansion=none
5. 访问
http://localhost:8080/swagger-ui/index.html
6. Controller示例
package com.omni.admin.controller;
import com.omni.admin.common.result.ApiResult;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* 接口信息表
*/
@Tag(name = "接口管理")
@RestController
@RequestMapping("/api-info")
public class ApiInfoController {
@Operation(summary = "测试接口文档")
@GetMapping("/demo")
public ApiResult<Void> demo(){
return ApiResult.success();
}
}
7. Springdoc-openapi 属性
springdoc-openapi依赖于使用标准文件位置的标准 Spring 配置属性(YML 或属性)。
7.1. Springdoc-OpenAPI 核心属性
参数名称 | 默认值 | 描述 |
---|---|---|
springdoc.api-docs.path | /v3/api-docs | String ,用于 Json 格式的 OpenAPI 文档的自定义路径。 |
springdoc.api-docs.enabled | true | Boolean .禁用 springdoc-openapi 端点(默认为 /v3/api-docs)。 |
springdoc.packages-to-scan | * | List of Strings .要扫描的包列表(逗号分隔) |
springdoc.paths-to-match | /* | List of Strings .要匹配的路径列表(逗号分隔) |
springdoc.produces-to-match-to | /* | List of Strings .生成要匹配的媒体类型列表(逗号分隔) |
springdoc.headers-to-match | /* | List of Strings .要匹配的标头列表(逗号分隔) |
springdoc.consumptions-to-matchs. | /* | List of Strings .要匹配的消耗媒体类型列表(逗号分隔) |
springdoc.paths-to-exclude | List of Strings .要排除的路径列表(逗号分隔) | |
springdoc.packages-to-exclude | List of Strings .要排除的包列表(逗号分隔) | |
springdoc.default-consumptions-media-type | application/json | String .默认使用媒体类型。 |
springdoc.default-produces-media-type | **/** | String .默认生成媒体类型。 |
springdoc.cache.disabled | false | Boolean .禁用计算的 OpenAPI 的 springdoc-openapi 缓存。 |
弹簧文档显示执行器 | false | Boolean .显示执行器端点。 |
springdoc.auto-tag-classes | true | Boolean .禁用 springdoc-openapi 自动标记。 |
springdoc.model-and-view-allow | false | Boolean .允许带有 ModelAndView 的 RestControllers 返回出现在 OpenAPI 描述中。 |
springdoc.override-with-generic-response | true | Boolean .如果为 true,则自动将@ControllerAdvice响应添加到所有生成的响应中。 |
springdoc.api-docs.groups.enabled | true | Boolean .禁用 springdoc-openapi 组。 |
springdoc.group-configs[0].group | String .组名称 | |
springdoc.group-configs[0].displayName | String .组的显示名称。 | |
springdoc.group-configs[0].packages-to-scan | * | List of Strings .要扫描组的包列表(逗号分隔) |
springdoc.group-configs[0].paths-to-match | /* | List of Strings .要为组匹配的路径列表(逗号分隔) |
springdoc.group-configs[0].paths-to-exclude | `` | List of Strings .要为组排除的路径列表(逗号分隔) |
springdoc.group-configs[0].packages-to-exclude | List of Strings .要为组排除的包列表(逗号分隔) | |
springdoc.group-configs[0].produces-to-match | /* | List of Strings .生成要匹配的媒体类型列表(逗号分隔) |
springdoc.group-configs[0].consumes-to-match | /* | List of Strings .要匹配的消耗媒体类型列表(逗号分隔) |
springdoc.group-configs[0].headers-to-match | /* | List of Strings .要匹配的标头列表(逗号分隔) |
springdoc.webjars.prefix | /webjars | String ,要更改 webjars 前缀,该前缀可见 swagger-ui 的 URL 为 spring-webflux。 |
springdoc.api-docs.resolve-schema-properties | false | Boolean .在@Schema(名称、标题和说明)上启用属性解析程序。 |
springdoc.remove-broken-reference-definition | true | Boolean .禁用删除损坏的引用定义。 |
springdoc.writer-with-default-pretty-printer | false | Boolean .启用OpenApi规范的漂亮打印。 |
springdoc.model-converters.deprecating-converter.enabled | true | Boolean .禁用弃用模型转换器。 |
springdoc.model-converters.polymorphic-converter.enabled | true | Boolean .禁用多态模型转换器。 |
springdoc.model-converters.pageable-converter.enabled | true | Boolean .禁用可分页模型转换器。 |
springdoc.model-converters.sort-converter.enabled | true | Boolean .禁用排序转换器。 |
springdoc.use-fqn | false | Boolean .启用完全限定名称。 |
springdoc.show-login-endpoint | false | Boolean .使 Spring 安全登录端点可见。 |
springdoc.pre-load-enabled | false | Boolean .预加载设置,用于在应用程序启动时加载 OpenAPI。 |
springdoc.writer-with-order-by-keys | false | Boolean .启用确定性/字母顺序排序。 |
springdoc.use-management-port | false | Boolean .在执行器管理端口上公开招摇 UI。 |
springdoc.disable-i18n | false | Boolean .使用 i18n 禁用自动翻译。 |
springdoc.show-spring-cloud-functions | true | Boolean .显示弹簧云函数 Web 终结点。 |
springdoc.api-docs.version | openapi_3_0 | String .选择或(使用值 )。OpenAPI 3.0``OpenAPI 3.1``OPENAPI_3_1 |
springdoc.default-flat-paramObject | false | Boolean .默认平展参数。 |
springdoc.default-support-form-data | false | Boolean .在指定 api 以接受表单数据时默认设置表单数据的参数。 |
7.2. swagger-ui 属性
- 上提供了对 swagger-ui 属性的支持。请参阅官方文档。
springdoc-openapi
- 您可以在文档中使用与 Spring 引导属性相同的 swagger-ui 属性。
参数名称 | 默认值 | 描述 |
---|---|---|
springdoc.swagger-ui.path | /swagger-ui.html | String ,用于 swagger-ui HTML 文档的自定义路径。 |
springdoc.swagger-ui.enabled | true | Boolean .禁用 swagger-ui 端点(默认情况下为 /swagger-ui.html)。 |
springdoc.swagger-ui.configUrl | /v3/api-docs/swagger-config | String .要从中获取外部配置文档的 URL。 |
springdoc.swagger-ui.layout | BaseLayout | String .通过插件系统提供的组件的名称,用作 Swagger UI 的顶级布局。 |
springdoc.swagger-ui.validatorUrl | validator.swagger.io/validator | 默认情况下,Swagger UI 会尝试根据 swagger.io 的在线验证器验证规范。您可以使用此参数设置不同的验证程序 URL,例如,对于本地部署的验证程序验证程序徽章。将其设置为 ,或者将禁用验证。none``127.0.0.1``localhost |
springdoc.swagger-ui.tryItOutEnabled | false | Boolean .控制默认情况下是否应启用“试用”部分。 |
springdoc.swagger-ui.filter | false | Boolean OR String .如果设置,则启用筛选。顶部栏将显示一个编辑框,可用于筛选显示的标记操作。可以是用于启用或禁用的布尔值,也可以是字符串,在这种情况下,将使用该字符串作为筛选器表达式启用筛选。筛选区分大小写,与标记内任意位置的筛选器表达式匹配。 |
springdoc.swagger-ui.operationsSorter | Function=(a ⇒ a) .对每个 API 的操作列表应用排序。它可以是“alpha”(按路径字母数字排序),“method”(按HTTP方法排序)或函数(参见Array.prototype.sort()以了解排序函数的工作原理)。默认值为服务器返回的顺序不变。 | |
springdoc.swagger-ui.tagsSorter | Function=(a ⇒ a) .对每个 API 的标记列表应用排序。它可以是“alpha”(按路径字母数字排序)或函数,请参阅 Array.prototype.sort() 以学习如何编写排序函数)。每次传递时,将两个标记名称字符串传递给分拣机。默认值是由 Swagger UI 确定的顺序。 | |
springdoc.swagger-ui.oauth2RedirectUrl | /swagger-ui/oauth2-redirect.html | String .OAuth 重定向网址。 |
springdoc.swagger-ui.displayOperationId | false | Boolean .控制操作 ID 在操作列表中的显示。缺省值为 。false |
springdoc.swagger-ui.displayRequestDuration | false | Boolean .控制“试用”请求的请求持续时间(以毫秒为单位)的显示。 |
springdoc.swagger-ui.deepLink | false | Boolean .如果设置为 ,则启用标签和操作的深层链接。有关更多信息,请参阅 [深层链接文档](/docs/usage/deep-linking.md)。true |
springdoc.swagger-ui.defaultModelsExpandDepth | 1 | Number .模型的默认扩展深度(设置为 -1 将完全隐藏模型)。 |
springdoc.swagger-ui.defaultModelExpandDepth | 1 | Number .模型示例部分上模型的默认扩展深度。 |
springdoc.swagger-ui.defaultModelRendering | String=["example"*, "model"] .控制首次呈现 API 时模型的显示方式。(用户始终可以通过单击“模型”和“示例值”链接来切换给定模型的渲染。 | |
springdoc.swagger-ui.docExpansion | String=["list"*, "full", "none"] .控制操作和标记的默认展开设置。它可以是“列表”(仅展开标签)、“完整”(展开标签和操作)或“无”(不展开任何内容)。 | |
springdoc.swagger-ui.maxDisplayTags | Number .如果设置,将显示的标记操作数限制为最多此数量。默认值为显示所有操作。 | |
springdoc.swagger-ui.showExtensions | false | Boolean .控制供应商扩展 () 字段和操作、参数和架构的值的显示。x- |
springdoc.swagger-ui.url | String .要配置,自定义 OpenAPI 文件的路径。如果使用,将被忽略。urls | |
springdoc.swagger-ui.showCommonExtensions | false | Boolean .控制参数的扩展 (、、、、) 字段和值的显示。pattern``maxLength``minLength``maximum``minimum |
springdoc.swagger-ui.supportedSubmitMethods | Array=["get", "put", "post", "delete", "options", "head", "patch", "trace"] .启用了“试用”功能的 HTTP 方法列表。空数组禁用所有操作的“试用”。这不会从显示中过滤操作。 | |
springdoc.swagger-ui.queryConfigEnabled | false | Boolean .自 以来禁用。此参数启用(旧版)通过 URL 搜索参数覆盖配置参数。在启用此功能之前,请参阅安全公告。v1.6.0 |
springdoc.swagger-ui.oauth. additionalQueryStringParams | String .添加到授权 URL 和令牌 URL 的其他查询参数。 | |
springdoc.swagger-ui.disable-swagger-default-url | false | Boolean .禁用 swagger-ui 默认宠物商店网址。(从 v1.4.1 开始可用)。 |
springdoc.swagger-ui.urls[0].url | URL .Topbar 插件使用的 swagger 组的 url。URL 在此数组中的所有项中必须是唯一的,因为它们用作标识符。 | |
springdoc.swagger-ui.urls[0].name | String .Topbar 插件使用的 swagger 组的名称。名称在此数组中的所有项中必须是唯一的,因为它们用作标识符。 | |
springdoc.swagger-ui.urlsPrimaryName | String .加载 Swagger UI 时将显示的招摇组的名称。 | |
springdoc.swagger-ui.oauth.clientId | String .默认客户端 ID。必须是字符串。 | |
springdoc.swagger-ui.oauth.clientSecret | String .默认客户端机密。切勿在生产环境中使用此参数。它公开了重要的安全信息。此功能仅适用于开发/测试环境。 | |
springdoc.swagger-ui.oauth.realm | String .领域查询参数(适用于 OAuth 1)已添加到授权 URL 和令牌 URL。 | |
springdoc.swagger-ui.oauth.appName | String .OAuth 应用程序名称,显示在授权弹出窗口中。 | |
springdoc.swagger-ui.oauth.scopeSeparator | String .用于传递范围的 OAuth 范围分隔符,在调用之前进行编码,默认值为空格(编码值 %20)。 | |
springdoc.swagger-ui.csrf.enabled | false | Boolean .启用 CSRF 支持 |
springdoc.swagger-ui.csrf.use-local-storage | false | Boolean .从本地存储获取 CSRF 令牌。 |
springdoc.swagger-ui.csrf.use-session-storage | false | Boolean .从会话存储中获取 CSRF 令牌。 |
springdoc.swagger-ui.csrf.cookie-name | XSRF-TOKEN | String .可选的 CSRF,用于设置 CSRF cookie 名称。 |
springdoc.swagger-ui.csrf.header-name | X-XSRF-TOKEN | String .可选的 CSRF,用于设置 CSRF 标头名称。 |
springdoc.swagger-ui.syntaxHighlight.activated | true | Boolean .是否应激活语法突出显示。 |
springdoc.swagger-ui.syntaxHighlight.theme | agate | String …突出显示.js要使用的语法着色主题。(只有这 6 种样式可用。String=["agate"*, "arta", "monokai", "nord", "obsidian", "tomorrow-night"] |
springdoc.swagger-ui.oauth. useBasicAuthentication WithAccessCodeGrant | false | Boolean .仅针对访问代码流激活。在对 tokenURL 的authorization_code请求期间,使用 HTTP 基本身份验证方案(具有基本 base64encode(client_id + client_secret)的授权标头)传递客户端密码。 |
springdoc.swagger-ui.oauth. usePkceWithAuthorization CodeGrant | false | Boolean .仅适用于授权代码流。代码交换的证明密钥为 OAuth 公共客户端带来了增强的安全性。 |
springdoc.swagger-ui.persistAuthorization | false | Boolean .如果设置为 true,它将保留授权数据,并且在浏览器关闭/刷新时不会丢失 |
springdoc.swagger-ui.use-root-path | false | Boolean .如果设置为 true,则可以直接从应用程序根路径访问 swagger-u。 |
8. Springdoc-openapi 实例
8.1. springdoc 应用实例
8.2 演示应用程序的源代码
https://github.com/springdoc/springdoc-openapi-demos.git
9. 从SpringFox迁移
- 删除 springfox 和 swagger 2 依赖项。改为添加依赖项。
springdoc-openapi-ui
<dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-ui</artifactId> <version>1.6.14</version> </dependency>
- 将 swagger 2 注释替换为 swagger 3 注释(它已包含在依赖项中)。 招摇 3 注释的包是 .
springdoc-openapi-ui``io.swagger.v3.oas.annotations
@Api
→@Tag
@ApiIgnore
→或或@Parameter(hidden = true)``@Operation(hidden = true)``@Hidden
@ApiImplicitParam
→@Parameter
@ApiImplicitParams
→@Parameters
@ApiModel
→@Schema
@ApiModelProperty(hidden = true)
→@Schema(accessMode = READ_ONLY)
@ApiModelProperty
→@Schema
@ApiOperation(value = "foo", notes = "bar")
→@Operation(summary = "foo", description = "bar")
@ApiParam
→@Parameter
@ApiResponse(code = 404, message = "foo")
→@ApiResponse(responseCode = "404", description = "foo")
- 如果使用对象捕获多个请求查询参数,请使用
@ParameterObject
- 此步骤是可选的:仅当您有多个 bean 时,才将它们替换为 bean。
Docket``GroupedOpenApi
以前:
@Bean public Docket publicApi() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.basePackage("org.github.springshop.web.public")) .paths(PathSelectors.regex("/public.*")) .build() .groupName("springshop-public") .apiInfo(apiInfo()); } @Bean public Docket adminApi() { return new Docket(DocumentationType.SWAGGER_2) .select() .apis(RequestHandlerSelectors.basePackage("org.github.springshop.web.admin")) .paths(PathSelectors.regex("/admin.*")) .apis(RequestHandlerSelectors.withMethodAnnotation(Admin.class)) .build() .groupName("springshop-admin") .apiInfo(apiInfo()); }
现在:
@Bean public GroupedOpenApi publicApi() { return GroupedOpenApi.builder() .group("springshop-public") .pathsToMatch("/public/**") .build(); } @Bean public GroupedOpenApi adminApi() { return GroupedOpenApi.builder() .group("springshop-admin") .pathsToMatch("/admin/**") .addMethodFilter(method -> method.isAnnotationPresent(Admin.class)) .build(); }
如果你只有一个 - 删除它,而是将属性添加到你的 :Docket``application.properties
springdoc.packagesToScan=package1, package2
springdoc.pathsToMatch=/v1, /api/balance/**
@Bean public OpenAPI springShopOpenAPI() { return new OpenAPI() .info(new Info().title("SpringShop API") .description("Spring shop sample application") .version("v0.0.1") .license(new License().name("Apache 2.0").url("http://springdoc.org"))) .externalDocs(new ExternalDocumentation() .description("SpringShop Wiki Documentation") .url("https://springshop.wiki.github.org/docs")); }