Swagger 是开发中最经常使用的框架之一了,但 Swagger 自己又有不少不完善的地方,好比,在众多的接口中查询某一个接口,又或者是把全部的接口导出成 Word 格式等,都没法在 Swagger 中实现。html
有人可能会问:为何要把接口导成 Word 格式?这种场景还挺常见的,好比须要将接口对外部公司开放时,又或者是开发环境的网络不能对外部开放(如专线,不少医院都拉的是专线),而生产环境的 Swagger 又是关闭状态的时候,这时候只能依赖离线文档来实现接口的调用了,而离线文档最经常使用的格式即是 Word 了。
那么为了解决 Swagger 的这些问题,咱们须要使用一个 Swagger 的加强工具来实现,而这个扩展工具就是咱们今天要重点介绍的 Knife4j,那 Knife4j 长得是什么样呢?咱们一块儿来看,以下图所示:git
从这个主页能够看出,Knife4j 会将 Swagger 中设置的摘要信息(Docket)显示在欢迎页,Docket 的设置能够看我以前的文章,而且 Knife4j 还很贴心的提供了一个统计全部接口的功能,在欢迎页的最下方咱们能够很清楚的看到当前 POST 接口的数量,以及 GET 的接口的数量。github
PS:Knife4j 支持中文和英文两种语言展现,对于国内的小伙伴来讲,可读性很是的高(由于都是中文的嘛)。
我以为 Knife4j 最实用的一个功能就是“接口搜索”了,经过这个功能咱们能够很是方便的找到咱们须要的接口,以下图所示:spring
Knife4j 提供了 4 种格式的离线文档下载:Markdown、Html、Word、OpenAPI 等方式,以下图所示:网络
能够经过 Knife4j 过滤某一类型的接口,好比过滤 GET 或者 POST 接口,以下图所示:框架
若是有公共的请求参数,咱们能够经过 Knife4j 轻松搞定,以下图所示:spring-boot
使用 Knife4j 能够更友好的实现接口调试,由于在使用 Knife4j 时,它会将必传的参数以红色边框的方式显示,这样咱们就直观的区分开必填参数和非必填参数了,以下图所示:工具
从上面的内容能够看出 knife4j 的功能是很强大的,但令我更惊喜的是它的配置异常的简单,咱们只需在已经成功配置了 Swagger 的项目中(Swagger 配置可参考个人上一篇文章),添加 Knife4j 的依赖便可,配置信息以下:测试
<!-- https://mvnrepository.com/artifact/com.github.xiaoymin/knife4j-spring-boot-starter --> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>knife4j-spring-boot-starter</artifactId> <version>3.0.2</version> </dependency>
通过以上简单的依赖添加以后,无需配置任何内容,咱们就能够成功的使用 Knife4j 了。spa
咱们能够经过 http://localhost:8080/doc.html 访问 Knife4j 的主页,以下图所示:
Swagger 做为很是欢迎的框架同时也存在着一些功能“缺陷”,那么为了弥补 Swagger 的不足,咱们引入了 Knife4j 框架,使用 Knife4j 咱们能够很方便的实现:接口搜索、离线文档下载、全局参数设置、接口过滤和更加友好的接口测试等功能。然而和它的功能一样使人惊讶的是它的配置,在使用 Knife4j 时,咱们只须要在项目中添加它的引用,以后无需任何多余的操做就能够直接使用 Knife4j 了,简直完美,因此你不来试一试吗?
关注公号:「Java中文社群」查看视频版介绍及更多Swagger内容~