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

简介: 哈喽,我是树酱。去年中旬的时候写过一篇关于如何更好管理 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天前
|
监控 安全 数据挖掘
Email 接口API有哪些?具体分析一下阿里云和AOK的优点
本文介绍了常见的Email接口API,如阿里云邮件推送、AOKSend、SendGrid、Mailgun和Amazon SES。阿里云API以其高稳定性和数据分析功能脱颖而出,支持批量发送和多语言;而AOKSend API以易于集成、高安全性和优秀客户支持为亮点。企业在选择时应考虑自身需求和预算,以优化邮件营销效果。
|
2天前
|
定位技术 API
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
|
2天前
|
JSON 安全 API
解锁淘宝商品评论API接口:电商数据分析的新视角
淘宝商品评论API接口是淘宝开放平台提供的一组API接口,允许开发者通过编程方式获取淘宝商品评论数据。这些接口可以获取到商品的详细信息、用户评论、评分等数据,为电商数据分析提供了丰富的素材。
|
2天前
|
缓存 负载均衡 安全
探索API接口开发(定制与开发接口)
在当今数字化、互联互通的时代,API(应用程序编程接口)已经成为连接不同软件、服务和应用的关键桥梁。API接口开发,作为软件架构和系统设计的重要组成部分,不仅影响着数据交换的效率,更决定了整个系统的灵活性和可扩展性。本文将深入探讨API接口开发的各个方面,包括其重要性、开发流程、最佳实践以及面临的挑战。
|
3天前
|
文字识别 API 开发工具
印刷文字识别产品使用合集之API接口无法调用如何解决
印刷文字识别(Optical Character Recognition, OCR)技术能够将图片、扫描文档或 PDF 中的印刷文字转化为可编辑和可搜索的数据。这项技术广泛应用于多个领域,以提高工作效率、促进信息数字化。以下是一些印刷文字识别产品使用的典型场景合集。
25 6
|
3天前
|
监控 供应链 数据挖掘
抖音电商新篇章:douyin.item_get API接口的深度应用
douyin.item_get接口最基本的应用就是获取商品的详细信息。商家可以通过输入商品的ID或链接,获取商品的标题、价格、图片、描述、规格等关键信息。这些信息对于商家来说至关重要,可以帮助他们了解商品的销售情况、竞争态势以及市场需求。
|
4天前
|
安全 API 开发者
智能体-Agent能力升级!新增Assistant API & Tools API服务接口
ModelScope-Agent是一个交互式创作空间,它支持LLM(Language Model)的扩展能力,例如工具调用(function calling)和知识检索(knowledge retrieval)。它已经对相关接口进行了开源,以提供更原子化的应用LLM能力。用户可以通过Modelscope-Agent上的不同代理(agent),结合自定义的LLM配置和消息,调用这些能力。
|
4天前
|
存储 自然语言处理 搜索推荐
Elasticsearch 8.10 同义词管理新篇章:引入同义词 API
Elasticsearch 8.10 同义词管理新篇章:引入同义词 API
15 0
|
4天前
|
JSON 搜索推荐 数据挖掘
电商数据分析的利器:电商关键词搜索API接口(标题丨图片丨价格丨链接)
淘宝关键词搜索接口为电商领域的数据分析提供了丰富的数据源。通过有效利用这一接口,企业和研究人员可以更深入地洞察市场动态,优化营销策略,并提升用户体验。随着电商平台技术的不断进步,未来的API将更加智能和个性化,为电商行业带来更多的可能性。
|
4天前
|
存储 缓存 运维
DataWorks操作报错合集之DataWorks根据api,调用查询文件列表接口报错如何解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
25 1

热门文章

最新文章