使用场景
从前一个请求的响应结果中,提取到某些需要的内容,可以作为下一个接口需要的入参从而实现关联。例如:用户的登录登出。
Jmeter正则表达式提取器的界面(添加->后置处理器->正则表达式提取器)
参数解释:
-
引用名称:下一个请求要引用的参数名称,如填写token,则下一个请求接口可用${token}引用它。
-
正则表达式 :
():括起来的部分就是要提取的内容;
.:匹配任意字符串;
+:匹配一次或多次;
?:不要太贪婪,在找到第一个匹配项后停止匹配。
-
模板:用
$$
引用起来,如果在正则表达式字段中,文本框写了多个正则表达式,则可以是$2$、$3$
等等,表示提取到的第几个值给引用名称。如: 1 1 1表示匹配到的第1个值赋给引用名称。 -
匹配数字:0代表随机取值,1代表全部取值,通常情况下填0。
-
缺省值:如果正则表达式没有匹配到值,则使用此缺省值给引用名称。
-
PS:(.+?) 和 (.*?) 的区别:
(.+?)
提取1个字符串及以上,不要太贪婪,在找到第一个匹配项后停止;(.*?)
提取0个字符串及以上,要取的值是空值的时候可以取得到。
例如:“test":"",如果要取test的值,使用 (.+?) 匹配不到值。使用 (.*?)
则可以取到test的值为空,写法是: “test":"(.*?)"
。
Java正则表达式方法
这里就不对Java正则表达式的使用做基础学习了,下面列出了我们在进行“关联”操作时,需要掌握的基本元字符:
- ( ) :将 () 之间括起来的表达式定义为“组”(group),并且将匹配这个表达式的字符保存到一个临时区域,我们主要就是利用这个元字符配合所指定的字符串匹配规则来进行匹配信息的提取;
- .+: 一个以上的任意字符,通过Greediness(贪婪型)匹配策略进行表达式模板的匹配(最大匹配);
- .+?:通过?元字符表示一个非贪婪模式匹配,即通过 Reluctant(勉强型)匹配策略进行表达式模板的匹配(最小匹配);
另外,还包括.,.?,\d,\D,\w,\W等。
关于正则表达式的举例说明
1、提取单个字符串:
假设我们想要匹配Web页面的如下部分:name = “file” value = “readme.txt”
并要提取readme.txt。一个合适的正则表达式是:name = “file” value = “(.+?)”。我们可以这么写:引用名称:file
正则表达式:name = “file” value = “(.+?)”
模板:
$1$
readme.txt在需要引用的地方可以通过:${file}进行使用。
2、提取多个字符串:
假设我们想要匹配Web页面的如下部分:name = “file.name” value = “readme.txt”
并要提取file.name和readme.txt。一个合适的正则表达式是:name = “(.+?)” value= “(.+?)”。这样就会创建2个组,分别用于$1$
和$2$
。> >我们可以这么写:引用名称:file
正则表达式:name = “(.+?)” value = “(.+?)”
模板:
$1$$2$
如下变量的值将会被设定为:
file : file.namereadme.txt
file_g0 : name = “file.name” value = “readme.txt”
file_g1 : file.name
file_g2 : readme.txt
在需要引用的地方可以通过:${file}, ${file_g0},{file_g1},{file_g2}进行使用。
3、正则表达式中有转义符(例如: \ ?),需要进行转义:
例如:id?test":“1234” ,我们想要匹配出1234。
一个合适的正则表达式是: id?test\":"(.+?)"