一天一个关于测试知识点,5分钟内讲解你最关心的软件测试问题,今天就接着来谈谈关于软件测试中的“深入分析正则表达式提取器(一)”。
JMeter正则表达式提取器的配置项中,"Regular Expression","Template"与"Match No."这三个配置项是比较难以理解的,本文针对这三个配置项设置进行深入分析,以便大家能够游刃有余的使用其功能.
一、JMeter使用的正则表达式
JMeter包含模式匹配工具Apache Jakarta ORO,对应的jar包在JMeter安装目录下的lib\oro-2.0.8.jar.
Jakarta项目是在Apache软件基金会营运的开放源代码开发项目之一.开发着面向对象编程语言Java的程序库,框架等.其中的ORO是一组用于处理文本的Java类库,提供了与Perl5兼容的正则表达式功能.
二、正则表达式提取器中的Regular Expression
该配置项填写提取响应数据的正则表达式.
JMeter匹配文本时可以选择不分组捕获与分组捕获两种方式.
1.不分组捕获
当"Template"配置相中填写的是"$0$"时,"Regular Expression"配置项中可以没有(),表示不分组,返回整个匹配项.
如图所示:
2.分组捕获
当使用分组捕获时,"Regular Expression"配置项中则必须至少包含一组(),用以捕获一个或多个字符串.
一组()称为一个捕获组,并且捕获组可以嵌套.
每个捕获组都有一个编号与之对应,以方便引用捕获组匹配的内容.若有多个捕获组,编号规则为:
按照"("从左至右出现的先后顺序,从1开始依次递增进行编号: 1,2,3, ... ,n
还有一个额外编号为0的捕获组,用于表示匹配到的整个正则表达式字符串.
比如:
正则表达式: ((\d{4})-(\d{2})-(\d{2}))\s((\d{2}):(\d{2}):(\d{2}))
捕获组编号: 1 2 3 4 5 6 7 8
响应文本: Today is 2019-06-25 14:29:30,Tuesday
匹配后各捕获组对应的内容如下:
g1:2019-06-25
g2:2019
g3:06
g4:25
g5:14:29:30
g6:14
g7:29
g8:30
g0:2019-06-25 14:29:30
三、正则表达式提取器中的Template
"Template"用以设置捕获到的字符串以怎样的格式保存到JMeter变量中.可以原样保存,也可以格式化保存,下面讨论这两种情况.
1 原样保存捕获组字符串
在此项中,可以用$1$表示引用捕获组1中的内容,$2$表示引用捕获组2中的内容, ... ,$n$表示引用捕获组n中的内容,$0$表示引用正则表达式匹配后的整个字符串.
2 格式化保存捕获组字符串
除了使用$n$引用捕获组的内容外,还可以加入需要的字符,将匹配的内容按照某种格式保存.