SpringBoot集成Knife4j实现接口文档和参数校验
一、核心认知
1.1 什么是SpringDoc OpenAPI?
SpringDoc OpenAPI 是 Spring Boot 生态中替代传统 Swagger2 的接口文档工具,基于 OpenAPI 3.0 规范,支持 Spring Boot 3.x(也兼容 2.x),核心优势是配置简单、原生支持 Spring Web/Spring WebFlux。
补充说明:
- Swagger2 已停止维护,SpringDoc 是目前官方推荐的替代方案
- OpenAPI 3.0 是国际通用接口描述标准,前后端分离开发必备
- Spring Boot 3.x 使用 Jakarta 包名,必须使用对应兼容版本
1.2 什么是 knife4j?
Knife4j 是国人开发的接口文档增强工具,底层基于 OpenAPI 规范(兼容 Swagger/SpringDoc),但提供了比原生 Swagger UI 更美观、更贴合国内开发者习惯的中文界面,还增加了离线文档导出、接口调试、权限控制等实用功能!
原生 SpringDoc 与 Knife4j 对比
| 特性 | 原生 SpringDoc (Swagger UI) | Knife4j (该依赖) |
|---|---|---|
| 界面语言 | 英文 | 中文 (可切换) |
| 界面风格 | 简约但不够友好 | 更美观、贴合国内使用习惯 |
| 额外功能 | 基础接口调试 | 离线文档导出 (PDF/HTML)、接口排序、权限控制、全局参数配置 |
| 底层规范 | OpenAPI 3.0 | 完全兼容 OpenAPI 3.0 (复用 SpringDoc 注解) |
| 适配版本 | Spring Boot 2.x/3.x | 该版本适配 Spring Boot3.x (Jakarta) |
1.3 数据校验核心
Jakarta Validation + Hibernate Validator
- jakarta.validation-api:提供数据校验的标准 API(包含@Valid、@NotBlank等核心注解),定义校验规范。
- hibernate-validator:是上述规范的主流实现框架,负责实际的校验逻辑执行,是 SpringBoot 中数据校验的必备依赖。
二、快速使用
2.1 引入依赖
<dependencies>
<!-- Spring Web 核心依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 测试依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- Knife4j OpenAPI3 适配SpringBoot3.x(Jakarta) -->
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
<version>4.3.0</version>
</dependency>
<!-- Lombok 简化实体代码 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
</dependencies>2.2 修改配置文件
# 服务器端口(可选,默认8080)
server:
port: 8080
# SpringDoc 核心配置
springdoc:
info:
title: "用户管理系统API" # 接口文档标题
version: "v1.0.0" # 接口文档版本
description: "基于SpringDoc+Knife4j的接口文档示例,集成数据校验功能" # 接口文档描述
# Knife4j 增强配置
knife4j:
enable: true # 开启Knife4j所有增强功能(核心)
setting:
language: zh_cn # 界面默认语言:中文
enable-footer: false # 关闭底部版权信息(可选,美化界面)
enable-request-cache: false # 关闭请求缓存(可选)2.3 编写实体类
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import jakarta.validation.constraints.Min;
import jakarta.validation.constraints.Max;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* 用户信息实体
*/
@Schema(name = "User", description = "用户信息实体,包含用户名、年龄核心字段")
@Data // 生成get/set/toString等方法
@AllArgsConstructor // 全参构造
@NoArgsConstructor // 无参构造
public class User {
@Schema(description = "用户名", required = true, example = "张三")
@NotBlank(message = "用户名不能为空") // 非空校验:字符串不能为null、空字符串、纯空格
private String name;
@Schema(description = "用户年龄", required = false, example = "25", minimum = "1", maximum = "120")
@NotNull(message = "年龄不能为null") // 非null校验
@Min(value = 1, message = "年龄不能小于1岁") // 最小值校验
@Max(value = 120, message = "年龄不能大于120岁") // 最大值校验
private Integer age;
}2.4 编写 Controller 层
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Parameters;
import io.swagger.v3.oas.annotations.enums.ParameterIn;
import io.swagger.v3.oas.annotations.media.Content;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.responses.ApiResponse;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.validation.Valid;
import com.ruangong.springbootdemo2.pojo.User;
import org.springframework.web.bind.annotation.*;
// 1. @Tag:Controller 级别的接口分类
@Tag(name = "用户管理接口", description = "用户新增、查询、修改、删除操作")
@RestController
@RequestMapping("/user")
public class UserController {
// 2. @Operation:方法级别的接口描述
@Operation(
summary = "新增用户", // 接口简短描述
description = "传入用户信息,新增一条用户记录(用户名不能为空)", // 详细描述
// 3. @ApiResponse:定义接口响应结果
responses = {
@ApiResponse(responseCode = "200", description = "新增成功",
content = @Content(schema = @Schema(implementation = String.class))),
@ApiResponse(responseCode = "400", description = "参数校验失败")
}
)
@PostMapping
public String addUser(@Valid @RequestBody User user) {
return "新增用户成功:" + user.getName();
}
// 4. @Parameters/@Parameter:描述路径/请求参数
@Operation(summary = "根据ID查询用户")
@Parameters({
@Parameter(name = "id", description = "用户ID", required = true, in = ParameterIn.PATH, example = "1001")
})
@GetMapping("/{id}")
public User getUserById(@PathVariable Long id) {
User user = new User();
user.setName("张三");
user.setAge(25);
return user;
}
}
2.5 启动项目并访问接口文档
启动成功后,访问以下地址:
- Knife4j 专属中文界面(推荐):http://localhost:8080/doc.html
- 兼容原生 Swagger UI:http://localhost:8080/swagger-ui.html
- OpenAPI 原始数据:http://localhost:8080/v3/api-docs
补充说明:
- doc.html 是 Knife4j 增强界面,支持中文、调试、导出、全局参数
- swagger-ui.html 保留兼容,方便老项目迁移
- v3/api-docs 是标准 OpenAPI 格式,可导入 Postman/YAPI
三、核心注解说明
3.1 接口文档注解(OpenAPI3/SpringDoc)
| 注解 | 作用级别 | 核心作用 |
|---|---|---|
| @Tag | Controller | 接口模块分类,定义模块名称和描述 |
| @Operation | 方法 | 描述单个接口的名称、详细说明 |
| @ApiResponse | 方法 | 定义接口的响应码、响应描述、响应数据类型 |
| @Parameters/@Parameter | 方法 | 描述路径参数 / 请求参数的名称、是否必传、示例值 |
| @Schema | 实体 / 实体字段 | 描述实体 / 字段的含义、是否必传、示例值、范围 |
3.2 数据校验注解(Jakarta Validation)
| 注解 | 作用级别 | 核心作用 |
|---|---|---|
| @Valid | 方法参数 | 触发参数校验,绑定实体的校验规则 |
| @NotBlank | 字符串字段 | 非空校验(禁止 null、空字符串、纯空格) |
| @NotNull | 任意字段 | 非 null 校验(允许空字符串) |
| @NotEmpty | 集合 / 数组 | 集合 / 数组不能为空 |
| @Size | 字符串 / 集合 | 字符串 / 集合长度范围校验 |
| @Min/@Max | 数值字段 | 数值范围校验 |
| 字符串字段 | 邮箱格式校验 |
注意事项
- SpringBoot 版本适配:SpringBoot3.x 需使用knife4j-openapi3-jakarta-spring-boot-starter,SpringBoot2.x 使用非 Jakarta 版本的 Knife4j 依赖。
- 校验注解的使用场景:@NotBlank仅适用于字符串,数值类型使用@NotNull+@Min/@Max组合。
- @Valid 注解的位置:需加在请求体参数前(@RequestBody后),否则无法触发校验。
- Knife4j 依赖的特性:Knife4j 已内置 SpringDoc,无需单独引入 SpringDoc 的依赖,避免版本冲突。
- JDK 版本要求:SpringBoot3.x 最低要求 JDK17,需保证开发环境 JDK 版本符合要求。
以上就是SpringBoot集成Knife4j实现接口文档和参数校验的详细内容,更多关于SpringBoot Knife4j接口文档和参数校验的资料请关注脚本之家其它相关文章!
相关文章
SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法
这篇文章主要介绍了SpringBoot使用Mybatis&Mybatis-plus文件映射配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-05-05
基于OpenCv与JVM实现加载保存图像功能(JAVA 图像处理)
openCv有一个名imread的简单函数,用于从文件中读取图像,本文给大家介绍JAVA 图像处理基于OpenCv与JVM实现加载保存图像功能,感兴趣的朋友一起看看吧2022-01-01
java日期时间格式化@JsonFormat与@DateTimeFormat的使用
本文主要介绍了java日期时间格式化@JsonFormat与@DateTimeFormat的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-08-08
Spring中的@Value和@PropertySource注解详解
这篇文章主要介绍了Spring中的@Value和@PropertySource注解详解,@PropertySource:读取外部配置文件中的key-value保存到运行的环境变量中,本文提供了部分实现代码,需要的朋友可以参考下2023-11-11


最新评论