如何更好管理 Api 接口(续)

本文涉及的产品
云解析DNS-重点域名监控,免费拨测 20万次(价值200元)
简介: 哈喽,我是树酱。去年中旬的时候写过一篇关于如何更好管理 Api 接口。最近有朋友问我,我们都是根据Swagger文档,然后通过“阅读”swagger文档中每个微服务包含的CRUD(增刪查改)等API,再通过“手动”撸出各种service文件,以此达到封装的结果。但是这样会暴露一些问题,如下👇

微信截图_20220514232654.png


哈喽,我是树酱。去年中旬的时候写过一篇关于如何更好管理 Api 接口。最近有朋友问我,我们都是根据Swagger文档,然后通过“阅读”swagger文档中每个微服务包含的CRUD(增刪查改)等API,再通过“手动”撸出各种service文件,以此达到封装的结果。但是这样会暴露一些问题,如下👇


  • 如果接口发生变更,比如接口从v1迁移到v2版本,那需要进行大量的改造
  • 每增加一个项目,我都是需要封装一套service,重复造轮子不亦乐乎?
  • 团队加入新成员,编写重复的接口封装等


那有什么办法可以解决上述的问题? 方法是有的,本质上通过程序自动化去生成各种service文件,解放双手。那具体怎么做呢?我们可以通过解析swagger接口文档的结构


1.什么是 Swagger / OpenAPI ?


在聊解析文档之前,我们首先需要先了解一下 OpenAPI  👇


微信截图_20220514232710.png


OpenAPI规范,也称作OAS,是一种API文档标准


通过 OpenAPI 规范来定义您的 API,您就可以用文档生成工具来展示您的 API,甚至可以使用代码生成工具来自动生成各种编程语言的服务器端和客户端的代码。


👧 啊乐同学:那openAPI与swagger之间有是什么关系?


OpenAPI 始于 Swagger 规范,Swagger 规范已于2015 年捐赠给 Linux 基金会后改名为 OpenAPI,并定义最新的规范为 OpenAPI 3.0

本质上你可以理解为前者是规范,后者则是实现规范的工具 👇


  • OpenAPI = 规范
  • Swagger = 实现规范的工具


👦 啊乐同学:那么一个通过OpenAPI规范实现的对象是什么样子的呢?


具体主要包括以下这些字段信息(指的是OpenAPI 3.0)


微信截图_20220514232726.png


如果你想实时预览OpenAPI在线编辑的效果,可以尝试使用 Swagger Editor


微信截图_20220514232758.png


👦 啊呆同学:我看有两种规范,OAS2与OAS3,这两种有什么区别呢?


OAS2是Swagger2的简称,上文提到,自 Swagger 规范捐献给linux之后,将Swagger规范重命名为OpenAPI规范,就是我们提到的OAS3。下图是两者的区分👇


微信截图_20220514232811.png


推荐阅读:


2.如何解析 Swagger / OpenAPI ?


梳理完OpenAPI规范结构,接下来我们就需要通过解析OpenApi文档结构来生成我们的service文件


我在社区找到目前的两种解决方式 👇


2.1 @umijs/plugin-openapi插件


umijs封装了一个openapi插件,通过输入一个 openapi 的规范文件,就可以完成自动化创建service。


这个规范文件我们在通过swagger-ui的界面中可以获取


微信截图_20220514232833.png


然后把这个复制swagger的url到openapi的配置中(schemaPath参数),可以参考下图👇


微信截图_20220514232850.png


然后执行命令行就可以自动生成以下目录结构serves


微信截图_20220514232901.png


这里以宠物商店的DEMO API 文档为例,看下生成的接口封装成什么样子


微信截图_20220514232918.png


同时在serves中我们也会生成 typings.d.ts 文件,包含了openapi中的定义

目前该工具的劣势在于,重度绑定了umi且对中文支持不友好。如果你觉得不适合内部的技术栈,可以参考该工具的实现思路,然后在它的基础上自己造轮子


2.2 本地化工具生成


OpenApi社区开源了OpenApi Generator,我们可以通过 OpenAPI Generator,通过提供OpenAPI 规范(上文提到的OAS2和OAS3)来自动生成 API 客户端库、文档及配置。


比如我们前端依赖axios作为请求库,那么我们可以通过指定类型来生成ts+axios的请求相关的代码


具体使用请查阅 🔗 github - openapi-generator


如果你是前端并且对java并不熟悉的童鞋,直接使用会收到技术栈限制,因为它提供的是一个JAR包,虽然也有提供cli工具,但是只支持yml格式解析


那么有没有更编辑的方式,可以不依赖环境去使用呢?


这里提供一个工具,方便你直接使用: Apifox


Apifox不仅支持mock功能和接口调试,我发现还有个代码生成功能,代码生成引擎使用的也就是我们提到的openapi-generator,可以根据接口/模型定义,自动生成各种语言/框架(如 TypeScript、Java、Go、Swift 等130 种语言及框架)的业务代码,比如接口请求代码


微信截图_20220514232932.png


上图是Apifox的生成代码的界面,这里以TypeScript语言+axios请求库为例,我们还可以选择我们导出的代码包含的内容,比如只需要仅接口代码或仅模型等


3.最后


如果你有更好的实现方式,也可以在评论区留言,也可以加我微信,我们一起喝茶🍵 讨论



相关文章
|
2月前
|
缓存 监控 前端开发
顺企网 API 开发实战:搜索 / 详情接口从 0 到 1 落地(附 Elasticsearch 优化 + 错误速查)
企业API开发常陷参数、缓存、错误处理三大坑?本指南拆解顺企网双接口全流程,涵盖搜索优化、签名验证、限流应对,附可复用代码与错误速查表,助你2小时高效搞定开发,提升响应速度与稳定性。
|
2月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
2月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
3月前
|
JSON 前端开发 API
如何调用体育数据足篮接口API
本文介绍如何调用体育数据API:首先选择可靠服务商并注册获取密钥,接着阅读文档了解基础URL、端点、参数及请求头,然后使用Python等语言发送请求、解析JSON数据,最后将数据应用于Web、App或分析场景,同时注意密钥安全、速率限制与错误处理。
433 152
|
2月前
|
人工智能 自然语言处理 测试技术
Apipost智能搜索:只需用业务语言描述需求,就能精准定位目标接口,API 搜索的下一代形态!
在大型项目中,API 数量庞大、命名不一,导致“找接口”耗时费力。传统工具依赖关键词搜索,难以应对语义模糊或命名不规范的场景。Apipost AI 智能搜索功能,支持自然语言查询,如“和用户登录有关的接口”,系统可理解语义并精准匹配目标接口。无论是新人上手、模糊查找还是批量定位,都能大幅提升检索效率,降低协作成本。从关键词到语义理解,智能搜索让开发者少花时间找接口,多专注核心开发,真正实现高效协作。
|
2月前
|
存储 缓存 算法
亚马逊 SP-API 深度开发:关键字搜索接口的购物意图挖掘与合规竞品分析
本文深度解析亚马逊SP-API关键字搜索接口的合规调用与商业应用,涵盖意图识别、竞品分析、性能优化全链路。通过COSMO算法解析用户购物意图,结合合规技术方案提升关键词转化率,助力卖家实现数据驱动决策,安全高效优化运营。
|
3月前
|
人工智能 运维 监控
阿里云 API 聚合实战:破解接口碎片化难题,3 类场景方案让业务响应提速 60%
API聚合破解接口碎片化困局,助力开发者降本增效。通过统一中间层整合微服务、第三方接口与AI模型,实现调用次数减少60%、响应提速70%。阿里云实测:APISIX+函数计算+ARMS监控组合,支撑百万级并发,故障定位效率提升90%。
294 0
|
3月前
|
JSON 自然语言处理 监控
淘宝关键词搜索与商品详情API接口(JSON数据返回)
通过商品ID(num_iid)获取商品全量信息,包括SKU规格、库存、促销活动、卖家信息、详情页HTML等。
|
3月前
|
人工智能 API 监控
告别多接口拼凑!阿里云 API 模型聚合实现技术能力协同跃迁
API聚合整合400+国内外AI模型,统一接口、屏蔽差异,降低开发与维护成本,提升效率与系统稳定性,助力开发者高效应对多API调用困境。
390 0
|
3月前
|
人工智能 供应链 API
淘宝API商品详情接口全解析:从基础数据到深度挖掘
淘宝API商品详情接口不仅提供基础数据,更通过深度挖掘实现从数据到洞察的跨越。开发者需结合业务场景选择合适分析方法,利用AI标签、区块链溯源等新技术,最终实现数据驱动的电商业务创新。