详解 JSON 提取器
为什么要用 JSON 提取器
JSON 是目前大多数接口响应内容的数据格式
在接口测试中,不同接口之间可能会有 数据依赖 ,在 Jmeter 中可以通过后置处理器来提取接口的响应内容
JSON 提取器是其中一个可以用来提取响应内容的元件
JSON 提取器的应用场景
提取某个特定的值
提取多个值
按条件取值
提取值组成的列表
JSON 提取器
我们通过实际栗子去讲述理论知识点
JSON 提取器界面介绍
字段含义
测试计划树结构
下面多个栗子都以这个测试计划为基础哦
提取某个特定的值的栗子
登录接口响应
登录是执行其他接口的前置接口,所以要获取用户登录后的 token、uuid
提取 token
相对路径的方式
提取 uuid
绝对路径的方式
其他接口调用 token、uuid
知识点
- 提取某个特定值的方式有两种:绝对路径、相对路径
- 提其他接口可以通过 ${ var } 这种格式,来获取提取到的值
综合栗子
上面讲的是 使用 JSON 提取器时的一个流程
在实际项目中,接口的响应内容肯定是非常复杂的,而我们需要提取的值也是多样化的,需要通过各种实战栗子来讲述清晰
Json 字符串
这也是某个接口返回的响应内容,后面的栗子也是以这个 JSON 字符串为基础来提取各种值
{
"ret": 200,
"msg": "V2.5.1 YesApi App.User.GetList",
"data": {
"total": 3,
"err_msg": "",
"err_code": 0,
"users": [
{
"role": "user",
"status_desc": "正常",
"reg_time": "2020-06-22 15:19:51",
"role_desc": "普通会员",
"ext_info": {
"yesapi_nickname": "",
"yesapi_points": 0
},
"uuid": "6D5EDCB459F0917A98106E07D5438C58",
"username": "fangjieyaossb",
"status": 0
},
{
"role": "user",
"status_desc": "正常",
"reg_time": "2020-06-22 14:27:17",
"role_desc": "普通会员",
"ext_info": {
"yesapi_nickname": "",
"yesapi_points": 0
},
"uuid": "0164DC0680F84DCE40D3DD4A36640ECA",
"username": "fangjieyaossa",
"status": 0
},
{
"role": "admin",
"status_desc": "正常",
"reg_time": "2020-03-23 22:48:32",
"role_desc": "管理员",
"ext_info": {
"yesapi_nickname": "",
"yesapi_points": 0
},
"uuid": "079BF6BB82AFCFC7084F96AECAF0519F",
"username": "fangjieyaoss",
"status": 0
}
]
}
}
提取单个值
重点
1、如果匹配到多个值,也只能提取到一个值
2、如果想提取匹配到的所有 uuid,可以设置为 -1,结果如下图
还会告诉你匹配了多少个值 {uuid} 而是 {uuid_2}
利用切片提取单个值
和 Python 切片一样的原理
提取多个值
1、四种写法类似,选一种方法自己熟记即可
2、重点: 提取多个值,提取器的 Match No. 必须填 -1
$.data.users[].role
提取所有 role 字段值
[] 表示取数组的所有元素
$…users…role_desc
提取所有 role_desc 字段值
$…reg_time
提取所有 reg_time 字段值
$…[*].username
提取所有 username 字段值
按条件提取值
有时候只需要提取某个特定条件下的参数值
语法格式
[?(expression)]
栗子:
@
代表当前节点,像上面的四个栗子,@代表 users 这个列表字段
=~
后面跟正则表达式,如果想提取 包含指定字符 的值,可以使用此正则: /.指定字符串.?/i
i 代表大小写不敏感
勾选 Compute concatenation var 的栗子
JSON 提取器
测试结果
uuid_1=6D5EDCB459F0917A98106E07D5438C58
uuid_2=0164DC0680F84DCE40D3DD4A36640ECA
uuid_3=079BF6BB82AFCFC7084F96AECAF0519F
uuid_ALL=6D5EDCB459F0917A98106E07D5438C58,0164DC0680F84DCE40D3DD4A36640ECA,079BF6BB82AFCFC7084F96AECAF0519F
uuid_matchNr=3
加入我们测试交流!!~群。。642830685,领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!
更多推荐
所有评论(0)