Swagger2与Springdoc集成与使用详解

2025-05-24 03:50

本文主要是介绍Swagger2与Springdoc集成与使用详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐...

以下是将 Swagger2 迁移到 Springdoc(支持 OpenAPI 3)的集成与使用指南,涵盖关键步骤、配置示例及注意事项:

1. 依赖配置

Springdoc 是支持 OpenAPI 3 规范的现代工具,适用于 Spring Boot 项目。

需替换或添加以下依赖:

<!-- Maven 依赖 -->
<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
    <version>2.2.0</version> <!-- 使用最新版本 -->
</dependency>

注意:若项目原使用 springfox-swagger2,需移除相关依赖以避免冲突。

2. 基础配置

2.1 启用 Springdoc

Springdoc 自动配置,无需显式启用注解。

application.propertiesapplication.yml 中配置基本信息:

# application.properties
springdoc.swagger-ui.enabled=true
springdoc.api-docs.path=/api-docs
springdoc.swagger-ui.path=/swagger-ui.html
springdoc.version=1.0.0
springdoc.default-produces-media-type=application/json

2.2 自定义 OpenAPI 信息

通过 Java 配置类定义 API 元数据:

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;

@Configuration
public class OpenApiConfig {

    @Bean
    public OpenAPI customOpenAPI() {
        return new OpenAPI()
                .info(new Info()
                        .title("API 文档")
                        .version("1.0")
                        .description("基于 Springdoc 的 OpenAPI 文档")
                        .contact(new Contact().name("开发者").http://www.chinasem.cnemail("dev@example.com"))
                        .license(new License().name("Apache 2.0")));
    }
}

3. 注解使用

Springdoc 使用 io.swagger.v3.oas.annotations 注解替代 io.swagger.annotations

常用注解对照表:

Swagger2 注解Springdoc 注解用途
@Api@Tag控制器分类描述
@ApiOperation@Operation接口方法描述
@ApiParam@Parameter方法参数描述
@ApiModel@Schema数据模型描述
@ApiModelProperty@Schema模型字段描述
@ApiResponse@ApiResponse接口响应描述

示例代码:

import io.swagger.v3.oas.annotations.Operationhttp://www.chinasem.cn;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;

@RestController
@Tag(name = "用户管理"China编程, description = "用户相关操作接口")
@RequestMapping("/users")
public class UserController {

    @Operation(summary = "获取用户详情", description = "根据用户ID查询详细信息")
    @GetMapping("/{id}")
    public User getUser(
        @Parameter(description = "用户ID", required = true) @PathVariable Long id) {
        // 业务逻辑
    }
}

4. 访问 Swagger UI

启动应用后,通过以下 URL 访问交互式文档界面:

  • Swagger UI: http://localhost:8080/swagger-ui.html
  • OpenAPI JSON: http://localhost:8080/v3/api-docs

5. 高级配置

5.1 分组多套 API

为不同模块配置多组 API 文档:

@Bean
public GroupedOpenApi publicApi() {
    return GroupedOpenApi.builder()
            .group("public-apis")
            .pathttp://www.chinasem.cnhsToMatch("/api/public/**")
            .build();
}

@Bean
public GroupedOpenApi adminApi() {
    return GroupedOpenApi.builder()
            .group("admin-apis")
            .pathsToMatch("/api/admin/**")
            .build();
}

5.2 安全配置

集成 JWT 或 OAuth2 时,添加安全方案:

@Bean
public OpenAPI customOpenAPI() {
    return new OpenAPI()
            .components(new Components()
                    .addSecuritySchemes("bearerAuth", 
                        new SecurityScheme()
                   javascript         .type(SecurityScheme.Type.HTTP)
                            .scheme("bearer")
                            .bearerFormat("JWT")))
            .info(/* 略 */);
}

6. 与 Spring Security 集成

确保 Spring Security 允许访问文档端点:

@Configuration
@EnableWebSecurity
public class SecurityConfig {

    @Bean
    public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
        http
            .authorizeHttpRequests(auth -> auth
                .requestMatchers("/swagger-ui/**", "/v3/api-docs/**").permitAll()
                .anyRequest().authenticated()
            );
        return http.build();
    }
}

7. 迁移注意事项

  1. 移除旧依赖:彻底清除 springfox-swagger2swagger-annotations
  2. 注解替换:全局替换包路径 io.swagger.annotationsio.swagger.v3.oas.annotations
  3. 路径变化:Swagger UI 的默认路径从 /swagger-ui/ 变为 /swagger-ui.html

8. 常见问题

Q1: 文档页面无法加载?

  • 检查依赖冲突:确保无 springfox 残留依赖。
  • 验证路径配置:确认 springdoc.swagger-ui.path 未被覆盖。

Q2: 注解未生效?

  • 包路径正确性:确认使用 io.swagger.v3.oas.annotations 下的注解。
  • 方法签名匹配@Parameter 需直接修饰参数或配合 @RequestParam 使用。

通过以上步骤,可快速将项目从 Swagger2 迁移至 Springdoc,并充分利用 OpenAPI 3 的新特性。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程China编程(www.chinasem.cn)。

这篇关于Swagger2与Springdoc集成与使用详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v