Apifox 是一个 API 协作开发平台,后端、前端、测试都可以使用 Apifox 来提升团队的工作效率。对于后端开发者而言,Apifox 的核心功能主要包括四个模块:调用 API、定义 API、开发与调试 API 以及生成 API 文档。本文将详细介绍后端开发人员如何有效利用 Apifox 提高工作效率。
视频纯享版 ⬇️
调用 API
快捷请求
许多开发者可能已经使用过 Postman 进行 API 测试。在 Apifox 中,新建一个「快捷请求」后,调试界面就与 Postman 类似。只需填写必要的 Header 和 Body 信息,然后点击“发送”按钮即可完成 API 调用。
多协议支持
除了常见的 HTTP 协议,Apifox 还支持 WebSocket、TCP、GraphQL 和 MsgPack 等多种协议。你可以通过点击加号按钮,以新建不同协议的接口。
对于使用 RPC 架构的项目,Apifox 还提供了新建 gRPC 或 Dubbo 项目的选项,方便开发人员进行调试。
导入现有 API 项目
如果你手里已经有了一个完整的 API 项目,无论是 Swagger、OpenAPI 还是 Postman 等格式,都可以方便地导入到 Apifox,省去重新配置过程,以直接开始调用和管理接口。
定义 API
自动生成文档
对许多后端开发者来说,编写 API 文档往往是一项极为繁琐的工作。Apifox 提供了一种简便的方法来创建 API 文档。
当你新建了一个「快捷请求」,并成功调用后,只需点击“保存为接口”按钮,Apifox 就会根据该接口的请求和响应自动生成 API 文档。生成的文档中包含了你刚刚调用的接口的请求和返回示例数据。
IDEA 插件支持
对于使用 Java Spring 框架或 Kotlin 的开发者,Apifox 提供了 Apifox Helper 这一 IDEA 插件。安装该插件后,可以自动生成 API 文档并一键同步到 Apifox 的项目中。
Swagger 集成
如果你的团队使用 Swagger,Apifox 也提供了自动导入功能。你可以设置定时导入,把数据实时同步到项目中。
文档先行理念
Apifox 倡导“文档先行”的开发理念,即在开发前先定义好 API。这种方法有助于前后端团队同步进行开发,以大幅度提升开发效率。
在 Apifox 中,新建一个接口后,可切换到「文档模式」,在该模式下定义 API。此界面分为三个部分:接口基础信息、请求参数和返回响应。在相应的地方填写接口名称、路径、请求方法、请求参数等信息即可。
在接口“返回响应”中,通常存在通用的数据结构。建议预先定义数据模型,通过引用和解除关联,可以轻松完成复杂的响应定义。
编写响应示例往往较为麻烦,但 Apifox 提供了「自动生成」功能。根据数据结构定义和字段命名,Apifox 能够自动填充示例数据,如自动生成人名、手机号等,可以节省大量手动编写示例的时间。
此外,你还可以将 JSON、XML 甚至 MySQL 建表语句导入作为数据结构,非常便捷。
对于不同接口的相同错误响应(如 400、401、404 等),你可以在「组件库」中定义响应组件。响应组件允许在多个接口中引用,或在此基础上解除关联进行修改,减少重复工作。
开发与调试 API
前后端协同开发
在定义好 API 后,可以将前端开发者加入项目,前端可以在接口开发完成前使用 Mock 数据进行开发。这样就无需等待后端接口开发完成后才实现业务逻辑,以有效缩短开发周期。
代码生成
Apifox 可以根据 API 定义自动生成代码。点击接口中的“生成代码”按钮,可以选择“生成接口请求代码”或“生成业务代码”。支持多种编程语言和框架,并可配置代码风格。生成的代码包含路由处理、请求验证、响应处理等基础功能,开发者只需在此基础上添加业务逻辑。
动态生成请求
接口开发完成后,可以直接在 Apifox 中进行自测,在定义好的接口中点击“发送”按钮开始测试。如果请求体较为复杂,你可以使用“自动生成”功能,根据数据结构自动生成一组接口参数。
同时,可以利用“动态值”功能生成随机或特定格式的测试数据。动态值还支持 Base64、MD5 等加密函数,可根据需求进行选择。
响应校验
在发送请求后,Apifox 会自动校验返回数据是否符合预定义的 API 文档。如果返回数据不符合预期,例如缺少必要字段或返回值不在预定义的枚举值中,Apifox 会在界面中以红色标注提示错误,帮助你及时发现并修正问题。
前/后置操作
对于熟悉 Postman 的用户,Apifox 提供了完全兼容的脚本支持。你可以在「自定义脚本」中直接运行从 Postman 迁移过来的脚本,脚本可以用于设置环境变量、进行复杂的数据处理、加密解密或执行自定义的测试逻辑。
如果需要断言和提取变量,你可以通过填写 JsonPath 表达式,从响应中提取元素并进行断言或存储为变量,可视化的方式让你无需编写脚本即可实现复杂的自测需求。
除了断言、提取变量等操作,还支持数据库操作,可以在请求发送前后查询数据库,验证数据操作的正确性,支持 MySQL、Oracle、SQL Server、PostgreSQL 和 ClickHouse 等热门数据库。
用例管理
对于已经调试好的请求,可以保存为用例,便于后续重复测试。每种情况的数据请求都可以保存为独立的用例,以此简化自测流程,提高测试效率。
环境管理
Apifox 提供了灵活且强大的环境管理功能,允许你为不同的服务配置不同的「前置 URL」。
在环境管理中,你可以创建多个环境(如开发环境、测试环境、生产环境等),每个环境中可以定义多个服务(如订单服务、用户服务等)及其对应的前置 URL。这种设计特别适合处理微服务架构或需要访问多个后端服务的场景。
在接口定义时,可以选择该接口所属的服务,Apifox 会自动使用当前环境中对应服务的前置 URL。这样,当切换环境时,所有接口都会自动使用新环境中配置的正确服务地址,无需手动修改每个接口的 URL。
此外,你还可以在目录级别设置服务,使得该目录下的所有接口都使用指定的服务配置。
调试模式
对于规模较小、不需要先编写接口文档的项目,你可以将「文档模式」调整为「调试模式」。进入调试模式后,你可以直接发送请求并修改参数,适用于边开发边自测的 Code-first 开发方式。调试完成后,Apifox 会自动生成完整的接口定义,方便后续测试和文档生成。
生成 API 文档
在 API 开发完成后,就可以在 Apifox 里便捷地生成和分享 API 文档。
在线分享文档
通过点击「分享文档 -> 快捷分享」选项,你可以新建一个分享对象,选择需要分享的接口,设置运行环境和访问密码,设置完毕点击“保存”按钮,即可生成美观的接口文档,该文档可交付给合作方或其他部门。
在生成的 API 文档中,你可以直接点击“调试”按钮在页面中发起请求,或生成请求代码。
发布文档站
如果你需要将接口文档展示在官网或面向全网读者,可以选择「发布文档站」功能。该功能支持自定义导航栏、自定义域名、设置文档重定向规则,并集成了 Algolia 的搜索服务,帮助你打造个性化的 API 文档界面。
你可以创建多个文档站点,并在每个站点中发布不同版本的 API 文档。
文档访问者可以在公开的文档站中查看已发布的版本信息,并通过点击切换不同的文档版本进行浏览。
Apifox 为后端开发提供了全面、高效的 API 管理解决方案。从 API 调用、定义、调试到文档生成,Apifox 通过集成多种功能,简化了开发流程。
无论是大型项目的文档先行开发(文档模式),还是小型项目的代码先行开发(调试模式),Apifox 都能满足不同需求,助力开发者高效完成 API 相关工作。
想要了解更多详细信息,请参考 Apifox 帮助文档,并通过实际使用来体验 Apifox 带来的便利与高效。
关于测试人员如何使用 Apifox 可以前往了解:
如果你有什么酷炫的想法或者实践,欢迎在评论区分享,也欢迎发送邮件至 [email protected] 投稿,有精美周边掉落哦!无论是个人使用小技巧,还是解决难题的思路想法,统统都可以!