SpringBoot 3.0 升级之 Swagger 升级

最近想尝试一下最新的 SpringBoot 项目,于是将自己的开源项目进行了一些升级。

  • JDK 版本从 JDK8 升级至 JDK17
  • SpringBoot 版本从 SpringBoot 2.7.3 升级到 SpringBoot 3.2.0

SpringFox3.0.0

SpringBoot2.7.3 版本的时候,项目使用的是 SpringFox3.0.0 的依赖,用于使用 Swagger,相关依赖如下:

<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>

项目编译没有问题,但是启动运行的时候报错 javax.servlet.http.HttpServletRequest ClassNotFoundException 异常。

这是因为 SpringFox3.0.0 底层有 Swagger2 和 Swagger3 两套一来,其中 Swagger2 底层依赖 javax 模块,但是在 SpringBoox3 的版本中已经彻底移除了 javax 模块,改为使用 jakarta ,所以才会报这个错误。

openapi3

解决方案:移除 Swagger2,改为完全使用 Swagger3。

在项目 pom.xml 中移除 SpringFox3.0.0 的依赖,改为使用 openapi3 的依赖,如下:

<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
    <version>4.0.0</version>
</dependency>

Swagger 注解迁移

Swagger2 和 Swagger3 使用的是完全不同的两套注解,所以原本使用 Swagger2 相关注解的代码页需要完全迁移,改为使用 Swagger3 的注解。

Swagger2 Swagger3
@Api @Tag
@ApiOperation @Operation
@ApiImplicitParams @Parameters
@ApiImplicitParam @Parameter
@ApiModel @Schema
@ApiModelProperty @Schema
@ApiResponses @ApiResponses
@ApiResponse @ApiResponse
@ApiIgnore @Hidden 或者 其他注解的 hidden = true 属性

@Api

  • Swagger2 代码
@Api(value = "用户操作接口", tags = "UserController")
  • Swagger3 代码
@Tag(name = "UserController", description = "用户操作接口")

@ApiOperation

  • Swagger2 代码
@ApiOperation(value = "分页查询用户数据")
  • Swagger3 代码
@Operation(description = "分页查询用户数据")

@ApiImplicitParam

  • Swagger2 代码
@ApiImplicitParams({
   
     @ApiImplicitParam(name = "currentPage", value = "当前页码", dataTypeClass = Integer.class, required = true),
     @ApiImplicitParam(name = "size", value = "当前页大小", defaultValue = "10", dataTypeClass = Integer.class),
     @ApiImplicitParam(name = "queryUser", value = "用户查询条件", dataTypeClass = User.class)
}
  • Swagger3 代码
@Parameters({
   
    @Parameter(name = "currentPage", description = "当前页码", required = true),
    @Parameter(name = "size", description = "当前页大小", example = "10"),
    @Parameter(name = "queryUser", description = "用户查询条件")
})

@ApiModel

  • Swagger2 代码
@ApiModel(value = "用户信息实体类")
  • Swagger3 代码
@Schema(name = "用户信息实体类")

@ApiModelProperty

  • Swagger2 代码
@ApiModelProperty(value = "用户名称")
  • Swagger3 代码
@Schema(name = "用户名称")

相关推荐

  1. SpringBoot 3.0 升级 Swagger 升级

    2023-12-17 00:52:01       53 阅读
  2. 升级到springdoc的Swagger3

    2023-12-17 00:52:01       34 阅读
  3. SpringBoot2升级SpringBoot3总结

    2023-12-17 00:52:01       38 阅读
  4. spring-session升级

    2023-12-17 00:52:01       47 阅读
  5. Android App-targetSDKVersion28升级30

    2023-12-17 00:52:01       50 阅读
  6. 升级道:精通Conda的自我升级艺术

    2023-12-17 00:52:01       31 阅读
  7. 【Spring】SpringMVC项目升级SpringBoot实践

    2023-12-17 00:52:01       76 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-17 00:52:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-17 00:52:01       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-17 00:52:01       82 阅读
  4. Python语言-面向对象

    2023-12-17 00:52:01       91 阅读

热门阅读

  1. (第38天)RAC 修改 IP 信息

    2023-12-17 00:52:01       55 阅读
  2. 前端(二)

    2023-12-17 00:52:01       54 阅读
  3. 使用Python实现蒙特卡罗算法

    2023-12-17 00:52:01       54 阅读
  4. C#基础——面向对象(封装 继承 多态)

    2023-12-17 00:52:01       64 阅读
  5. ca-certificates.crt解析加载到nssdb中

    2023-12-17 00:52:01       55 阅读
  6. Go中的工作池:并发任务的优雅管理

    2023-12-17 00:52:01       52 阅读
  7. 快速学习C++中的模板

    2023-12-17 00:52:01       54 阅读
  8. [笔记] wsl2 下使用 qemu/grub 模拟系统启动(多分区)

    2023-12-17 00:52:01       55 阅读
  9. 来聊聊CAS

    2023-12-17 00:52:01       57 阅读
  10. Linux 中定时任务

    2023-12-17 00:52:01       55 阅读