SpringBoot 3.5 集成 Knife4j 4.3的详细步骤

 更新时间:2026年04月29日 09:51:22   作者:贝玉开源  
这篇文章给大家介绍SpringBoot3.5集成Knife4j 4.3步骤,本文分步骤结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

避坑指南:还在用 SpringFox?快换成这位“天选之子”吧!

各位小伙伴,有没有遇到过这种让人抓狂的场面:兴冲冲地把 Spring Boot 2 升级到 Spring Boot 3,一启动,嘿,项目跑起来了!正准备给自己点个赞,结果一打开 Swagger 页面——404 空白。

这时候你才恍然大悟:原来当年陪我们渡过了无数个 CRUD 日夜的 SpringFox,早在 2020 年就悄悄停更了。它不仅跟不上 OpenAPI 3 的新潮规范,更致命的是,它底层死死抱住的 javax.* 包,在 Spring Boot 3 时代已经被彻底连根拔起,换成了 jakarta.* 。

简单来说,这不是你代码写得有问题,而是时代的眼泪。面对这种“版本刺客”,硬刚肯定是不现实的。既然官宣分手,咱们就得收拾心情,寻找新的幸福——也就是今天的主角:SpringDoc。而 Knife4j 的底层就是SpringDoc。

为什么我说它是“天选之子”?

• 无缝衔接:它是基于 OpenAPI 3 规范量身定制的,对 Spring Boot 3 甚至 WebFlux 都是原生级支持,丝滑得就像德芙。

• 极简主义:以前用 SpringFox 时,那一堆繁琐的 Docket 配置是不是让你很头疼?换成 SpringDoc 后,很多时候你只需要引入一个 Starter 依赖,连配置文件都不用写就能直接起飞。

• 社区活跃:不像前任那样玩失踪,SpringDoc 社区更新非常活跃,遇到 Bug 也有人管,这才是长长久久的靠谱之选。

一、 核心组件与关系介绍

在微服务架构中,API 文档工具通常分为“规范”、“生成器”和“展示层”三个部分。以下是它们的具体分工与关系:

组件

角色定位

核心作用

与 Knife4j 的关系

Swagger (OpenAPI 3)

接口规范

定义了一套用于描述 API 接口的标准(如路径、参数、返回值)。

Knife4j 完全遵循 OpenAPI 3.0 规范生成文档。

SpringDoc

规范实现

扫描 Spring Boot 代码中的注解 (如 @Tag, @Operation) ,自动生成符合 OpenAPI 规范的 JSON 数据。

SpringDoc 自带原生 Swagger UI。

底层依赖。Knife4j 4.x 已内置 SpringDoc,负责数据的生产。

Knife4j

UI 增强层

基于 SpringDoc 提供的数据,渲染出美观、交互性更强的文档界面。

上层封装。在 SpringDoc 基础上提供了文档增强、离线导出等功能。

二、 Knife4j 简介与资源

Knife4j 是一个为 Java MVC 框架集成 Swagger 生成 API 文档的增强解决方案。其前身是 swagger-bootstrap-ui,旨在提供更符合国人习惯的接口文档体验。

  • 核心作用
    1. 文档说明:根据代码注解自动生成详尽的接口文档,包含请求/响应示例。
    2. 在线调试:提供强大的接口调试功能,支持全局参数、动态参数修改。
    3. 离线文档:支持导出 Markdown、HTML、Word 等格式的离线文档,方便交付。
    4. 界面优化:提供现代化的 UI 界面,支持深色模式、接口搜索与排序。
  • 官方资源

三、 Spring Boot 3.5 单体应用集成步骤

1. 环境准备

  • JDK:17 及以上(Spring Boot 3.x 强制要求)
  • Spring Boot:3.5.9
  • Knife4j:4.3.0

2. 引入 Maven 依赖

pom.xml 中添加 Knife4j 的 Starter。该依赖已内置 SpringDoc,无需再单独引入 Swagger 相关包。

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

依赖包 knife4j-openapi3-jakarta-spring-boot-starter 包含子依赖包主要有:

依赖包

描述

核心作用

knife4j-openapi3-ui

Knife4j 的 UI 核心

提供增强的 Web 界面 (/doc.html),包含文档渲染、接口调试、全局参数、离线导出等功能。

knife4j-core

Knife4j 工具模块

提供工具类、模型定义、核心工具链等底层支持。

springdoc-openapi-starter-webmvc-ui

SpringDoc WebMVC 集成与 UI

提供原生的 Swagger UI (/swagger-ui.html),是 SpringDoc 自动配置的入口。

springdoc-openapi-starter-webmvc-api

SpringDoc WebMvc API 支持

提供对 Spring WebMVC 的底层支持,包含请求/响应处理、参数解析等。

springdoc-openapi-starter-webmvc-common

SpringDoc WebMvc 通用模块

包含 SpringDoc 的通用工具类和核心逻辑,是 API 模块的基础。

swagger-annotations-jakarta

OpenAPI 注解库 (Jakarta)

提供 jakarta命名空间版本的 OpenAPI 注解,如 @Tag, @Operation, @Schema等。

swagger-models-jakarta

OpenAPI 模型库 (Jakarta)

提供 jakarta命名空间版本的 OpenAPI 数据模型,如 Info, Contact, OpenAPI等。

swagger-ui

Swagger UI 前端资源

包含 Swagger UI 的所有前端静态资源(HTML, JS, CSS),被 springdoc-openapi-starter-webmvc-ui所依赖。

3. 配置文件 (application.yml)

配置 SpringDoc 的扫描规则和 Knife4j 的增强特性。

# SpringDoc 原生配置
springdoc:
  swagger-ui:
    enabled: true
    path: /swagger-ui.html
    tags-sorter: alpha
    operations-sorter: alpha
  api-docs:
    enabled: true
    path: /v3/api-docs
  group-configs:
    - group: default
      paths-to-match: '/**'
      packages-to-scan: com.example.controller
# Knife4j 增强配置
knife4j:
  enable: true
  setting:
    language: zh_cn
    enable-swagger-models: true
    swagger-model-name: 实体类列表

4. 初始化配置 @Configuration

/**
 * OpenApi3在线接口文档组件初始化
 */
@Slf4j
@Configuration(proxyBeanMethods = false)
@ConditionalOnProperty(name = "springdoc.api-docs.enabled", matchIfMissing = true)
public class OpenApi3Config {
    @Bean
    public OpenAPI springDocOpenAPI() { 
        return new OpenAPI(SpecVersion.V30).info(new Info()
                                                 .title("API文档")
                                                 .description("简介")
                                                 .version("v1.0"))
        // 配置Authorizations
        .components(new Components()
                    .addSecuritySchemes("Authorization", new SecurityScheme().name("Authorization").in(SecurityScheme.In.HEADER).type(SecurityScheme.Type.APIKEY))
                    .addSecuritySchemes("TenandId", new SecurityScheme().name("TenandId").in(SecurityScheme.In.HEADER).type(SecurityScheme.Type.APIKEY)));
    } 
}

5. 注解示例

Spring Boot 3.x 使用 OpenAPI 3 规范注解,与旧版 Swagger 2 不同。

注解

作用位置

描述

示例/替代旧注解

@Tag

Controller 类

API 分组标签

替代 @Api

@Operation

Controller 方法

单个接口的详细描述

替代 @ApiOperation

@Parameter

方法参数

描述单个参数

替代 @ApiParam

@Schema

模型类/字段

描述数据模型/字段

替代 @ApiModel, @ApiModelProperty

@Parameters

方法

多个参数的容器

包含多个 @Parameter

控制器Controller

import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
@RestController
@RequestMapping("/api/users")
@Tag(name = "用户管理")
public class UserController {
    @GetMapping("/{id}")
    @Operation(summary = "根据ID查询用户")
    public String getUser(@Parameter(description = "用户ID", required = true) @PathVariable Long id) {
        return "User " + id;
    }
}

实体Bean

@Schema(description = "用户信息")
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor 
public class UserInfo   { 
    /**
	 * 中文名
	 */
	@Schema(description = "中文名") 
	private String name;
}

6 访问验证

启动项目后,访问以下地址:

效果图

四、 Spring Cloud Gateway 集成方案

在微服务架构中,通常希望在网关层聚合所有微服务的接口文档,无需逐个访问子服务。

1. 网关服务 (Gateway) 配置

在 Gateway 模块中引入聚合依赖:

<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>knife4j-gateway-spring-boot-starter</artifactId>
    <version>4.3.0</version>
</dependency>
<!-- 这里特别注意,只能引入 springdoc-openapi-starter-webflux-api ,
不要引入 springdoc-openapi-starter-webflux-ui, 
不然在 doc.html 会出现微服务下拉列表无法获取数据 -->
<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webflux-api</artifactId>
    <version>2.8.15</version> 
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway-server-webflux</artifactId>
    <version>4.3.3</version> 
</dependency>

application.yml 中开启服务发现模式聚合:

# 第二种配置方式:自动发现
knife4j:
  gateway:
    enabled: true
    # 指定聚合模式为服务发现(基于注册中心如 Nacos/Eureka)
    strategy: discover
    discover:
      enabled: true
      version: openapi3
# 第二种配置方式:手动配置
knife4j:
  gateway:
    enabled: true
    strategy: manual
    operations-sorter: order
    routes:
      - name: 用户服务
        context-path: /user
        url: /user/v3/api-docs/default
      - name: 订单管理
        context-path: /order
        url: /order/v3/api-docs/default

2. 子微服务 (Service) 配置

确保每个业务微服务都按照 第三部分 的步骤引入了 knife4j-openapi3-jakarta-spring-boot-starter 并正确配置了 packages-to-scan

3. 访问方式

启动网关和各个微服务后,直接访问 网关的地址 即可查看聚合文档:

http://网关IP:网关端口/doc.html

效果图

到此这篇关于SpringBoot 3.5 集成 Knife4j 4.3的详细步骤的文章就介绍到这了,更多相关SpringBoot 集成 Knife4j内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • gradle项目中资源文件的相对路径打包技巧必看

    gradle项目中资源文件的相对路径打包技巧必看

    这篇文章主要介绍了gradle项目中资源文件的相对路径打包技巧必看篇,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Spring Boot支持Crontab任务改造的方法

    Spring Boot支持Crontab任务改造的方法

    这篇文章主要介绍了Spring Boot支持Crontab任务改造的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • SpringMVC开发restful API之用户查询代码详解

    SpringMVC开发restful API之用户查询代码详解

    这篇文章主要介绍了SpringMVC开发restful API之用户查询代码详解,小编觉得挺不错的,这里分享给大家,需要的朋友可以参考。下面随小编一起看看吧。
    2017-11-11
  • 一文详解如何使用IO流实现文件数据的读写及文件复制

    一文详解如何使用IO流实现文件数据的读写及文件复制

    Java中的IO流是基础操作之一,包括控制台输入、控制台输出、读写文件等,下面这篇文章主要介绍了如何使用IO流实现文件数据的读写及文件复制的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-10-10
  • Java实现将数字日期翻译成英文单词的工具类实例

    Java实现将数字日期翻译成英文单词的工具类实例

    这篇文章主要介绍了Java实现将数字日期翻译成英文单词的工具类,结合完整实例形式分析了Java日期转换与字符串操作相关实现技巧,需要的朋友可以参考下
    2017-09-09
  • Java纯代码实现导出pdf合并单元格

    Java纯代码实现导出pdf合并单元格

    这篇文章主要为大家详细介绍了Java如何纯代码实现导出pdf与合并单元格功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • System.getProperty(“line.separator“)含义及意义详解

    System.getProperty(“line.separator“)含义及意义详解

    这篇文章主要介绍了System.getProperty(“line.separator“)含义,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • SpringBoot2.6.x默认禁用循环依赖后的问题解决

    SpringBoot2.6.x默认禁用循环依赖后的问题解决

    由于SpringBoot从底层逐渐引导开发者书写规范的代码,同时也是个忧伤的消息,循环依赖的应用场景实在是太广泛了,所以SpringBoot 2.6.x不推荐使用循环依赖,本文给大家说下SpringBoot2.6.x默认禁用循环依赖后的应对策略,感兴趣的朋友一起看看吧
    2022-02-02
  • Spark调度架构原理详解

    Spark调度架构原理详解

    这篇文章主要介绍了Spark 调度架构原理详解,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • springmvc 中dao层和service层的区别说明

    springmvc 中dao层和service层的区别说明

    这篇文章主要介绍了springmvc 中dao层和service层的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08

最新评论