JMeter关联的几种方式总结案例

一、接口响应结果,一般为HTML、JSON格式的数据,对于HTML的响应结果的提取,能够经过正则表达式,也能够经过XPath 来提取。正则表达式

二、对于JSON格式的数据,能够经过正则表达式、JSON Extractor插件、BeanShell 来提取。shell

如何经过JSON Extractor 插件来提取JSON响应结果。express

须要下载插件,下载地址为:https://jmeter-plugins.org/wiki/JSONPathExtractor/json

下载后解压之后将lib和lib/ext中的jar包放到安装目录对应位置,重启便可。数组

 

 

场景一:post

须要提起的字符串是APP登陆接口的响应内容中的autoTokenspa

 

 

Variable names : 名称 
JSONPath Expression:JSON表达式 
Match Numbers:匹配哪一个,可为空即默认第一个 
Default Value:未取到值的时候默认值插件

这里由于返回的是json数据,$.data.autoToken,获取autoToken的值3d

调试:调试

场景1适合返回的json的autoToken只有一个的场景

 

场景2:

案例以下:

若是仍是按照1中的方法

使用$.data.id去提取id的值时,发现获取到的数据为空 
原来这个responses 的data为数组,故应为 $.data[0].id 提取第1个值

 

 

 

备注: JSON中 data 是一个对象数组data[0] 表明取的是第一个数组的对象data[*] 表明取所有对象

.id 取的是id的值 .name取的是name的值

这里要分别取resources 和 trades 的全部id值,表达式能够写:$.data.trades[*].id  (表明trades下全部子集中的id)

 

 

jmeter后置处理器 JSON Extractor取多个变量值

 

一、须要获取响应数据的请求右键添加-后置处理器-JSON Extractor

二、若是要获取json响应数据多个值时,设置的Variable names (后续引用变量值的变量名设置)与JSON Path expressions及Default Values的数量必定要一致;

如json体以下:

 {
"msg": "success", "code": "200", "data": { "total": 3, "aList": [ { "Time": 1501534900012, "id": 1 }, { "Time": 1501516732000, "id": 2 }
         ] } }

如上定义后,

Variable names设置为id1;id2

JSON Path expressions定义为$.data.aList[0].id;$.data.aList[1].id

Default Values:0;0

变量id1取值将为2,变量id2取值为3;若取不到id1的值会根据Default Values定义默认赋值为0

能够经过添加beanshell打印id一、id2的值验证结果

print("id1:"+vars.get("id1"));
print("id2:"+vars.get("id2"));

以上是经过JSON Extractor插件提取的

 

 

下面经过正则提取:

 

 

相关文章
相关标签/搜索