Swagger增强神器:Knife4j!用它轻松实现接口搜索、Word下载、接口过滤...

开发 前端
wagger 是开发中最常用的框架之一了,但 Swagger 本身又有很多不完善的地方,比如,在众多的接口中查询某一个接口,又或者是把所有的接口导出成 Word 格式等,都无法在 Swagger 中实现。

[[388819]]

wagger 是开发中最常用的框架之一了,但 Swagger 本身又有很多不完善的地方,比如,在众多的接口中查询某一个接口,又或者是把所有的接口导出成 Word 格式等,都无法在 Swagger 中实现。

有人可能会问:为什么要把接口导成 Word 格式?这种场景还挺常见的,比如需要将接口对外部公司开放时,又或者是开发环境的网络不能对外部开放(如专线,很多医院都拉的是专线),而生产环境的 Swagger 又是关闭状态的时候,这时候只能依赖离线文档来实现接口的调用了,而离线文档最常用的格式便是 Word 了。

那么为了解决 Swagger 的这些问题,我们需要使用一个 Swagger 的增强工具来实现,而这个扩展工具就是我们今天要重点介绍的 Knife4j,那 Knife4j 长得是什么样呢?我们一起来看,如下图所示:

图片从这个主页可以看出,Knife4j 会将 Swagger 中设置的摘要信息(Docket)显示在欢迎页,Docket 的设置可以看我之前的文章,并且 Knife4j 还很贴心的提供了一个统计所有接口的功能,在欢迎页的最下方我们可以很清楚的看到当前 POST 接口的数量,以及 GET 的接口的数量。

PS:Knife4j 支持中文和英文两种语言展示,对于国内的小伙伴来说,可读性非常的高(因为都是中文的嘛)。

Knife4j 功能介绍

1.搜索功能

我觉得 Knife4j 最实用的一个功能就是“接口搜索”了,通过这个功能我们可以非常方便的找到我们需要的接口,如下图所示:

2.离线文档下载

Knife4j 提供了 4 种格式的离线文档下载:Markdown、Html、Word、OpenAPI 等方式,如下图所示:

3.接口过滤

可以通过 Knife4j 过滤某一类型的接口,比如过滤 GET 或者 POST 接口,如下图所示:

4.全局参数设置

如果有公共的请求参数,我们可以通过 Knife4j 轻松搞定,如下图所示:

5.更友好的接口调试

使用 Knife4j 可以更友好的实现接口调试,因为在使用 Knife4j 时,它会将必传的参数以红色边框的方式显示,这样我们就直观的区分开必填参数和非必填参数了,如下图所示:

Knife4j 使用配置

从上面的内容可以看出 knife4j 的功能是很强大的,但令我更惊喜的是它的配置异常的简单,我们只需在已经成功配置了 Swagger 的项目中,添加 Knife4j 的依赖即可,配置信息如下:

  1. <!-- https://mvnrepository.com/artifact/com.github.xiaoymin/knife4j-spring-boot-starter --> 
  2. <dependency> 
  3.     <groupId>com.github.xiaoymin</groupId> 
  4.     <artifactId>knife4j-spring-boot-starter</artifactId> 
  5.     <version>3.0.2</version> 
  6. </dependency> 

 

经过以上简单的依赖添加之后,无需配置任何内容,我们就可以成功的使用 Knife4j 了。

访问 Knife4j

我们可以通过 http://localhost:8080/doc.html 访问 Knife4j 的主页,如下图所示:

总结

Swagger 作为非常欢迎的框架同时也存在着一些功能“缺陷”,那么为了弥补 Swagger 的不足,我们引入了 Knife4j 框架,使用 Knife4j 我们可以很方便的实现:接口搜索、离线文档下载、全局参数设置、接口过滤和更加友好的接口测试等功能。然而和它的功能同样令人惊讶的是它的配置,在使用 Knife4j 时,我们只需要在项目中添加它的引用,之后无需任何多余的操作就可以直接使用 Knife4j 了,简直完美,所以你不来试一试吗?

 

责任编辑:武晓燕 来源: Java中文社群
相关推荐

2022-01-26 20:01:24

管理工具knife4j

2022-01-28 14:39:59

Swaggerpostmanmock

2024-06-12 00:00:01

Java函数式接口

2024-08-28 08:42:21

API接口限流

2024-09-10 08:15:33

Asp项目API

2020-08-23 12:27:39

测试接口技巧

2024-06-03 10:53:18

LLMRAGGraphRAG

2023-07-24 08:00:56

客户端访问指定

2019-02-25 10:18:43

工具代码测试

2023-03-08 08:48:50

Swag工具

2023-03-06 08:53:13

2009-07-10 14:26:28

实现SwingActionListe

2021-03-23 09:06:34

下载神器文件下载插件

2023-08-09 08:37:44

2017-07-20 17:05:04

JavaScriptswagger-decSwagger

2021-05-14 07:45:07

Sentinel 接口限流

2010-02-06 18:04:21

Android 接口

2009-08-31 15:55:17

C#实现Strateg

2010-03-22 13:15:07

Python支付接口

2010-03-04 09:20:48

Android接口
点赞
收藏

51CTO技术栈公众号