zoukankan      html  css  js  c++  java
  • JMeter 后置处理器之正则表达式提取器详解

    后置处理器之正则表达式提取器详解

     

    by:授客 QQ:1033553122

     

    1. 添加正则表达式提取器

    右键线程组->添加->后置处理器->正则表达式提取器

     

     

     

    2. 提取器配置介绍

     

     

    说明:

    Apply to

    Main sample only - 仅作用于Main sample

     

    Sub-samples only - 仅作用于sub-sample

     

    Main sample and sub-samples - 作用于两者

     

    JMeter Variable - 仅作用于命名变量

     

    提取器按顺序,作用于所有满足条件的sample。比如有一个Main sampler和3个子sub-sample,每个都包含一个匹配正则表达的值,也就是说正则表达式总的匹配4个值。

    如果设置匹配数字为3,选择Sbu-samples only,提取器将匹配第三个sub-sample;

    如果设置匹配数字为3,选择Main sample and sub-samples,提取器将匹配第二个sub-sample;

     

    如果设置匹配数字为0,或者负数,提取器将处理所有满足的sample;

    如果设置匹配数字大于0,那么一旦找到足够匹配的将停止匹配

     

     

    Field to check(要检查的响应字段)

    Body - 响应体(包含请求头)

     

    Body (unescaped) - 所有html转义字符都被替换后的响应体。需要注意的是,jmeter不会根据上下文处理html转义字符,所以可能会有不正确替换,另外,该选项很影响性能,仅在绝对必要并且意识到其影响的情况下使用。

     

    Body as a Document - 通过Apache Tika,从各种类型的文档中提取文本。注意,该选项很影响性能

     

    Request Headers - 请求头,可能不适用非HTTP sample

     

    Response Headers - 响应头,可能不适合非HTTP sample

     

    URL

     

    Response Code - 响应状态码,比如 200

     

    Response Message - 响应消息,比如 OK

     

    引用名称

    用于存储结果的变量名称,自定义输入。需要注意的是,每个匹配组的名称为 refname_g#。其中 refname 为输入的变量名称, # 为组号。group0 为整个匹配, group1 为第1组

     

    正则表达式

    至少包含一组(),以捕获匹配的字符串,除非模板使用$0$

     

     

    模板

    $1$ 表示 group1

    $2$ 表示 group2

    $0$ 表示整个匹配的整个表达式

     

    匹配数字(0表示随机)

    0 表示随机

    大于0的正数N 表示选择第N个匹配的

    负数表示获取全部,供For Each 控制器使用

     

    正则表达式,模板和匹配数字的关系(个人理解)

    $0$  表示存储整个正则表达式匹配的值,分组名称:refname_g0 

    $1$,$2$,…,$N$ 分别存储正则表达式匹配到的第1组,第2组,…,第N组的值,即同正则表达式中,从左往右的每个括号“(……)”里的表达式匹配到的值一一对应,分组名称:refname_gN(此处,N为正整数)

     

    匹配数字N,代表了索引,从1开始,0表示随机,负数表示全部,需结合For Each 控制器使用。正则表达式可能会匹配多个值,所以每个组都可能会有多个匹配的值,所以,需要指定取哪个值(此处,N为0,整数)

     

    也就是说,$x$ 指定了从从哪个、哪些组取数据, 匹配数字指定了每个组中待取的目标值。注意,模板支持多个组,比如$1$$2$…$N$,对应的,${refname}的取值为每个组中对应索引值按模板顺序拼接后的值

     

    总之,默认情况下,${refname}的值,就是根据上述规则取的,当然我们可以通过 ${refname_g#}的方式,获取指定组中的数据,比如${refname_g0},${refname_g1},

    ${refname_g2}会根据匹配数字,分别从第0,1,2组中取对应的值。

     

     

     

    缺省值

    如果正则表达式没有匹配到值,则设置变量${var}为默认的值,否则引用了${var}的地方,不会替换${var}为对应的变量值。

     

    Use empty default value 如果勾选,则设置默认值为空字符串

     

    3. 例子

     

     

     

    HTTP2请求响应内容:

    {'bagNo': '94509771001', 'destDeptCode': '755AB'}{'bagNo': '94509772001', 'destDeptCode': '755CD'}{'bagNo': '94509773001', 'destDeptCode': '755EF'}

     

    以下是相同正则表达式下,不同模板及匹配数字下运行的不同结果:

    正则表达式:'bagNo': '(.+?)', 'destDeptCode': '(.+?)',

    实验1

    1、

    模板:$1$

    匹配数字:0

     

    ${value}取值:每次从94509771001,94509772001,94509773001三者中随机取一个

     

    2、

    模板:$1$

    匹配数字:1

     

    ${value}取值:94509771001

     

    3、

    模板:$1$

    匹配数字:2

     

    ${value}取值:94509772001

     

    实验2

    1、

    模板:$2$

    匹配数字:1

     

    ${value}取值:755AB

     

    2、

    模板:$2$

    匹配数字:2

     

    ${value}取值:755CD

     

    实验3

    1、

    模板:$1$$2$

    匹配数字:1

     

    ${value}取值:94509771001755AB 

    2、

    模板:$2$$1$

    匹配数字:2

    ${value}取值:755CD94509772001 

    实验4

    1、

    模板:$0$

    匹配数字:1

     

    ${value}取值:'bagNo': '94509771001', 'destDeptCode': '755AB', 

     

    2、

    模板:$0$

    匹配数字:2

     

    ${value}取值:'bagNo': '94509772001', 'destDeptCode': '755CD', 

     

     

    4. 正则表达式说明

    ():封装了待返回的匹配字符串。

    .:匹配任何字符串。

    +:一次或多次。

    ?:在找到第一个匹配项后停止

     

    5. 参考链接:

    http://jmeter.apache.org/usermanual/regular_expressions.html

     

    http://jmeter.apache.org/usermanual/component_reference.html#Regular_Expression_Extractor

     

     

     

     

  • 相关阅读:
    k-means聚类JAVA实例
    钓鱼站点以世界杯足球赛为饵,收集个人资料
    南桥--特殊回文数
    Oracle 数据文件管理
    hihoCoder #1142 : 三分求极值
    时间复杂度和空间复杂度[数据结构]
    poj 3635 Full Tank? ( 图上dp )
    FastQC结果详解
    毕业设计常见问题
    centos 查看USB接口的版本
  • 原文地址:https://www.cnblogs.com/shouke/p/10157491.html
Copyright © 2011-2022 走看看