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

如何做接口测试?

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

01、通用的项目架构

02、什么是接口

接口:服务端程序对外提供的一种统一的访问方式,通常采用HTTP协议,通过不同的url,不同的请求类型(GET、POST),不同的参数,来执行不同的业务逻辑。

客户端大多数的业务操作,都是需要调用服务端接口来获取一些数据,或者触发某些业务,然后客户端拿到接口返回的数据后,会根据数据内容做不同的处理和展示。

03、为什么要做接口测试

A、在公司里,客户端和服务端通常是由不同的团队开发的,在项目开发过程中,客户端和服务端开发的进度不一致,比如服务端先开发完了,这个时候可以先对服务端进行接口测试,确保服务端逻辑和返 回数据是正确的,然后再测试客户端。或者是某些测试部门,专门测试服务端开发团队,因此,他们的测试对象就是接口

B、在测试某些业务时,不能仅仅通过前端来测试,比如用户注册,前端限制了用户名不能为空,但是有些人可能通过工具绕过前端直接调用服务端接口,如果服务端没有做相关的逻辑判断,就会造成数据 错误,包括接口数据传输过程中是否对关键信息加密等,所以必须针对服务端接口单独做测试。

C、在开发提测后,可以先通过工具把服务端的接口测试跑一遍,确保接口测试用例都是通过的,快速判断服务端接口是否符合预期,然后再通过UI界面进行测试,否则接口有bug,前端页面必定有bug。

04、接口测试工具和流程

常见的HTTP接口测试工具有Jmeter、Postman、SoupUI等。企业里用的比较多的是Jmeter。

Jmeter是一款开源、免费的接口测试工具,它可以对接口的功能、性能进行测试。还可以实现接口自动化。

Jmeter具体使用,请参考《Jmeter接口工具实战》文档

接口测试流程:

和普通的web测试一样,也是先进行需求分析、测试用例编写、执行测试、提交bug、回归测试、提交 测试报告等。

05、接口测试的关注点

1、输入

输入主要是指接口的入参,我们平常的测试中,会先考虑正常的入参,以及异常的入参,异常情况包括:参数异常和数据异常,用例设计这块使用较多的是等价类划分和边界值分析

  • 正常的入参

    正常的入参很好理解,就是根据接口设计文档的入参标准,输入正常的参数,响应按接口设计文档的约 定条件正常返回

  • 参数异常

    参数异常包括:参数为空,多参或少参,错误的参数

  • 数据异常

    数据异常:数据类型错误、非空参数为空,长度不符合设计,不在范围内的数据,不合法的成员,特殊 字符或敏感字符,存在关联关系的参数数据异常等

2、业务逻辑

和基于UI的功能测试一样,接口测试也需要了解接口背后的业务逻辑,针对业务流程的处理逻辑,我们 可以从入参的限制条件、事件的操作对象、业务的状态转换等不同维度来考虑

  • 限制条件分析

    数值的限制:字典,等级,行业相关限制,金额限制,分数限制等

    状态的限制:有效|无效,在线|离线,拉黑|洗白等

    关系的限制:存在或不存在,绑定或解绑等

    权限的限制:管理员,普通用户等

  • 对象分析

    对象分析主要是对合法和不合法的对象进行操作,比如银行卡用户对卡进行充值,则可能存在:用户A使用非用户A的卡充值;用户A使用自己的卡进行充值,卡已过有效期;用户A使用自己的卡进行充值, 卡为黑名单或挂失等。

  • 状态转换的分析

    比如支付类业务,先支付成功,撤单后会退款,再次支付如果支付未成功,则是支付失败,状态之间的 切换是否正常,未按正常业务顺利进行操作时,状态怎么显示,是否可控,是否出现异常状态,空状态 业务怎么处理等

  • 时序分析

    一些复杂的活动中,一个活动是由一系列的动作按照指定顺序进行,这些动作形成一个动作流,是有按照这个顺序依次执行,才能等到预期的结果,那么在执行过程中发生的其他分支动作程序会作何处理?

3、输出

在考虑异常时,通常我们都会想到正常情况,无效的情况,但是不一定能覆盖所有错误码,而接口定义返回的错误码可以帮助我们补充这一部分的用例,比如网络异常,无效的规则,无效的参数,无效的业务ID,无效的任务,服务器异常等,把errorcode的值都补充上去可以设计更多的用例

这种根据输出进行设计用例,可以发现前后端是否正常输出结果,提示是否友好,提示是否出现敏感信息等

4、数据库操作

  • 业务数据入库是否正常,是否有重复数据入库,是否出现乱码

  • 数据更新是否正常,尤其是时间类字段,时间是否为24小时制的格式

  • 表中各个字段是否符合预期

5、安全性

敏感信息是否加密(如用户名、银行账号,密码,转账金额)

6、性能

  • 接口最大支持多少并发数

  • 接口每秒能处理多少次业务(TPS)

  • 接口的平均响应时间(RT)

  • 接口对服务器资源的消耗(CPU、内存、网络、磁盘)

7、兼容性

接口测试不需要考虑客户端的兼容性,主要是数据的兼容性。比如对于老接口的历史数据是否兼容,用 新接口去处理老的数据,是否能正常处理。

8、其他

  • 幂等性:就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用。

举个最简单的例子:

那就是支付,用户购买商品后支付,支付扣款成功,但是返回结果的时候网络异 常,此时钱已经扣了,用户再次点击按钮,此时系统应该拒绝支付,并且提示“不能重复支付”。相当于 第二次支付不会产生任何作用。在做接口测试时,对于某些有幂等性要求的接口,需要针对幂等进行测 试。

通常可以采用Jmeter连续调用2次接口进行支付、提交等操作,来测试幂等性。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

http://www.jsqmd.com/news/115060/

相关文章:

  • 世界上最流行的黑客漏洞扫描工具Nessus保姆级安装教程,网络安全零基础入门到精通实战!
  • ​2025胶原蛋白肽测评榜单:6大品牌真实效果报告,仙次元紧致提亮逆转肌龄 - 博客万
  • 科普一下:黑客盗QQ究竟是怎么回事?真的是用技术手段做到的吗?
  • 如何在PHP中实现接口的多继承?
  • android13避免开机进入安全模式
  • 网络安全新手入门—简单用MSF黑客工具渗透安卓手机(小白的第一次黑客渗透)
  • Spring Boot 机制一: 自动配置原理源码级深度讲解 - 教程
  • 收藏!一文读懂RAG技术核心(附大模型从入门到实战全套学习礼包)
  • 渗透测试之kali自带的SQLmap详解—重点sqlmap--tamper 使用方式详解,搞完你就很nice了
  • 【每天了解一个AI证书】CAIE认证大纲设计解析(2026年)
  • 2025年标准氩气生产商权威推荐榜单:标准高纯氩气/高纯氩气/氩气纯度标准源头厂家精选 - 品牌推荐官
  • 【收藏向】大模型系列:从原理到代码,零基础吃透LLM训练与推理
  • 7D互动影院革新娱乐体验,探秘5D影院设备生产厂家
  • 重磅消息!ESXi 8.0 系列推出ESXi 8.0 Update 3h 更新重要版本啦
  • 2025年12月防冻液,45度橙色防冻液,超流体散热快防冻液厂家权威推荐,散热防冻双效实力盘点 - 品牌鉴赏师
  • 渗透测试之kali自带的SQLmap详解—重点sqlmap--tamper使用方式详解,搞完你就很nice了
  • 三方备付金代付下发
  • 【保姆级教程】Attention机制全解析!用PyTorch手写Transformer,大模型开发入门到精通!
  • 2025公共金属家具制造企业TOP5权威测评:河北优美实力怎么样 - mypinpai
  • 【必收藏】2025大模型浪潮下,程序员的职业突围指南:从被动淘汰到主动领跑
  • 基于数据服务的信息需求 管理系统设计与实现
  • 揭秘Open-AutoGLM本地部署难题:如何在Windows系统中高效配置并运行
  • 从《黑镜》科幻预言到现实:AI 2027-2042年冲击全解析(附大模型学习路线+资料,建议收藏)
  • 基于Python的淘宝月季销售预测数据可视化系统 爬虫
  • 国产GPU首次实现十万卡集群!摩尔线程“夸娥“架构如何挑战英伟达霸主地位?
  • 2025-2026北京专业离婚律师评测推荐榜单:核心亮点与服务优势全攻略 - 老周说教育
  • 基于Python网易云音乐排行榜数据分析系统设计与实现_i23qqb6l
  • 8 个 AI 写作工具,MBA 论文写作不再难!
  • 2025年育发生发液产品综合盘点:生发育发液/止脱生发/防脱生发深度解析与品牌参考 - 品牌推荐官
  • 基于单片机的开关电源设计