欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > Swagger2与Springdoc集成与使用指南

Swagger2与Springdoc集成与使用指南

2025/5/24 22:10:54 来源:https://blog.csdn.net/m0_51041242/article/details/147279267  浏览:    关键词: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 {@Beanpublic OpenAPI customOpenAPI() {return new OpenAPI().info(new Info().title("API 文档").version("1.0").description("基于 Springdoc 的 OpenAPI 文档").contact(new Contact().name("开发者").email("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.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;@RestController
@Tag(name = "用户管理", 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").pathsToMatch("/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().type(SecurityScheme.Type.HTTP).scheme("bearer").bearerFormat("JWT"))).info(/* 略 */);
}

6. 与 Spring Security 集成

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

@Configuration
@EnableWebSecurity
public class SecurityConfig {@Beanpublic 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 的新特性。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词