通过正则表达式来提取数据。
在正则表达式提取器中:
() 括起来的部分就是要提取的内容
. 匹配任何字符串
+ 一次或多次
? 不要太贪婪,在找到第一个匹配项后就停止
参数说明:
Apply to:作用域(在HTTP请求中可能存在自动重定向、提取页面嵌入资源的情况,都会导致有主取样器和子取样器的情况)
l main sample and sub-samples:作用于父节点取样器及对应子节点取样器
l main sample only:仅作用于父节点取样器
l sub-samples only:仅作用于子节点取样器
l Jmeter variable name to use:作用于jmeter变量(输入框内填写jmeter变量名称)
要检查的响应字段:即从哪里取值
l Body:响应报文体,最常用
l Body(unescaped):转义的响应体,是替换了所有的html转义符的响应主体内容,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用
l Body as a document:从不同类型的文件中提取文本,注意这个选项比较影响性能
l Response headers:响应信息头(如果你使用的是中文版的Jmeter,会看到这一项是信息头,这是中文翻译问题,应以英文为准)
l Request headers:请求信息头
l URL:请求url
l Response code:响应状态码,比如200、404等
l Response message:响应信息。比如处理成功返回的“成功”或“OK”字样
引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的值、字段、变量名,后文中引用方法是${引用名称}
正则表达式(Regular Expression):使用正则表达式解析响应结果,()括号表示提取字符串中的部分值,前后是提取的边界内容。
模板(Template):正则表达式的提取模式。如果正则表达式有多个提取结果,则结果是数组形式,模板$1$,$2$等等,表示把解析到的第几个值赋给变量;从1开始匹配,以此类推。
若只有一个结果,则只能是$1$。($1$指第一个模板,$2$指第二个模板,$0$指全文匹配)
匹配数字(Match No)(0代表随机):正则表达式匹配数据的结果可以看做一个数组,表示如何取值:0代表随机取值,正数n则表示取第n个值(比如1代表取第一个值);负数则表示提取所有符合条件的值(可以与for each controller一起使用来遍历)。----主要作用于成功匹配到的结果有多组的情况下,用来选择将第几个匹配到的结果赋给引用变量。
缺省值(Default Value):匹配失败时候的默认值;通常用于后续的逻辑判断,一般通常为特定含义的英文大写组合,比如:ERROR等。
示例-关于模板和匹配数字:
待提取响应数据:
"username"="beyondhd1","passwd"="123456p1"
"username"="beyondhd2","passwd"="123456p2"
情况1:正则表达式:"username"="(.+?)","passwd"="123456"
模板 | 匹配数字 | ${A} | ${A_g0} | ${A_g1} |
$0$ | 1 | "username"="beyondhd1","passwd"="123456" | "username"="beyondhd1","passwd"="123456" | beyondhd1 |
$0$ | 2 | "username"="beyondhd2","passwd"="123456" | "username"="beyondhd2","passwd"="123456" | beyondhd2 |
$1$ | 1 | beyondhd1 | "username"="beyondhd1","passwd"="123456" | beyondhd1 |
$1$ | 2 | beyondhd2 | "username"="beyondhd2","passwd"="123456" | beyondhd2 |
$2$ | 1 | null | "username"="beyondhd1","passwd"="123456" | beyondhd1 |
$2$ | 2 | null | "username"="beyondhd2","passwd"="123456" | beyondhd2 |
情况2:正则表达式:"username"="(.+?)","passwd"="(.+?)"
模板 | 匹配数字 | ${B} | ${B_g0} | ${B_g1} | ${B_g2} |
$0$ | 1 | "username"="beyondhd1","passwd"="123456" | "username"="beyondhd1","passwd"="123456" | beyondhd1 | 123456 |
$0$ | 2 | "username"="beyondhd2","passwd"="123456" | "username"="beyondhd2","passwd"="123456" | beyondhd2 | 123456 |
$1$ | 1 | beyondhd1 | "username"="beyondhd1","passwd"="123456" | beyondhd1 | 123456 |
$1$ | 2 | beyondhd2 | "username"="beyondhd2","passwd"="123456" | beyondhd2 | 123456 |
$2$ | 1 | 123456 | "username"="beyondhd1","passwd"="123456" | beyondhd1 | 123456 |
$2$ | 2 | 123456 | "username"="beyondhd2","passwd"="123456" | beyondhd2 | 123456 |
$1$$2$ | 1 | beyondhd1123456 | "username"="beyondhd1","passwd"="123456" | beyondhd1 | 123456 |
$1$$2$ | 2 | beyondhd2123456 | "username"="beyondhd2","passwd"="123456" | beyondhd2 | 123456 |
总结:引用正则表达式提取器的结果时,有两种方法
方法1:准确填写模板,使用${引用名称}
方法2:使用${引用名称_g1}或${引用名称_g2},即调用第1个提取结果还是第2个提取结果(即对应正则表达式中的第几个圆括号)