使用jmeter实现HTTP协议接口测试
1、工具准备
抓包工具:
fiddler(http协议抓包神器)
链接:https://pan.baidu.com/s/1cjHHJWLkvdNGCwe923Auxg
提取码:927r
2、知识准备
HTTP协议
HTTP协议是一种无状态协议,主要包含请求(request)和响应(response)两大部分
请求(request)
当浏览器向Web服务器发出请求时,它向服务器传递了一个数据块,也就是请求信息,HTTP请求信息由3部分组成:
- 请求方法 URI协议/版本
- 请求头(Request Header)
- 请求正文(请求头和请求正文之间是一个空行,这个行非常重要,它表示请求头已经结束,接下来的是请求正文)
HTTP请求中,最常用的方法是get和post请求,两者最基本的区别如下:
- get请求的参数一般放在请求行中,常用于向服务器获取资源, 以?分割URL和传输数据,参数之间以&相连,如:http://192.XXX.XX.XXX:XXXX/supplychainfinance-audit/orderManege/getOrdersList?currentPage=1&pageSize=10; POST请求的参数需要放在body里,常用于向服务器提交表单
- GET提交的数据大小有限制(因为浏览器对URL的长度有限制),而POST方法提交的数据没有限制
响应(response)
响应即为接口返回的信息,包含3部分:
- 状态行(包含协议/版本 状态码)
- 响应头
- 响应体(常见的响应格式有HTML、json、xml)
jmeter中各元件作用域及执行顺序
请参考: http://www.cnblogs.com/imyalost/p/5971168.html
3、使用jmeter发送HTTP请求
可以通过点击optitions->choose languaage->chinese(simplified)切换语言为简体中文
1. 添加线程组
通过对线程组属性配置,可以控制并发数、循环次数、持续时间等
2. 添加HTTP请求
添加cookie管理器
添加HTTP Cookie 管理器后,jmeter会自动记录并保存服务端返回的cookie信息,并且在后面所有请求中自动添加cookie。每个线程的cookie都是独立的。
线程组->右键,添加->取样器->HTTP请求
添加HTTP信息头管理器
由于systoken用于保存登陆信息、subSysClientid为所测试系统特有字段,需单独添加信息头
请求内容填写
由于Content-Type: application/x-www-form-urlencoded; charset=UTF-8;所以此处请求体选用表单形式填写
若Content-Type: application/json则表示请求格式为json格式,需添加HTTP信息头管理器,请求内容填写在消息体数据中:
3. 添加响应断言
断言可以用于判断服务器的返回是否是期望结果,由于被测试系统在请求成功后都会返回"message":"成功",所以断言选择“成功”
模式匹配规则中各项的含义:
包括:返回结果包括你指定的内容,支持正则匹配
匹配:返回结果与你指定断言完全一致,支持正则匹配
Equals:返回结果与你指定断言完全一致,不支持正则匹配
SubString:与 “包括”差不多,都是指返回结果包括你指定的内容,但是subString不支持正则字符串
否:就相当于取反。 如果上面断言结果为true,勾选“否”后,最终断言结果为false。如果上面断言结果为false,勾选“否”后,则最终断言结果为 true
或者:如果测试模式下添加多个判断条件,只要有一个为true,则断言结果为true
4. 添加后置处理器
由于后续请求都会用到登陆返回的systoken,所以需要将其提取出来,作为下一个请求的参数(使用方式 ${Token})。
Content-Type: application/json;charset=UTF-8表示响应的数据格式为json格式,所以添加json提取器
json表达式简介
响应原文:`{"code":1,"sysToken":"platform-XXXXXXXXXXXXX-20190001","message":"成功"}`
匹配内容:platform-XXXXXXXXXXXXX-20190001
json表达式:$.sysToken或者sysToken($表示根路径)
响应原文:`{"code": 1,"data":{"sysToken": "platform-XXXXXXXXXXXXX-20190001","message": "成功"}}`
匹配内容:platform-XXXXXXXXXXXXX-20190001
json表达式:$.data.sysToken或者data.sysToken($表示根路径)
响应原文:`{"code": 1,"data":[{"sysToken": "platform-XXXXXXXXXXXXX-20190001","message": "成功"}]}`
匹配内容:platform-XXXXXXXXXXXXX-20190001
json表达式:与前一个相比多了[],则表示为数组,所以需要用$.data[0].sysToken或者data[0].sysToken($表示根路径)
5. 运行并查看结果
在线程组下添加“查看结果树”,可以查看该线程组下所有请求的结果
最终运行后的结果如下:
请求:
响应:
4. 结构优化
1. 添加HTTP请求默认值
添加方式:右键->添加->配置元件->HTTP请求默认值
在同一个项目中,请求的协议、ip、端口号、编码方式基本一致,添加“HTTP请求默认值”后有效避免了每添加一个请求后都需要重新填写这些字段
2. 参数化
参数化可以有效实现测试数据与脚本分离,提高脚本可用性
从csv文件中读取测试数据,需添加csv数据文件设置(右键->添加->配置元件->csv数据文件设置),添加完成后,在请求中使用${username}、${fullname}、${permission}即可获取文件中的值