博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jmeter(十二)关联之正则表达式提取器
阅读量:4916 次
发布时间:2019-06-11

本文共 1592 字,大约阅读时间需要 5 分钟。

如果有这样的情况:一个完整的操作流程,需要先完成某个操作,获得某个值或数据信息,然后才能进行下一步的操作(也就是常说的关联/将上一个请求的响应结果作为下一个请求的参数);

在jmeter中,可以利用正则表达式提取器来帮助我们完成这一动作。

 

首先:在默认的测试计划中添加一个线程组,然后添加取样器,这里我以JDBC请求做例子:

 

然后:右键添加后置处理器→正则表达式提取器,正则表达式提取器界面如下:

说明:

后置处理器:在请求结束或者返回响应结果时发挥作用

正则表达式提取器:允许用户从服务器的响应中通过使用perl的正则表达式提取值。该元素会作用在指定范围取样器,用正则表达式提取所需值,生成模板字符串,并将结果存储到给定的变量名中。

APPly to:作用范围(返回内容的断言范围)

         Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器

         Main sample only:仅作用于父节点的取样器

         Sub-samples only:仅作用于子节点的取样器

         JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)

要检查的响应字段:需要检查的响应报文的范围

         主体:响应报文的主体

         Body(unescaped):主体,响应的主体内容且替换了所有的html转义符,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用 

         Body as a Document:从不同类型的文件中提取文本,注意这个选项比较影响性能 

         Response Headers:响应信息头

         Request Headers:请求信息头

         URL:统一资源定位符,即Internet上用来描述信息资源的字符串

         Response Code:响应状态码,比如200、404等

         Response Message:响应信息

PS:jmeter的中文翻译有时候不太准确,建议尽量选择语言格式为英文(为了方便说明,这里选择中文语言,当然,自己明白最好,不用纠结这个)

引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的值、字段、变量名(例子中我提取的是SOCIAL_NO)

引用方法:引用方法:${引用名称}

正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值,请不要使用“||”,除非你本身需要匹配这个字符。

下面是常用的正则表达式操作符:

模板(Template):从匹配的结果中创建一个字符串,这是通过正则表达式匹配出来的一组值,意为使用提取到的第几个值(可能有多个值匹配,因此使用模板);从1开始匹配,以此类推.

                参数可以在取值模板组合使用,例如:“$1$-$2$”作为模板得到的值是使用“-”连接的第一个待匹配内容与第二个待匹配内容组合而成的字符串。

匹配数字(Match No):正则表达式匹配数据的结果可以看做一个数组,表示如何取值:0代表随机取值,正数n则表示取第n个值(比如1代表取第一个值),负数则表示提取所有符合条件的值。

缺省值:匹配失败时候的默认值;通常用于后续的逻辑判断,一般通常为特定含义的英文大写组合,比如:ERROR

 

最后,根据上面的说明,完成配置,然后可以先添加一个监视器(查看结果树),检查是否取到了对应的值;

提取到的参数,调用时用${SOCIAL_NO_1},${SOCIAL_NO_2}...,如果想要得到匹配出的参数的个数,用${SOCIAL_NO_matchNr},如果想随机选取一个,只需要将

匹配数字设为0,使用${SOCIAL_NO}调用即可。

 

同类型博客推荐:

             

 

转载于:https://www.cnblogs.com/imyalost/p/6485754.html

你可能感兴趣的文章
FMX下Edit只能输入数字
查看>>
java根据模板生成pdf
查看>>
基础数据类型长度
查看>>
C# 4.0 并行计算部分
查看>>
利用jQuery选择器和jQuery中的DOM操作实现九宫格拼图
查看>>
iOS:项目重命名
查看>>
矩阵树定理学习笔记
查看>>
mysql依据某一张表的字段,查询出对应的表所在的数据库
查看>>
做了一个非竞价排名、有较详细信息的程序员职位 match 网站
查看>>
关于protell 99se原理图和PCB板入门
查看>>
取MS CRM表单的URL
查看>>
Build an ETL Pipeline With Kafka Connect via JDBC Connectors
查看>>
类操作,removeClass&addClass
查看>>
生成静态页
查看>>
多线程(三):检索线程对象
查看>>
005-快速展开博客园博客中折叠的代码
查看>>
iOS Modal
查看>>
史上最全的maven的pom.xml文件详解(转载)
查看>>
把查询的结果组织为一串字符(eg:板板鞋,兵乓球,篮球,足球)
查看>>
Eclipse下JRebel的安装和基本使用
查看>>