Spring Boot 整合 Knife4j:打造更优雅的 API 文档
在现代 Web 应用开发中,API 文档的重要性不言而喻。清晰、准确、易用的 API 文档不仅可以方便开发者理解和使用 API,还能提高团队协作效率。Knife4j 是一个基于 Swagger 的增强型 API 文档工具,它可以为 Spring Boot 项目生成美观、易于交互的 API 文档,本文将介绍如何在 Spring Boot 项目中整合 Knife4j,并提供详细的代码示例和最佳实践。
一、为什么选择 Knife4j?
Knife4j 是一个基于 Swagger 的增强型 API 文档框架,相比于 Swagger UI,Knife4j 提供了更强大的功能和更好的用户体验:
- 界面美观: Knife4j 提供了更加美观和现代的界面,使得 API 文档更具吸引力。
- 功能强大: Knife4j支持在线调试、参数示例、离线文档导出等多种实用功能。
- 易于集成: Knife4j 可以轻松地与 Spring Boot 集成。
- 支持多种主题: Knife4j 提供了多种主题,可以自定义 API 文档的风格。
- 更好的可读性: Knife4j 在 API文档的呈现上做了优化,使其更易于阅读和理解。
二、Spring Boot 整合 Knife4j实践
2.1 添加 Knife4j 依赖
<dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</artifactId><version>3.0.3</version>
</dependency><dependency><artifactId>guava</artifactId><groupId>com.google.guava</groupId><version>29.0-jre</version>
</dependency>
注意: 请使用合适的版本号,确保你的 Spring Boot 版本与 Knife4j 和 Swagger 兼容。
2.2 创建 Swagger 配置类
import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
import com.google.common.base.Function;
import com.google.common.base.Optional;
import com.google.common.base.Predicate;
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.documentation.RequestHandler;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;@Configuration
@EnableSwagger2
@EnableKnife4j
@ConditionalOnWebApplication
public class SwaggerConfig implements WebMvcConfigurer {/*** 定义分隔符*/private static final String SPLITOR = ";";@Bean(value = "systemApi")public Docket createSystemRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).groupName("1.系统管理模块").select().apis(basePackage("com.extend.chk.system.controller")).paths(PathSelectors.any()).build();}@Bean(value = "reportApi")public Docket createReportRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).groupName("2.数据可视化模块").select().apis(basePackage("com.extend.chk.report.controller")).paths(PathSelectors.any()).build();}@Bean(value = "warnApi")public Docket createWarnRestApi() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).groupName("3.预警模块").select().apis(basePackage(("com.extend.chk.warn.controller"))).paths(PathSelectors.any()).build();}private ApiInfo apiInfo() {return new ApiInfoBuilder().description("学习管理平台接口文档").version("v1.0.0").title("学习管理平台接口文档").build();}/*** 重写basePackage方法,使能够实现多包访问* @param basePackage* @return*/public static Predicate<RequestHandler> basePackage(final String basePackage) {return input -> declaringClass(input).transform(handlerPackage(basePackage)).or(true);}private static Function<Class<?>, Boolean> handlerPackage(final String basePackage) {return input -> {// 循环判断匹配for (String strPackage : basePackage.split(SPLITOR)) {boolean isMatch = input.getPackage().getName().startsWith(strPackage);if (isMatch) {return true;}}return false;};}private static Optional<? extends Class<?>> declaringClass(RequestHandler input) {return Optional.fromNullable(input.declaringClass());}/*** 配置静态资源* @param registry*/@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/");}
}
@Configuration: 标识这是一个配置类,用来定义 Bean 或其他配置信息。@EnableSwagger2: 启用 Swagger 2 来生成和管理 RESTful API 的文档。@EnableKnife4j:增强 Swagger UI 的展示效果,提供更美观、功能更丰富的 API 文档界面。@ConditionalOnWebApplication:确保上述配置仅在应用程序为 Web 应用时才生效。@Bean: 创建 Docket Bean,用于配置 Swagger 文档信息。apiInfo(): 配置 API的基本信息,例如标题、描述、版本号等。apis(basePackage(("com.extend.chk.warn.controller"))): 指定生成API 文档的 Controller 所在的包。paths(PathSelectors.any()): 定义路径过滤规则,决定哪些 URL 路径应被包含在文档中,这里设置为所有路径。groupName("1.系统管理模块"):为生成的 API 分组指定名称。这可以将不同的 API 接口按功能或模块进行分类展示。
2.3 在类上使用 Swagger 注解
2.3.1 在controller里面使用Swagger 注解
@Api(tags = "项目管理")
@RestController
@RequestMapping("/project/manage")
public class ProjectManageController extends BaseController {@Autowiredprivate ProjectManageService ProjectManageService;@ApiOperation(value = "查询项目列表")@GetMapping("/list")public Result<PageDataInfo<ProjectManage>> queryProjectManageList(ProjectManageReq req) {return success(buildPageDataInfo(ProjectManageService.queryProjectManageList(req)));}@ApiOperation(value = "查询项目详情")@GetMapping("/query")public Result<ProjectManage> queryProjectManageById(Integer workspaceId, Integer projectId) {return success(ProjectManageService.queryProjectManageById(workspaceId, projectId));}@ApiOperation(value = "项目新增")@PostMapping(value = "/add")@Log(title = "项目新增", businessType = BusinessType.INSERT)public Result addProjectManage(@Validated @RequestBody ProjectManage ProjectManage) {ProjectManageService.addProjectManage(ProjectManage);return success();}@ApiOperation(value = "项目修改")@PostMapping(value = "/update")@Log(title = "项目修改", businessType = BusinessType.UPDATE)public Result updateProjectManage(@Validated @RequestBody ProjectManage ProjectManage) {ProjectManageService.updateProjectManage(ProjectManage);return success();}@ApiOperation(value = "项目删除")@ApiImplicitParams({@ApiImplicitParam(name = "workspaceId", value = "空间id", required = true),@ApiImplicitParam(name = "projectId", value = "项目id", required = true)})@PutMapping(value = "/delete")@Log(title = "项目删除", businessType = BusinessType.DELETE)public Result operateProjectManage(Integer workspaceId, Integer projectId) {ProjectManageService.operateProjectManage(workspaceId, projectId);return success();}
}
@Api: 用于描述 Controller 的基本信息,例如分类标签。@ApiOperation: 用于描述 API的基本信息,例如接口名称、描述等。@ApiImplicitParam: 用于描述 API的参数信息,例如参数名称、类型、是否必填等。
2.3.2 在请求类和返回类里面使用Swagger 注解
@ApiModel(value = "ProjectManage对象", description = "项目管理表")
public class ProjectManage extends BaseEntity<ProjectManage> {private static final long serialVersionUID = 1L;@ApiModelProperty("主键id")private Integer id;@ApiModelProperty("项目名称")private String name;@ApiModelProperty("项目负责人id")private String ownerId;@ApiModelProperty("项目成员id")private String memberId;@ApiModelProperty("工作空间id")private Integer workspaceId;@ApiModelProperty("项目状态(1-有效 2-失效)")private String status;@Overridepublic Serializable pkVal() {return this.id;}
}
@ApiModel:用于描述一个模型类(通常是一个 DTO 或实体类),提供该模型的详细信息,如名称、描述等。它使得生成的 API文档能够清晰地展示数据模型的用途和结构。@ApiModelProperty:用于描述模型类中的具体字段,指定字段的名称、类型、是否必填、默认值、备注等信息。这有助于开发者更好地理解每个字段的意义和用法。
2.4 访问 Knife4j 文档
启动 Spring Boot 应用,并在浏览器中访问以下地址,即可查看 Knife4j 生成的 API 文档:
http://localhost:8080/extend/doc.html#/home
三、最佳实践
- 使用 Swagger 注解描述 API: 使用 Swagger 注解详细描述 API 的参数、响应、错误码等,提高文档的可读性。
- 根据API 分组: 使用 Swagger 的分组功能,将 API 分类展示,方便用户查找。
- 添加 API 示例: 在 Swagger注解中添加 API 示例,帮助用户快速了解 API 的使用方法。
- 保持 API 文档与代码同步: 确保 API文档和代码同步更新,避免出现文档与代码不一致的问题。
- 使用清晰的 API 命名: 使用清晰的 API 命名和参数命名,提高 API的可读性。
相关文章:
Spring Boot 整合 Knife4j:打造更优雅的 API 文档
在现代 Web 应用开发中,API 文档的重要性不言而喻。清晰、准确、易用的 API 文档不仅可以方便开发者理解和使用 API,还能提高团队协作效率。Knife4j 是一个基于 Swagger 的增强型 API 文档工具,它可以为 Spring Boot 项目生成美观、易于交互的…...
Kafka 源码分析(一) 日志段
首先我们的 kafka 的消息本身是存储在日志段中的, 对应的源码是下面这段代码: class LogSegment private[log] (val log: FileRecords,val lazyOffsetIndex: LazyIndex[OffsetIndex],val lazyTimeIndex: LazyIndex[TimeIndex],val txnIndex: TransactionIndex,val baseOffset:…...
javaEE初阶————多线程初阶(2)
今天给大家带来第二期啦,保证给大家讲懂嗷; 1,线程状态 NEW安排了工作还未开始行动RUNNABLE可工作的,或者即将工作,正在工作BLOCKED排队等待WAITING排队等待其他事TIMED_WAITING排队等待其他事TERMINATED工作完成了 …...
Redis学习笔记1【数据类型和常用命令】
Redis学习笔记 基础语法 1.数据类型 String: 最基本的类型,可以存储任何数据,例如文本或数字。示例值为 hello world。Hash: 用于存储键值对,适合存储对象或结构体。示例值为 {"name": "Jack", "age": 21}。…...
JavaWeb项目——查询角色列表到页面中——转发模式
一、知识点 1、req.getRequestDispatch与resp.sendRedirect跳转方式的比较 一、实现原理 1、req.getRequestDispatcher: 属于服务器端跳转,在服务器内部将请求转发给另一个资源(如另一个 Servlet 或 JSP 页面)。调用 getReques…...
feign调用跳过HTTPS的SSL证书校验配置详解
一、问题抛出 如果不配置跳过SSL证书校验,当Feign客户端尝试连接到一个使用自签名证书的服务器时,可能会抛出类似以下的异常: javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building faile…...
今天也是记录小程序进展的一天(破晓时8)
嗨嗨嗨朋友们,今天又来记录一下小程序的进展啦!真是太激动了,项目又迈出了重要的一步,231啦!感觉每一步的努力都在积累,功能逐渐完善,离最终上线的目标越来越近了。大家一直支持着这个项目&…...
SQL-leetcode—1084. 销售分析 III
1084. 销售分析 III 表: Product --------------------- | Column Name | Type | --------------------- | product_id | int | | product_name | varchar | | unit_price | int | --------------------- product_id 是该表的主键(具有唯一值的列&…...
Linux C\C++编程-文件位置指针与读写文件数据块
【图书推荐】《Linux C与C一线开发实践(第2版)》_linux c与c一线开发实践pdf-CSDN博客 《Linux C与C一线开发实践(第2版)(Linux技术丛书)》(朱文伟,李建英)【摘要 书评 试读】- 京东图书 Linu…...
Flask简介与安装以及实现一个糕点店的简单流程
目录 1. Flask简介 1.1 Flask的核心特点 1.2 Flask的基本结构 1.3 Flask的常见用法 1.3.1 创建Flask应用 1.3.2 路由和视图函数 1.3.3 动态URL参数 1.3.4 使用模板 1.4 Flask的优点 1.5 总结 2. Flask 环境创建 2.1 创建虚拟环境 2.2 激活虚拟环境 1.3 安装Flask…...
【自动化测试】—— Appium使用保姆教程
目录 一. 连接手机 1. 授权 2. 调试 3. 获取参数 二. 启动APP 1. 启动Appium服务 2. 启动Appium Inspector 3. 配置Appium Inspector 三. 功能说明 1. 主菜单功能 2. 快照视图菜单 3. 元素视图菜单 四. 常见问题 1. appPackage有多个设备时 一. 连接手机 1. 授权 首先将手机的开…...
西门子【Library of General Functions (LGF) for SIMATIC S7-1200 / S7-1500】
文章目录 概要整体架构流程技术名词解释技术细节小结 概要 通用函数库 (LGF) 扩展了 TIA Portal 中用于 PLC 编程的 STEP 7 指令(数学函数、时间、计数器 等)。该库可以不受限制地使用,并包含 FIFO 、搜索功能、矩阵计算、 astro 计…...
IntelliJ IDEA 2023.3 中配置 Spring Boot 项目的热加载
IntelliJ IDEA 2023.3 中配置 Spring Boot 项目的热加载 在 IntelliJ IDEA 2023.3 中配置 Spring Boot 项目的热加载,可以让你在不重启应用的情况下看到代码修改的效果。以下是详细的配置步骤: 添加 spring-boot-devtools 依赖 在 pom.xml 文件中添加 …...
Python----Python高级(正则表达式:语法规则,re库)
一、正则表达式 1.1、概念 正则表达式,又称规则表达式,(Regular Expression,在代码中常简写为regex、 regexp或RE),是一种文本模式,包括普通字符(例如,a 到 z 之间的字母࿰…...
通过Ukey或者OTP动态口令实现windows安全登录
通过 安当SLA(System Login Agent)实现Windows安全登录认证,是一种基于双因素认证(2FA)的解决方案,旨在提升 Windows 系统的登录安全性。以下是详细的实现方法和步骤: 1. 安当SLA的核心功能 安…...
Node.js接收文件分片数据并进行合并处理
前言:上一篇文章讲了如何进行文件的分片:Vue3使用多线程处理文件分片任务,那么本篇文章主要看一下后端怎么接收前端上传来的分片并进行合并处理。 目录: 一、文件结构二、主要依赖1. express2. multer3. fs (文件系统模块)4. pat…...
Lsky-Pro在线图片搭建教程(Docker部署方式)
Lsky Pro+ 是一个使用 PHP 语言,采用 Laravel 框架开发的一款 Web 图片管理程序,中文名:兰空图床。如果你需要一个在线图床程序,那么这个开源项目可以帮助到你,部署流程非常简单。本章教程记录如何部署Lsky-Pro。 一、拉取镜像 docker pull halcyonazure/lsky-pro-docke…...
“深入浅出”系列之算法篇:(2)openCV、openMV、openGL
OpenCV是一个的跨平台计算机视觉库,可以运行在Linux囚、Windows 和Mac OS操作系统上。它轻量级而且高效,由一系列 C函数和少量C类构成,同时也提供了Python 接口,实现了图像处理和计算机视觉方面的很多通用算法。 OpenMV是一个开源,低成本&am…...
AI 新动态:技术突破与应用拓展
目录 一.大语言模型的持续进化 二.AI 在医疗领域的深度应用 疾病诊断 药物研发 三.AI 与自动驾驶的新进展 四.AI 助力环境保护 应对气候变化 能源管理 后记 在当下科技迅猛发展的时代,人工智能(AI)无疑是最具影响力的领域之一。AI 技…...
从CRUD到高级功能:EF Core在.NET Core中全面应用(三)
目录 IQueryable使用 原生SQL使用 实体状态跟踪 全局查询筛选器 并发控制使用 IQueryable使用 在EFCore中IQueryable是一个接口用于表示可查询的集合,它继承自IEnumerable但具有一些关键的区别,使得它在处理数据库查询时非常有用,普通集…...
如何用5步告别Mac菜单栏混乱?Ice帮你打造高效工作空间
如何用5步告别Mac菜单栏混乱?Ice帮你打造高效工作空间 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice 你是否曾因Mac菜单栏上密密麻麻的图标而感到焦虑?随着工作时间的推移&a…...
避坑指南:海康RGBD工业相机Python开发那些事儿——从环境配置到实时显示
避坑指南:海康RGBD工业相机Python开发全流程实战 第一次接触海康RGBD相机时,我被它强大的深度感知能力吸引,但随之而来的是一连串的环境配置和开发难题。记得那个深夜,我对着报错的OpenCV界面发呆,才意识到工业级设备的…...
实战工业分拣:基于快马平台构建自适应openclaw配置系统
最近在做一个工业分拣的自动化项目,正好用到了openclaw机械爪的配置,整个过程挺有意思的,记录下实战经验。 项目背景 这个项目模拟的是工厂流水线上的智能分拣场景。传送带上会随机出现不同颜色和形状的物体,需要机械爪能自动识别…...
软件驱动与应用开发-RK3588实战
一、RK3588设备树关键配置 1.1 I2C与SPI引脚复用配置 dts // 文件: rk3588-smart-monitor.dts / {// I2C2: 使用GPIO4_B1/B2 (功能3)&i2c2 {status = "okay";clock-frequency = <400000>;pinctrl-0 = <&i2c2m0_xfer>;pinctrl-names = "d…...
Postman便携版:Windows免安装API开发工具的新选择
Postman便携版:Windows免安装API开发工具的新选择 【免费下载链接】postman-portable 🚀 Postman portable for Windows 项目地址: https://gitcode.com/gh_mirrors/po/postman-portable 在现代API开发流程中,开发者常常面临工具安装繁…...
DS4Windows终极教程:3分钟让PlayStation手柄完美兼容Windows游戏
DS4Windows终极教程:3分钟让PlayStation手柄完美兼容Windows游戏 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 还在为PC游戏不支持你的PlayStation手柄而烦恼吗?…...
DedeCMS文件包含漏洞深度剖析:为什么一个‘无害’的txt文件能让你getshell?
DedeCMS文件包含漏洞技术解析:从文本文件到系统沦陷的连锁反应 在内容管理系统(CMS)的安全领域,最危险的漏洞往往藏匿于最平凡的功能之中。DedeCMS作为国内广泛使用的开源CMS,其文件包含漏洞(CVE-2023-2928…...
S2-Pro低代码平台集成:为业务人员赋能AI能力
S2-Pro低代码平台集成:为业务人员赋能AI能力 1. 低代码遇上AI:业务创新的新机遇 想象一下,市场部的同事小李需要快速搭建一个智能客服系统来处理客户咨询。传统方式下,他需要找IT部门排期,等待开发团队写代码、调试模…...
Face3D.ai Pro零基础入门:5分钟从照片到3D人脸,小白也能玩转
Face3D.ai Pro零基础入门:5分钟从照片到3D人脸,小白也能玩转 1. 引言:从照片到3D人脸的魔法 想象一下,用手机随手拍一张自拍,5分钟后就能得到一个可以360度旋转的3D人脸模型。这不是科幻电影里的场景,而是…...
领域驱动设计实战:解密DDDSample中Cargo聚合根的黄金法则
领域驱动设计实战:解密DDDSample中Cargo聚合根的黄金法则 【免费下载链接】dddsample-core This is the new home of the original DDD Sample app (previously hosted at sf.net).. 项目地址: https://gitcode.com/gh_mirrors/dd/dddsample-core DDDSample…...
