在接口自动化测试过程中,经常遇见提交数据的接口测试,开发设计的提交数据的方式常为POST、PUT、PATCH等,对于这些接口测试同学们也不陌生,几乎做接口自动化测试都会涉及。在提交数据过程中,不知大家是否遇到提交数据内容正确,请求方法(如POST)和请求资源路径正确但提示数据类型不支持(如:报错415 Unsupported Media Type)的问题?常在河边走,哪有不湿脚的题主本人就遇到了。
从一开始的一脸懵逼到后来的仔细查看,外加服务端日志分析,终于发现问题所在:题主在使用POST提交数据时,习惯性将Content-Type设置为application/json格式,而测试接口接收数据类型为multipartdata。所以,你懂的,当然失败了!
什么是multipartdata?rf如何提交multipartdata类型数据呢?也许经验丰富的你已经很了解了,那么可以忽略本文,但是题主还是想和大家聊聊。
一、数据提交方式
在寻找问题答案之前,我们先来看看以POST方式为例的提交数据方式,数据类型可以有哪些。
我们常见的、常用的数据提交方式主要有以下几种:
·application/json
·application/x-www-form-urlencoded
·multipart/form-data
1)application/json
application/json我们再熟悉不过了,几乎大多接口提交数据都会采用这种类型。在请求的headers中,添加Content-Type=application/json,用来告诉服务端消息主体是序列化后的 JSON 字符串,后端可以直接使用(客户端:服务端我这是JSON字符串你直接吸收吧~)。
2)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,编码后的新url为https://www.baidu.com/s?ie=utf-https://www.baidu.com/s?ie=utf-8&f=3&rsv_bp=1&rsv_idx=2&tn=baiduhome_pg&wd=51testing&rsv_spt=1&oq=51testing%25E8%25BD%25AF%25E4%25BB%25B6%25E6%25B5%258B%25E8%25AF%2595%25E5%259F%25B9%25E8%25AE%25AD%25E9%259D%25A0%25E8%25B0%25B1%25E5%2590%2597&rsv_pq=bae34d3400016490&rsv_t=878chqpZfcLiqflGGWpVes%2FOIJho8wHTN61dflgzhEP4LUSyIGA7OT9NVr%2BwWJvQk%2B01&rqlang=cn&rsv_dl=th_1&rsv_enter=1&rsv_btype=t&rsv_sug3=21&rsv_sug1=12&rsv_sug7=101&rsv_sug2=1&rsp=1&rsv_sug9=es_0_1&inputT=8808&rsv_sug4=13223&rsv_sug=9,即将搜索关键字转换为表单数据,使用x-www-form-urlencoded方式提交给服务器处理。
3)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 可以用于上传文件。
二、postman看看这几种数据提交方式吧
1)application/json
以ES向Index写入数据为例,如下图所示,Content-Type为application/json,Request-Body为key:value键值对组合。
图1 application/json数据提交方式信息
2)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。
图2 application/x-www-form-urlencoded数据提交方式信息
图3 application/x-www-form-urlencoded数据提交后url内容
3)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),文件名等信息。
图4 mutipart/form-data数据提交方式信息
图5 mutipart/form-data的boundary分割消息体格式
三、rf是怎么提交表单数据的
看了postman使用application/x-www-form-urlencoded和multipart-data提交表单数据的方法,最后来看看常用的rf时怎么实现的。以RequestLibrary关键字库为例:
1)application/json
aplication/json是rf自动化测试中常见的数据格式,不再赘述。
2)application/x-www-form-urlencoded
rf发送application/x-www-form-urlencoded类型数据方法如下图所示。
3)multipart/form-data
rf发送multipart/form-data类型数据方法如下图所示。
四、结束
在接口自动化过程中,application/json是我们常见的数据格式,multipart/form-data数据格式可能对于部分测试朋友来说有点陌生。希望本章能带你认识rf是如何上传multipart/form-data的文件的。
作者:刘晓佳Rachel
来源:http://www.51testing.com/html/79/n-4480379.html