jmeter之关联

前言:当请求之间有依赖关系,比如一个请求的入参是另一个请求返回的数据,这时候就需要用到关联处理,Jmeter可以通过“后置处理器”中的“正则表达式提取器”来处理关联。

一、后置处理器-------正则表达式提取器

jmeter之关联

jmeter之关联

引用名称:引用名称和引用的方法,不用多解释,和变量参数化差不多。

正则表达式:凡是要被引用的部分都替换成圆括号,括号内具体的表达式您可以单独查阅正则表达式相关的知识。      

     ():括起来的部分就是要提取的。

    .:匹配任何字符串。
    +:一次或多次。
    ?:不要太贪婪,在找到第一个匹配项后停止。

模板: 代表从正则表达式结果引用的样式,其实结果是一组,而不是一个。$0$代表这一组结果的全部,$1$代表这一组结果的第1个,以此类推;

    $1$$2$代表该正则表达式一组结果中的第1个和第2个,俩结果挨在一起中间没有间隔;

    $3$,$4$代表该正则表达式一组结果中的第3个和第4个,俩结果间有一个逗号相连。

匹配数字:0代表正则表达式结果组中随机,1代表全部。

缺省值:当引用不对时显示传递的信息,通畅写一个ERROR。

二、后续的HTTP请求

jmeter之关联

补充:复杂一点的关联,像取正则表达式结果里面多个值

比如一个请求的响应数据如下:

jmeter之关联

我们尝试来提取0.0,84956.0,1019,3这四个数据,添加正则表达式提取器做如下设置

jmeter之关联

jmeter之关联

事实上,myref_g0,myref_g1...myref_g4 是正则表达式的结果组,而myref才是被模板控制提取出来结果,这里为了更清晰的观察正则表达式的结果组才在验证请求中添加这么多参数,实际使用是用一个myref和模板配合就可以了。

myref_g0={"rent":0.0,"price":84956.0,"totalprice":1019,"roomType":3}

myref_g1=0.0

myref_g2=84956.0

myref_g3=1019

myref_g4=3

上一篇:利用sqoop对mysql执行DML操作


下一篇:使用 Spring Cloud Sleuth、Elastic Stack 和 Zipkin 做微服务监控