JMeter关联技术:正则表达式

也就是如图,我要提取JDBC Request的响应数据,那么这块儿就可以用到JMeter中的配置元件:正则表达式,进行上下文的关联

1、名称和注释:任意

2、Apply to(作用于)

(1)Main sample and sub-samples:父节点取样器及对应子节点取样器(2)Main sample only:仅作用于父节点取样器(3)Sub-samples only:仅作用于子节点取样器(4)JMeter Variable Name to use:作用于jmeter变量,输入框中输入变量名

3、要检查的响应字段:样本数据源

(1)主体: 接口响应主体内容,默认选择此项

(2)信息头:响应头的所有内容

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

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

(5)Request Headers:请求头的所有内容

(6)URL:是对sample的url进行匹配,也就是查看结果树里请求内容的第一行url,不包含data里的请求参数响应代码:http响应代码,如101,200,302,404,501等

(7)响应信息:http响应代码对应的响应信息,例如:OK, Found(HTTP/1.1 200 Ok;HTTP/1.1 302 Found)

4、引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的变量名

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

6、正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值

如何填这里的数据呢,以下是常用的正则表达式:

(1)JMeter中没有特殊的情况,用以下两个正则基本上可以解决多数问题:(.*?) 或用(.+?) #以任意字符开始,匹配上一个后停止匹配(注意括号要用小写())

7、模板(Template):提取正则表达式中的那个值

$1$ :提取第一个值

$2$:提取第二个值

8、匹配数字(Match No):正则表达式匹配数据的结果可以看做一个数组,表示如何取值

(1)0:表示随机取值

(2)负数:表示提取所有符合条件的值

(3)1:表示第一个值

9、缺省值:匹配失败时候的默认值;通常用于后续的逻辑判断,一般通常为特定含义的数据,比如:ERROR,NULL等

${name_pwd_g1}:提取第一个用户名的值

${name_pwd_g2}:提取第二个密码的值

JMeter中要注意作用域,选中线程组的话是,线程组的所有请求,因此我们选中“登录”这个请求后—》右键—-》添加—》定时器—》同步定时器,添加完成后如图

模拟用户组的数量:根据实际的情况填写,但要注意的是,超时单位为0时,用户组的数量要与线程组的数据匹配。例如:模拟用户数为2,线程组可以任意2的整数倍,2,4,6,8等都可以,但线程组中为7的话,因为没有设置超时机制,执行过程中会一直等待下一个数据的到来(第8个数据)

超时时间以毫秒为单位:最好设置超时机制,如果为0的话是没有超时机制,遇到以上用户数为2,线程数为7的情况下就会一直等待

四、最终结果要添加:察看结果树 进行调试,聚合报告为总的结果显示(如图添加请参考)

Excel VBA入门教程 1.7 正则表达式

在VBA中使用正则表达式,因为正则表达式不是vba自有的对象, 故此要用它就必须采用两种方式引用它:一种是前期绑定,另外一种是后期绑定。

前期绑定:就是手工勾选工具/引用中的Microsoft VBScript Regular Expressions 5.5; 然后在代码中定义对象:Dim regExp As New RegExp;后期绑定:使用CreateObject方法定义对象:CreateObject(\”vbscript.regexp\”)

RegExp对象的属性:

  • Global – 设置或返回一个Boolean值,该值指明在整个搜索字符串时模式是全部匹配还是只匹配第一个。如果搜索应用于整个字符串,Global 属性的值应该为 True,否则其值为 False。默认的设置为True。
  • Multiline – 返回正则表达式是否具有标志, 缺省值为False。如果指定的搜索字符串分布在多行,这个属性是要设置为True的。
  • IgnoreCase – 设置或返回一个Boolean值,指明模式搜索是否区分大小写。如果搜索是区分大小写的,则IgnoreCase 属性应该为False;否则应该设为True。缺省值为True。
  • Pattern – 设置或返回被搜索的正则表达式模式。被搜索的正则字符串表达式。它包含各种正则表达式字符。

RegExp对象的方法:

  • Execute – 对指定的字符串执行正则表达式搜索。需要传入要在其上执行正则表达式的文本字符串。正则表达式搜索的设计模式是通过RegExp对象的Pattern来设置的。Execute方法返回一个Matches集合,其中包含了在string中找到的每一个匹配的Match对象。如果未找到匹配,Execute将返回空的Matches集合。
  • Replace – 替换在正则表达式查找中找到的文本。
  • Test – 对指定的字符串执行一个正则表达式搜索,并返回一个Boolean值指示是否找到匹配的模式。Global属性对Test方法没有影响。如果找到了匹配的模式,Test方法返回True;否则返回False。
  • MatchCollection对象与Match对象 匹配到的所有对象放在MatchCollection集合中,这个集合对象只有两个只读属性:
  • Count:匹配到的对象的数目
  • Item:集合的又一通用方法,需要传入Index值获取指定的元素。 一般,可以使用ForEach语句枚举集合中的对象。集合中对象的类型是Match。
  • Match对象有以下几个只读的属性:FirstIndex – 匹配字符串在整个字符串中的位置,值从0开始。Length – 匹配字符串的长度。Value – 匹配的字符串。SubMatches – 集合,匹配字符串中每个分组的值。作为集合类型,有Count和Item两个属性。

Sample Code(前期绑定):

Sample Code(后期绑定):

VBA编程神器 VBA代码助手 可以极大提高编程速度,降低编程门槛欢迎使用

私信回复 代码助手 即可获得

用法 输入 字典+空格 即可看到如下提示 也可输入 dic+空格 zd+空格 均可得到提示

本提示数据库可完全自定义!

更多功能请大家探索

本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com

点赞 0
收藏 0

文章为作者独立观点不代本网立场,未经允许不得转载。