使用jmeter实现HTTP协议接口测试

使用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请求,两者最基本的区别如下:

响应(response)

响应即为接口返回的信息,包含3部分:

  • 状态行(包含协议/版本 状态码)
  • 响应头
  • 响应体(常见的响应格式有HTML、json、xml)
响应部分

jmeter中各元件作用域及执行顺序

请参考: http://www.cnblogs.com/imyalost/p/5971168.html

3、使用jmeter发送HTTP请求

可以通过点击optitions->choose languaage->chinese(simplified)切换语言为简体中文


language.png

1. 添加线程组

step1.png

通过对线程组属性配置,可以控制并发数、循环次数、持续时间等
线程组配置.png

2. 添加HTTP请求
添加cookie管理器
添加HTTP Cookie 管理器后,jmeter会自动记录并保存服务端返回的cookie信息,并且在后面所有请求中自动添加cookie。每个线程的cookie都是独立的。

cookie.png

线程组->右键,添加->取样器->HTTP请求

step2.png

添加HTTP信息头管理器
step3.png

由于systoken用于保存登陆信息、subSysClientid为所测试系统特有字段,需单独添加信息头

图片.png

请求内容填写
由于Content-Type: application/x-www-form-urlencoded; charset=UTF-8;所以此处请求体选用表单形式填写
请求内容.png

若Content-Type: application/json则表示请求格式为json格式,需添加HTTP信息头管理器,请求内容填写在消息体数据中:
json格式请求头.png

请求体.png

3. 添加响应断言
断言可以用于判断服务器的返回是否是期望结果,由于被测试系统在请求成功后都会返回"message":"成功",所以断言选择“成功”
模式匹配规则中各项的含义:
  包括:返回结果包括你指定的内容,支持正则匹配
  匹配:返回结果与你指定断言完全一致,支持正则匹配
  Equals:返回结果与你指定断言完全一致,不支持正则匹配
  SubString:与 “包括”差不多,都是指返回结果包括你指定的内容,但是subString不支持正则字符串
  否:就相当于取反。 如果上面断言结果为true,勾选“否”后,最终断言结果为false。如果上面断言结果为false,勾选“否”后,则最终断言结果为 true
  或者:如果测试模式下添加多个判断条件,只要有一个为true,则断言结果为true

响应.png

响应断言.png

4. 添加后置处理器
由于后续请求都会用到登陆返回的systoken,所以需要将其提取出来,作为下一个请求的参数(使用方式 ${Token})。
Content-Type: application/json;charset=UTF-8表示响应的数据格式为json格式,所以添加json提取器

图片.png

json.png

json2.png

  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. 运行并查看结果
在线程组下添加“查看结果树”,可以查看该线程组下所有请求的结果

查看结果树.png

最终运行后的结果如下:
请求:
请求体

请求头

响应:
响应体

响应头

4. 结构优化

1. 添加HTTP请求默认值
添加方式:右键->添加->配置元件->HTTP请求默认值
在同一个项目中,请求的协议、ip、端口号、编码方式基本一致,添加“HTTP请求默认值”后有效避免了每添加一个请求后都需要重新填写这些字段

默认值.png

2. 参数化
参数化可以有效实现测试数据与脚本分离,提高脚本可用性
从csv文件中读取测试数据,需添加csv数据文件设置(右键->添加->配置元件->csv数据文件设置),添加完成后,在请求中使用${username}、${fullname}、${permission}即可获取文件中的值
csv.png

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。