JMeter(七)_关联之正则表达式提取器
应用场景:
在一个线程组中,从前一个请求的响应结果中,提取到某些需要的内容,可以作为下一个接口需要的入参从而实现关联
添加路径:HTTP请求->添加->后置处理器->正则表达式提取器
说明
下面是JMeter-正则表达式提取器的界面
后置处理器:在请求结束或者返回响应结果时发挥作用
正则表达式提取器:允许用户从服务器的响应中通过使用perl的正则表达式提取值。该元素会作用在指定范围取样器,用正则表达式提取所需值,生成模板字符串,并将结果存储到给定的变量名中。
**APPly to:**作用范围(返回内容的断言范围)
- Main sample and sub-samples:作用于父节点的取样器及对应子节点的取样器
- Main sample only:仅作用于父节点的取样器
- Sub-samples only:仅作用于子节点的取样器
- JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)
要检查的响应字段:需要检查的响应报文的范围
- 主体:Response Body,响应数据主体
- Body(unescaped): 主体,响应的主体内容且替换了所有的html转义符,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用
- Body as a Document:从不同类型的文件中提取文本,注意这个选项比较影响性能
- Response Headers:响应信息头
- Request Headers: 请求信息头
- URL:统一资源定位符,即Internet上用来描述信息资源的字符串
- Response Code: 响应状态码,比如:200、404等
- Response Message: 响应信息,比如:OK
引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的值、字段、变量名(例子中我提取的是SOCIAL_NO)
引用方法:${xxx}
正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值
模板(Template): 用$$引用起来,如果在正则表达式字段中,文本框写了多个正则表达式,则可以是$2$$3$等等,表示提取到的第几个值给引用名称。如:$1$表示匹配到的第1个值赋给引用名称。
匹配数字(Match No):正则表达式匹配数据的结果可以看做一个数组,表示如何取值:0代表随机取值,正数n则表示取第n个值(比如1代表取第一个值),负数则表示提取所有符合条件的值。
缺省值:匹配失败时候的默认值;通常用于后续的逻辑判断,一般通常为特定含义的英文大写组合,比如:ERROR
正则表达式的举例说明:
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\“:”(.+?)”