Jmeter后置处理器之JSON Extractor

一、使用场景

  json extractor后置处理器用在返回格式为json的HTTP请求中,用来获取返回的json中的某个值。并保存成变量供后面的请求进行调用或断言等。

二、使用方法

步骤一:选择HTTP请求—>后置处理器—>JSON Extractor

Jmeter后置处理器之JSON Extractor

 

步骤二:在查看结果树中,通过json path expression找到需要的json值

Jmeter后置处理器之JSON Extractor

 

 Jmeter后置处理器之JSON Extractor

 

步骤三:设置JSON Extractor

 Jmeter后置处理器之JSON Extractor

名称:json后置表达式的名称,标识作用,建议使用有意义的名字

Variable names:保存的变量名,后面使用${Variable names}引用

JSON Path  expressions:上一步中调试通过的json path表达式

Match Numbers:匹配数字(0代表随机,1代表第一个,-1代表所有)

Default Values:找不到时默认值,一般设置为NOT FOUND

Compute concatenation var(suffix_ALL):是否统计所有,即将匹配到的所有值保存,名为“变量名_ALL”,使用场景需要获取的值有多个,后面需要对这一组数据进行操作,如:

Jmeter后置处理器之JSON Extractor

Jmeter后置处理器之JSON Extractor

三、关键点

Json Path expression的使用

语法:

JsonPath

描述

$

根节点

@

当前节点

.or[]

子节点

..

选择所有符合条件的节点

*

所有节点

[]

迭代器标示,如数组下标

[,]

支持迭代器中做多选

[start:end:step]

数组切片运算符

?()

支持过滤操作

()

支持表达式计算

四、实战

需求:实现一个业务场景,同步患者,首次同步时同步所有患者,第二次同步时同步比base_version大的患者。

分析:根据输入的参数base_version,同步不同的数据,base_version=1111111111111时同步所有,响应数据中返回所有患者的base_version。下一次同步时传入当前最大的base_version,只同步比这个base_version大的患者的。

关键点:第一次同步后获取最大的base_version,作为下一次同步的参数,关键是如何获取最大值

解决方案:

1、使用json后置处理器获取所有的base_version

2、通过前置处理器JSR223 PreProcessor对返回的base_version进行处理,找出最大值(发现是列表最后一个)

3、第二次同步接口中,传入计算后的最大的base_version

Jmeter后置处理器之JSON Extractor

Jmeter后置处理器之JSON Extractor

 或使用如下脚本,计算最大值

var base_versions=vars.get("base_versions_ALL");
var version_list=base_versions.split(",");
var maxInNumbers = Math.max.apply(Math, version_list);

vars.put("max_version",maxInNumbers);
上一篇:jmeter提取器(css、xpath、正则表达式)


下一篇:发布一个智能解析库 Gerapy Auto Extractor