当前位置: 首页 > news >正文

你还不会写API文档吗

一:API没人不了解吧


1.API浅谈

什么是API不会有人不知道吧?在步入软件研发之路之后,无论你是前端还是后端,还是测试,不会有人不知道什么是API吧!
三次握手四次挥手,这是什么?这就是API的本质。
当然,我们的日常开发途中,不会有人问你这个问题的,我们一般会说,我需要一个接口,这个接口想要实现什么功能。是的,这个接口就是API。

2.API普通规范

在协同开发中,我们需要有一套规范,才能够让前后端愉快的共同开发。因此,我们需要有一套接口规范,无论是内部严格的使用restful接口规范,还是对接外部某些三方会统一输出POST接口,这些都是团队对内部/外部约定俗成的规范。
此处,我不对以上两种接口输出规范做评价,各有各的规矩,各有各的好处,仁者见仁,智者见智。

3.开发遇到的api文档

基于最近有需求,需要对一个功能模块进行大改版,这个模块之前不是本人负责的,当需求确定之后,我对这个模块的接口进行了梳理(虽然有api管理工具),以便于确定需要对哪些接口进行改造或者新增某些接口。然而,在梳理过程中,我看到了这些问题。。。

二:这些问题怎么还会存在?


对了,先提一句,我们用的是apipost软件进行接口管理。

1.接口入参没有进行注释说明

这里有四五个入参没有进行说明?谁知道是什么参数呢?要不要传?
image.png

2.重复属性的入参字段没有说明作用

比如下列两个字段goods_class 和good_class_group,两个字端明显一致,但是一个是字符串,一个是数组,可能想实现一个商品可以在多个分类下的需求,但是,如果这个字段是优化过的需求,那么,两个字段中必定是有一个是即将废弃的字段,此处,是需要注明TODO的。
而且,在后端的代码逻辑中,也没有找到这两个字段的TODO注释,这就对其他协同开发者形成了威慑,不知道是为什么,但是不敢动。

image.png
image.png

3.后端没有处理的入参

这个现象和第一个现象结合,简直是一个大💣,如下字段inventory,自我理解,这个字段指的是库存,在查询数据库文档之后,没错,就是这个意思,但是,后端并没有处理这个参数。

你以为问题就结束了?

不,问题还有…

这个神奇的字段,在数据库文档中存在,但是在代码model (用的是mongo数据库) 中不存在…

经过查询代码提交记录,找到相关人员,询问为什么?原来是,库存需求被其他方案替换了,不再数据库中存储了,只是,稍稍忘记了修改文档。。。

image.png
image.pngimage.png

4.后端无效的查询字段

熟悉webstorm的伙伴大家都知道这个灰色字体是什么意思吧,上下文中未引用的声明。
那么,这个api中的查询条件order_id就是无效的,很明显,如果前端传入了order_id,则,返回的数据一定是错的,因为,没有进行数据匹配。

image.png

5.接口时间参数处理

在我们日常的开发途中,经常会有这么一种情况,需要查询某个时间段的数据,那么如下所示,有一个问题
23:59:59 < time < 00:00:00,time这一秒,数据没有被查询到。
这是一个很小的问题,但是也很容易被忽视。
其实只需要一个小小的修改,就可以避免这个问题,将 l t e 改为 lte改为 lte改为lt,然后将$lt的时间修改为第二天的00:00:00即可。

原代码:

        Object.assign(whereStr, {
          createdAt: {
            $gte: new Date(moment(payment_time).format('YYYY-MM-DD 00:00:00')),
            $lte: new Date(moment(payment_time).format('YYYY-MM-DD 23:59:59'))
          }
        })

修改后的代码:

        Object.assign(whereStr, {
          createdAt: {
            $gte: new Date(moment(payment_time).format('YYYY-MM-DD 00:00:00')),
            $lt: new Date(moment(new Date(payment_time).getTime() + 24 * 60 * 60 * 1000).format('YYYY-MM-DD 00:00:00'))
          }
        })

image.png

三:怎么写好api文档

其实在不同的公司,api文档的输出方式是不同的,由于本人所在公司使用的是apipost软件进行api管理。那么这篇文章中就先来谈谈如何使用apipost进行api文档管理。

1. 动态路由

使用标准的动态路由的写法,利于其他协作者共同开发,以及展示你参数的取值来源。善用路径变量,事半功倍。

image.png

2.学会"锁定"API

apipost有一个锁定api的功能,在锁定之后,其他协作着能修改其中的参数,但是只能在自己本地修改,无法保存,这样就避免其他协作者误操作,将api修改的惨不忍睹。

api左侧还有一个api状态的选项,可以在api开发完毕之后修改为"已完成",约定为前端可调用。

image.png

3.提取字段和描述

这个功能其实就是记录入/出参描述,但是这个描述,会自动获取“参数描述库”中的第一个描述,如果一个字段在不同的接口中代表不同的含义,就需要在提取时,进行检查。

image.png

四:API文档延伸

不同的公司,使用的是不同的API管理工具,每个工具都有其实用的点,善于发现,善于使用。
当然,有更多的和其他公司合作的机会时,一个api接口的word文档,就很有必要了。那么,一个合格的接口word文档是怎么样的?可以查看以下文章!

https://www.yuque.com/morange/morange/pq7pz1

寄语

工欲善其事,必先利其器!

相关文章:

  • Mach-O详解(一) - 破题
  • 今天来说说Java开发中常用的框架有哪些?
  • Three.js对模型进行多区域染色
  • 超全面试汇总——Hadoop(二)
  • Android辅助功能(Accessibility)简介
  • SSM网约车管理系统毕业设计-附源码051630
  • (9)YOLO-Pose:使用对象关键点相似性损失增强多人姿态估计的增强版YOLO
  • 第11章Linux实操篇-Linux磁盘分区、挂载
  • Kotlin协程:Flow的融合、Channel容量、溢出策略
  • android毕业设计选题基于Uniapp+SSM实现的互联网云数据环境下的供销APP购物商城电商
  • 超级详细的mysql安装和配置教程
  • 超级详细的Maven使用教程
  • 界面组件DevExpress WPF Data Grid哪些功能还能增强?一起来看
  • 爱上开源之golang入门至实战第四章函数(Func)(十)
  • SQL Dblink SQL
  • C++入门教程(10):for 语句
  • CSS 三角实现
  • Flannel解读
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • JSONP原理
  • php面试题 汇集2
  • React-redux的原理以及使用
  • scala基础语法(二)
  • Web标准制定过程
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 基于Android乐音识别(2)
  • 前端学习笔记之原型——一张图说明`prototype`和`__proto__`的区别
  • 数组的操作
  • 线上 python http server profile 实践
  • 正则表达式小结
  • 转载:[译] 内容加速黑科技趣谈
  • 2017年360最后一道编程题
  • 交换综合实验一
  • 教程:使用iPhone相机和openCV来完成3D重建(第一部分) ...
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • #经典论文 异质山坡的物理模型 2 有效导水率
  • $(selector).each()和$.each()的区别
  • (12)Linux 常见的三种进程状态
  • (delphi11最新学习资料) Object Pascal 学习笔记---第7章第3节(封装和窗体)
  • (Git) gitignore基础使用
  • (MATLAB)第五章-矩阵运算
  • (pojstep1.1.2)2654(直叙式模拟)
  • (附源码)springboot炼糖厂地磅全自动控制系统 毕业设计 341357
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (六)c52学习之旅-独立按键
  • (三)elasticsearch 源码之启动流程分析
  • (实战)静默dbca安装创建数据库 --参数说明+举例
  • (一)C语言之入门:使用Visual Studio Community 2022运行hello world
  • (转)Android学习笔记 --- android任务栈和启动模式
  • (转)C#开发微信门户及应用(1)--开始使用微信接口
  • .NET CLR基本术语
  • .NET core 自定义过滤器 Filter 实现webapi RestFul 统一接口数据返回格式
  • .NET Core、DNX、DNU、DNVM、MVC6学习资料
  • .NET Framework 服务实现监控可观测性最佳实践
  • .NET I/O 学习笔记:对文件和目录进行解压缩操作