打造优雅API文档体验

我是洋哥,一个拥有6年经验的程序员,Litchi开源组织发起人

在日常开发中,写接口文档是我们必不可少的,接口是前后端开发联调的桥梁。当然,接口维护是消耗时间成本的,作为后端开发,挑选一款界面友好,使用方便,免维护的接口文档工具是至关重要的

knif4j是什么?

knif4j是为java Mvc框架集成Swagger生成API文档的增强解决方案,其前身是swagger-bootstrap-ui,取名为knif4j是希望它能像一把匕首一样小巧、轻量,并且功能强悍。其底层是对springfox的封装,使用方式 也和springfox一致,只是它对接口文档UI进行了优化。

核心功能

knif4j 具有以下两点核心功能:

  •  文档说明: 根据swagger的规范说明,详细列出了接口文档的说明,包括:接口地址、类型、请求示例、请求参数 响应示例、响应参数、响应码等信息,对该接口的使用情况一目了然。

  •  在线调试: 提供在线接口联调的强大功能,自动解析当前接口参数,同时包含:表单验证,调用参数可返回接口响应内容、headers、响应时间、响应状态码等信息,帮助开发者在线调试。

优势

  • 兼容OpenAPI 2.0和3.0

  • 基础ui组件(自定义文档、动态参数调试、I18n、接口排序、导出等)

  • 基于Springdoc-openapi+OAS3规范的自动注入starter

  • 提供对主流网关组件的统一聚合OpenAPI接口文档的解决方案

  • 基于Springdoc-openapi项目提供OAS3规范的增强扩展

  • 提供基于K8S+Docker的云原生的聚合OpenAPI文档的解决方案

SpringBoot3.2集成knif4j实战

上面说了knif4j的核心功能和优势,光说不练假把式,我们动起来,下面我以litchi-admin项目为例,详细介绍集成过程,项目源代码地址传送门:https://gitee.com/litchi365/litchi-admin (给个star哦!)

1、引入依赖

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

2、配置application.yml

#springdoc相关配置
springdoc:swagger-ui:tags-sorter: alphaoperations-sorter: alphaapi-docs:path: /v3/api-docsenabled: truegroup-configs:- group: 'Litchi-Admin接口'paths-to-match: '/**'packages-to-scan: com.litchi    #按包路径匹配:一般到启动类的包名
#knife4j相关配置 可以不用改
knife4j:enable: true    #开启knife4j,无需添加@EnableKnife4j注解setting:language: zh_cn   #中文swagger-model-name: 实体类   #重命名SwaggerModel名称,默认

3、在启动类中添加@EnableKnife4j

@EnableKnife4j
@SpringBootApplication
public class LitchiAdminApplication {public static void main(String[] args) {SpringApplication.run(LitchiAdminApplication.class, args);}
}

4、配置OpenApi信息

@Configuration
public class OpenApiConfig {@Beanpublic OpenAPI openApi() {return new OpenAPI().info(new Info().title("Litchi-Admin接口文档").version("v1.0").description("此接口文档开发使用,生产环境需配置禁用").contact(new Contact().url("https://www.gengby.com").name("Noah").email("gby_dev@163.com")));}
}

5、在业务接口中使用注解

@Tag(name = "用户管理")
@Validated
@RestController
@RequestMapping("/system/user")
public class UserController {@Resourceprivate IUserService userService;@Resourceprivate EnumConverter enumConverter;@Operation(summary = "用户分页列表")@PostMapping("/page")public Result<PageResp<UserVO>> page(@Validated @RequestBody UserListQuery userListQuery) {return ok(userService.page(userListQuery));}@Operation(summary = "保存用户")@PostMapping("/save")public Result<String> save(@Validated @RequestBody UserSaveCmd userSaveCmd) {return ok(userService.save(userSaveCmd));}@Operation(summary = "修改用户")@PutMapping("/modify")public Result<Boolean> modify(@Validated @RequestBody UserModifyCmd userModifyCmd) {return ok(userService.update(userModifyCmd));}@Operation(summary = "删除用户")@DeleteMapping("/remove")public Result<Boolean> remove(@NotBlank(message = "ID不能为空") @Parameter(description = "用户ID") @RequestParam String id) {return ok(userService.delete(Long.parseLong(id)));}

我们以分页查询参数为例看下代码:

@Data
@Schema(description = "用户查询参数")
@EqualsAndHashCode(callSuper = true)
public class UserListQuery extends PageReq implements Serializable {@Schema(description = "姓名")private String userName;@Schema(description = "手机号")private String phone;@Schema(description = "邮箱")private String email;@Schema(description = "角色ID")private String roleId;}

6、启动项目

访问地址:http://localhost:9999/litchi/doc.html 即刻看到以下页面,你可以看到对应接口的文档描述,也可以在线进行接口调用

图片

图片

图片

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/491333.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握项目管理秘籍!常见方法和工具推荐

项目管理的基本流程是由项目启动、项目规划、项目执行、项目监控和项目收尾组成。在这个过程中&#xff0c;我们可以运用到一些经典的项目管理方法&#xff0c;如瀑布法、敏捷方法、Scrum方法、看板方法、精益方法等。也会用到一些项目管理工具如Zoho Projects、Trello、Quickb…

解决:“出现问题,Outlook 无法设置你的账户”

原文&#xff1a;https://blog.iyatt.com/?p14213 1 问题描述 Office 专业版 2024 预览版 在 Outlook 输入邮箱后无法进一步配置登录信息&#xff08;腾讯企业邮箱 Exchange 登录&#xff09; 2 解决方法 通过控制面板里的邮箱设置可以正常添加登录&#xff0c;而且能…

#FPGA(基础知识)

1.IDE:Quartus II 2.设备&#xff1a;Cyclone II EP2C8Q208C8N 3.实验&#xff1a;正点原子-verilog基础知识 4.时序图&#xff1a; 5.步骤 6.代码&#xff1a;

Spring Security源码学习

Spring Security本质是一个过滤器链 过滤器链本质是责任链设计模型 1. HttpSecurity 【第五篇】深入理解HttpSecurity的设计-腾讯云开发者社区-腾讯云 在以前spring security也是采用xml配置的方式&#xff0c;在<http>标签中配置http请求相关的配置&#xff0c;如用户…

如何做到三天内完成智能直流伺服电机系统开发?

适应EtherCAT/CANopen协议三相伺服电机直流伺服电机直线伺服音圈电机 如何开发高性能直流伺服电机驱动控制器&#xff1f; 需要熟悉高性能单片机&#xff08;至少是ARM或DSP水平的&#xff09;&#xff0c;需要掌握空间磁场矢量控制FOC&#xff0c;需要掌握运动轨迹算法……此…

【NTN 卫星通信】基于NTN和TN的Inter-PLMN海事应用场景

1 场景概述 NTN和TN联合组网的场景&#xff0c;可以有多种应用方式&#xff0c;以下用例描述了同时使用多个卫星PLMN和一个地面5G PLMN的海事场景。 MNO-G是一家成熟的卫星PLMN运营商&#xff0c;运营着几颗GEO卫星。MNO-L是一个相对较新的卫星PLMN运营商&#xff0c;操作LEO卫…

大数据信用查询一般能查到什么?这几点要清楚

大数据信用查询一般能查到什么?当我们谈论大数据信用查询时&#xff0c;我们不只是查看一些干瘪的数据&#xff0c;而是深入探索了一个人的大数据信用特征。这些查询结果为我们提供了一个全面的、多维度的个人信用画像&#xff0c;本文带大家详细了解一下&#xff0c;一起去看…

【无标题】周总结、简单回顾下这周的工作进度

总结 1.完成产品列举场景所有时区功能的改造 2.完成依赖任务的开发 3.完成报表按照格式导出的时间数据改造 2024/2/25 阴 嘶~不冷 “上海申请加入下雪群聊” 上海破天荒的下了雪&#xff0c;毛毛细雪也是雪 我说的&#xff01; 虽然天气不佳&#xff0c;但好在没…

Mysql5.7主从复制搭建

注意不适用Mysql8 Docker搭建Mysql主从复制 docker run -p 3307:3306 --name mysql-master \ -v /usr/local/develop/mysql-master/log:/var/log/mysql \ -v /usr/local/develop/mysql-master/data:/var/lib/mysql \ -v /usr/local/develop/mysql-master/conf:/etc/mysql/con…

代码随想录算法训练营第四一天 | 背包问题

目录 背包问题01背包二维dp数组01背包一维 dp 数组&#xff08;滚动数组&#xff09;分割等和子集 LeetCode 背包问题 01背包 有n件物品和一个最多能背重量为 w 的背包&#xff0c;第i件物品的重量是weight[i]&#xff0c;得到的价值是value[i] 。每件物品只能用一次&#x…

【C++】多态概念(入门)

介绍&#xff1a; 多态的概念&#xff1a;通俗来说&#xff0c;多态就是多种形态&#xff0c;具体点就是去完成某个行为&#xff0c;当不同的对象去完成时会产生出不同的状态。比如扫红包操作&#xff0c;同样是扫码动作&#xff0c;不同的用户扫 得到的不一样的红包&#xff0…

【卷积神经网络中用1*1 卷积有什么作用或者好处呢?】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;深度学习 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; 1*1 卷积有什么作用或者好处呢 作用降维和增加非线性特征组合和交互网络的宽度和深度调整全连接替代增强…