post 接口请求测试,通俗易懂!

GET 方法和 POST 方法传递数据的异同
http 请求方法 get 和 post 是最常被用到的两个方法,get 常用于向服务器请求数据,post 常用于提交数据给服务器处理。GET 方法其实也可以传递少量的数据。但它存在以下问题:1)GET 方法不包含 body,因此以在 URL 中拼接字段的方式传递数据,2)GET 方法中的 URL 参数会被显示到地址栏上,存在安全问题 3)传递的数据只能是键值对,无法传递其他类型的数据因此出于传递大量、多种类型的数据和安全性的考虑,上传数据常使用 post 方法。
POST 方法如何传递数据
POST 方法提交数据给服务器,涉及到 Content-Type 和消息主体编码方式两部分。服务器根据请求头中的 Content-Type 来判断消息主体的数据格式和编码方式,数据则存储在 body 参数中上传。
body 支持多种数据格式,如 form-data,x-www-form-urlencoded,json,xml,raw,不同的数据类型有不同的优势,有自己擅长的业务场景。
例如:application/x-www-form-urlencoded 是默认的数据类型,但是在传输大型文件的时候效率低下,multipart/form-data 的报文的主体内则可以包含多部分对象,通常用来发送图片、文件或表单等,适用于传输大型文件。
接口测试软件简介
简单介绍下我们用来做接口测试的工具——Apifox(apifox.cn )。
Postman 自然是接口测试工具领域的老大哥,但 Apifox 这类软件在于它整合了接口测试的整个流程——从接口文档导入到单个接口的测试,整个接口套件的管理,以及自动化测试,一站式服务省去了几个软件切来切去的麻烦,现在我们直接用它来演示。
它的官网下载地址也顺便挂一个:(www.apifox.cn ) 是免费软件来着,大家下载完对着界面边看思路边操作,学习效果会好些。
它的软件界面长这样,我们直接在首页的接口管理 tab 进行测试即可。

POST 请求接口的测试
Post 接口请求的测试关键在于理解各个数据类型的含义,并且能构造相应的数据,对各种正常,异常和边缘情况进行测试。接下来会一一介绍下各个数据类型的含义,并用 Apifox 演示一下各个类型的数据如何测试。
1.application/x-www-form-urlencoded 原生的 form 表单,在 body 中的数据格式为键值对。下图所示为百度文字识别 AI 的一个 POST 请求接口,测试这个请求接口需要填入的数据有 2 项。
在 header 处填入 Content-Type:

在 body 处填入要上传的数据:

点击发送,可以看到实际发出的请求为:

2.multipart/form-data 当数据较大的时候可以选择 multipart/form-data

实际发起的请求,Content-Type 和 body 传输的数据可以在[实际请求 tab]中查看:

3.Json 在接口请求中填入 Json 数据

发出的实际请求的 Content-Type 和 Body 数据类型:

测试方法
根据接口文档的参数描述,设计接口测试用例,造出相对应的正常和异常数据参数,上传数据进行测试。
1.设计接口测试用例
举例:某开放平台 API 的接口文档参数描述如下:

根据请求参数,上传 jpg,png,gif 等格式的正常测试数据,再上传非图片的 base64 编码数据进行测试,查看请求返回。以该接口 image 参数测试的部分用例来作为例子:

2.Apifox 中执行用例
a.直接上传未经过编码的照片

b.上传非图片的 base64 编码

c.上传照片的 base64 编码:

3.保存接口测试用例,生成自动化测试套件

在测试管理 tab 导入测试用例,生成测试用例并一键运行




查看并导出测试结果:

总结
POST 方法传递数据是接口测试中常见的测试点。这篇文章主要介绍了为什么要用 post 方法来传递数据,post 方法 body 传递参数的 4 种数据格式;设计用例并使用 Apifox 进行测试,最后生成了自动化测试用例及测试报告。
官网地址:apifox.cn
评论