接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

liam
• 阅读 561

可能现在的小程序员听到以前还有人用过 word 来做接口文档,会惊讶得不行,但在前后端分离推行的早期,确实没有那么多趁手好用的接口文档工具。

互联网发展到现在,接口文档也经历了从简单的word到markdown,到swagger,到Apifox 等逐步进化的方式,变得越来越美观,越来越规范,也支持越来越多的功能辅助调试。

接下来给大家盘点一下这些年接口文档的进化历程。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

一、接口文档的幼年体:word

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

一开始是前后端分离,后端得告知前端接口的各项信息,方便前端调用。 那需要提供的信息也就那些,就用 word 写吧,于是就有了这样的接口文档:

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

问题似乎解决了,但项目嘛,是不停修改和迭代的,这样会导致:

这份接口文档是随着项目进行频繁改动的。 每更新一次,就需要给项目成员分发一次新的接口文档

于是:
A.每改动一次就要新建一份,复制给项目组里很多人,这样一个文档复制来复制去,项目组里这么多人,谁都不知道拿到的是不是全新版本 ;

B.改一点就要生成一个新文档,于是文件夹里的接口文档可能就是这种形式:

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

是谁哭了我不说。

这些痛点促成了接口文档的第一次进化: 从word版的接口文档进化成网页版的接口文档。

二、接口文档的成长体:Markdown

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

网页版的接口文档多完美,只需要分发一个链接给项目成员保存起来。

这样,如果后端修改了接口,直接在网页里修改,就保证大家看到的都是最新版本的,也不用每次一有改动就发一份新文档给大家。

这样一个由markdown生成的静态的html 页面,一个接口的关键要素全都有 接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

问题解决!

但—— 新的问题又产生了。

这个接口文档是能用了,但又没那么好用,比如说:

1.写接口挺麻烦的,完全纯手工写,没有任何辅助工具,非常花时间

2.接口写完还不能立刻看到生成的接口文档的效果,写错了还要重新回去调

3.没有接口规范约束,接口文档怎么写,哪些参数要写,哪些不写,呈现形式怎么样全凭开发人员本身的业务水准。

于是就开始了新的一轮的进化——有人开发了一个工具,专门就用来写接口文档。

三、接口文档的完全体:swagger

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

怎么写? 在swagger editor里编写符合swagger 语法的接口文档,来生成接口文档,编写完的接口文档可以在swagger editor的右侧实时预览:

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

于是,进化到这个完全体阶段的接口文档工具已经实现了如下功能:

1.网页版接口文档支持的在线查看功能,当然他也有,而且这个接口文档的样式是符合open api3.0规范的,如果写得不符合语法,swagger editor 还会报错来纠正你。

一个标准的接口所应具备的信息:接口方法、接口路径、请求和响应参数,都能按照固定的格式呈现出来。 接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

2.它还具备了初步、简单的调试功能,就是接口请求参数为空格,填写参数、发送请求,就能返回响应参数

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

好像已经够用了对不对?

但——等等,这些如果是开发自己一个人用还行,但如果要运用到项目里,那么多的接口文档,蛮难管理的,swagger editor 不提供项目层级的归档和管理,维护也麻烦。

而且,到目前为止,也没有逃脱接口文档要靠手写生成的命运,还要去学swagger 注解,这样一来,学习成本有了,工作效率也提高不上去。

生成的接口文档,前端需要使用接口信息来调试页面,测试会用它来验证接口。 但目前接口文档的功能,对前端和测试的工作支持得还不够呀~

好像....还可以更完美??!

有痛点就会有解决方案,于是接口文档开始了新一轮的进化之路,进入究极进化形态的接口文档工具是——

四、接口文档的究极进化形态:Apifox

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

想要团队协作?安排。
想要不用写代码就能生成接口文档?可以。
想要直接在接口文档上调试接口?支持。
接口还没上生产环境、但想要模拟数据可以调试前端页面?支持。
想要直接用接口数据来做自动化测试?安排。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

于是一个究极进化形态的接口文档工具就诞生了。

首先是在已经存在的接口文档功能上做优化:

A.可视化的接口设计页面,不用写swagger 注解 ,填完参数保存就是一份接口文档。

只要你懂接口的知识就能上手写,四舍五入这学习成本就是零。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

B.一键导出接口文档,支持只分享部分接口文档,设置过期时间,设置密码

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

C.接口文档实时更新 一旦接口文档发生变更,数据会实时同步到参与项目的所有成员

其次是给前端和测试疯狂加外挂:

A.接口文档页面支持在线调试
接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

分享出去的接口文档页面支持简单的基础调试功能,如果你如要更加强大的调试辅助,则可以使用Apifox客户端。

客户端的调试功能对提取变量、断言、连接数据库等功能都做了可视化封装,不用写脚本,如果 有复杂的调试需求,仍旧支持脚本调试功能

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

B.支持生成代码
支持的代码种类也蛮多的,包括前后端常用的各种语言和框架,总共有130多种,javascript和swift,java等等生成的前端代码复制就能用。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

不仅支持生成接口请求代码,也支持生成数据模型代码,整个项目的代码,可以按需生成,然后自己再去做调整,这样需要写的代码量就大大减少了。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

F.提供mock环境
在接口未上线时也能模拟接口请求,构造出高度真实的业务数据供前端测试页面,后端、测试进行接口的调试和测试

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

可以复制链接到浏览器查看生成的在线文档:

https://www.apifox.cn/apidoc/shared-cbb5c14c-0faa-4b4d-9f6e-7027cd57c702/api-21636796

最后是将接口的一整条工作链整合到它这一个工具里:

A.支持项目层次的协作

每个接口归属于不同的模块,分属到不同的目录之中。 后端、前端、测试可以使用同一套接口数据源,也就是说接口创建出来之后,后端在上面维护,前端使用他做接口mock,测试用它做接口自动化,数据变更实时同步到各端,不需要切换多个软件。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

B.支持导入postman,swagger等多达20多种格式的接口数据,零成本实现项目迁移

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

C.支持导出swagger,html,word 格式的接口文档,也不绑架用户,你想迁移到其他系统也大大方方成全你。

接口文档进化图鉴,有些古早接口文档工具,你可能都没用过

这样一套组合拳打下来,基本上你能想到的接口文档该有的功能它都有了。

官网地址:www.apifox.cn

总结

因此,总结下来,接口文档一直以来都在不断地进化,战斗力也越来越强,也给研发人员提供了越来越到位的帮助,让他们能够少写不必要的代码,少做重复的工作。 大家可以根据自己项目的实际情况,选用合适的工具。

点赞
收藏
评论区
推荐文章
liam liam
2年前
高效进行接口测试,简单易懂!
前言日常测试过程中,常常需要多种工具来接力完成自己的接口测试任务。比如说,使用swagger查看接口文档,使用mock编造接口数据对前端页面做测试使用postman测试后端接口,用Jmeter来做接口自动化测试/性能测试。那有没有一款软件可以完美集成以上所有的功能?笔者发现一款叫Apifox的软件,一款完成能完成以上几乎所有软件的功能。官方给出Apifox(
liam liam
2年前
5分钟打造好用好看API文档
5分钟打造好用好看API文档🤔️你是否遇到过这样的场景?对接第三方开放平台文档的时候,左手刷着接口文档看API,右手操作着接口调试工具🧱写完接口想交付或提供API文档给第三方使用,又觉得文档展示体验一般?很鸡肋?
Easter79 Easter79
3年前
swagger接口文档生成工具
文章首推支付宝接口对接(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fmp.weixin.qq.com%2Fs%3F__biz%3DMzg3OTE1NTA2OA%3D%3D%26mid%3D2247485180%26idx%3D1%26sn%3D403efde
liam liam
2年前
程序员的摸鱼加速器!
最近趁摸鱼时间体验了一款神器,堪称后端前端们的摸鱼加速器,测试们的寿命催化剂。那就是:Apifox。中国自主研发的集文档、接口调试、Mock、接口自动化测试一体的协作平台。一套系统、一份数据,可解决多个系统之间的数据同步问题。定义好接口文档,则接口调试、数据Mock、接口测试就可以直接使用,无需再次定义;接口文档和接口开发调试也可以同一个工具,接口调试完成后
Stella981 Stella981
3年前
Hi,给他介绍一款markdown的帮助文档生成器
     当今大多数的团队都实现了前、后端分支。前端与后端的沟通都是通过接口来实现的(一般情况下都是webapi接口)。这种情况你肯定需要一个接口查询的帮助文档,这个当然用swagger都可以实现。但做为前端开发的我们是否也应该考虑把自己写的组件以帮助文档的方式公开都团队其他人员使用。就像iview,easyui等UI组件都有自己的帮助文档。今天我们都介绍
Stella981 Stella981
3年前
Spring Cloud Gateway 接口文档聚合实现
​在微服务架构下,通常每个微服务都会使用Swagger来管理我们的接口文档,当微服务越来越多,接口查找管理无形中要浪费我们不少时间,毕竟懒是程序员的美德。​由于swagger2暂时不支持webflux走了很多坑,完成这个效果感谢@dreamlu@世言。文档聚合效果通过访问网关的host:port/swaggerui.
Stella981 Stella981
3年前
SpringBoot整合Swagger3生成接口文档
  前后端分离的项目,接口文档的存在十分重要。与手动编写接口文档不同,swagger是一个自动生成接口文档的工具,在需求不断变更的环境下,手动编写文档的效率实在太低。与新版的swagger3相比swagger2配置更少,使用更加方便。一、pom文件中引入Swagger3依赖<dependency
Easter79 Easter79
3年前
SpringBoot整合Swagger3生成接口文档
  前后端分离的项目,接口文档的存在十分重要。与手动编写接口文档不同,swagger是一个自动生成接口文档的工具,在需求不断变更的环境下,手动编写文档的效率实在太低。与新版的swagger3相比swagger2配置更少,使用更加方便。一、pom文件中引入Swagger3依赖<dependency
liam liam
2年前
为什么越来越多的开发者放弃使用Postman,而选择Apifox
一、API调试常用解决方案1、PostmanSwaggerMockJMeter作为一个后端开发,我做的大部分项目一般都是基于Swagger来管理API文档,基于Postman来做接口调试,基于JMeter来做接口性能测试,基于RAP等工具MockAPI数据。\2、存在的问题(1)多系统数据不互通API设计者、前
API 小达人 API 小达人
1年前
「实用技巧」后端如何使用 Eolink Apikit 快速调试接口?
程序员最讨厌的两件事:1.写文档;别人不写文档。写文档、维护文档比较麻烦,而且费时,还会经常出现API更新了,但文档还是旧的,各种同步不一致的情况,从而耽搁彼此的时间,大多数开发人员不愿意写API文档。EolinkApikit为后端工程师提供API文档的创建与自动化生成、快速接口调试、以及API文档版本管理功能,协助后端工程师快速编写文档,调试接口,以及支持版本控制恢复历史记录。通过一套系统、一份数据,解决多个系统之间的数据同步问题。只要定义好接口文档,接口调试、数据Mock、接口测试就可以直接使用,无需再次定义。接口文档和接口开发调试使用同一个工具,接口调试完成后即可保证和接口文档定义完全一致。高效、及时、准确!