在接口自动化测试过程中,经常遇见提交数据的接口测试,开发设计的提交数据的方式常为POST、PUT、PATCH等,对于这些接口测试同学们也不陌生,几乎做接口自动化测试都会涉及。
在提交数据过程中,不知大家是否遇到提交数据内容正确,请求方法(如POST)和请求资源路径正确但提示数据类型不支持(如:报错415 Unsupported Media Type)的问题?
常在河边走,哪有不湿脚的,题主本人就遇到了。
从一开始的一脸懵逼到后来的仔细查看,外加服务端日志分析,终于发现问题所在:题主在使用POST提交数据时,习惯性将Content-Type设置为application/json格式,而测试接口接收数据类型为multipartdata。
所以,你懂的,当然失败了。
什么是multipartdata?rf如何提交multipartdata类型数据呢?也许经验丰富的你已经很了解了,那么可以忽略本文,但是题主还是想和大家聊聊。
1 数据提交方式
在寻找问题答案之前,我们先来看看以POST方式为例的提交数据方式,数据类型可以有哪些。
我们常见的、常用的数据提交方式主要有以下几种:
application/json
application/x-www-form-urlencoded
multipart/form-data
01 application/json
application/json我们再熟悉不过了,几乎大多接口提交数据都会采用这种类型。在请求的headers中,添加Content-Type=application/json,用来告诉服务端消息主体是序列化后的 JSON 字符串,后端可以直接使用(客户端:服务端我这是JSON字符串你直接吸收吧)。
02 application/x-www-form-urlencoded
application/x-www-form-urlencode是以表单提交数据的一种方式,当Content-Type 被指定为 application/x-www-form-urlencoded时,客户端会把表单数据转换成一个字串(name1=value1&name2=value2…),然后把这个字串append到url后面,用?分割,加载这个新的url。
例如,使用百度搜索“51testing“时,通过开发者工具可以看到发起请求的接口Content-Type=application/x-www-form-urlencoded。
即将搜索关键字转换为表单数据,使用x-www-form-urlencoded方式提交给服务器处理。
03 multipart/form-data
multipart/form-data也是表单提交数据的一种方式。
它同application/x-www-form-urlencoded 的区别是:
application/x-www-form-urlencoded只能上传键值对,并且键值对都是间隔分开的,multipart/form-data既可以上传文件等二进制数据,也可以上传表单键值;
application/x-www-form-urlencoded不能用于上传文件,只能提交文本,当然如果有file控件的话也只能提交文件名,而multipart/form-data 可以用于上传文件。
2 Postman
看看这几种数据提交方式吧。
01 application/json
以ES向Index写入数据为例,如下图所示,Content-Type为application/json,Request-Body为key:value键值对组合。
02 application/x-www-form-urlencoded
以51testing首页搜索“最新最热”文章为例。如下图2所示,使用postman发送post请求。
Content-Type为application/x-www-form-urlencoded,Request-Body为mod=”guid”,view=”newthread”。
请求提交后,Request-Body以key=value的形式被拼接到URL上,以&符号分割。
如下图3所示,最终请求URL为http://bbs.51testing.com/forum.php?mod=guide&view=newthread。
03 multipart/form-data
如下图4所示为使用multipart/form-data方式上传文件。Content-Type: multipart/form-data。
boundary=--------------------------268648824645901190036938,boundary为分隔符,用来分割消息体中不同内容的。
如当上传两个文件a.csv和b.csv时,使用boundary分割的消息体格式如下图5所示。在消息体中,Content-Disposition显示了请求数据的格式(如本例中的form-data),文件名等信息。
rf是怎么提交表单数据的
看了postman使用application/x-www-form-urlencoded和multipart-data提交表单数据的方法,最后来看看常用的rf是怎么实现的。
以RequestLibrary关键字库为例:
01 application/json
aplication/json是rf自动化测试中常见的数据格式,不再赘述。
02 application/x-www-form-urlencoded
rf发送application/x-www-form-urlencoded类型数据方法如下图所示。
03 multipart/form-data
rf发送multipart/form-data类型数据方法如下图所示。
结束
在接口自动化过程中,application/json是我们常见的数据格式,multipart/form-data数据格式可能对于部分测试朋友来说有点陌生。
希望本章能带你认识rf是如何上传multipart/form-data的文件的。