zoukankan      html  css  js  c++  java
  • jmeter正则表达式提取器--关联

    http://desert3.iteye.com/blog/1394934

    1、http://www.cnblogs.com/quange/archive/2010/06/11/1756260.html

    2、http://blog.csdn.net/zhangren07/archive/2010/10/15/5944158.aspx

    <input type="hidden" name="hidName" value="(.*)">   // 提取HTML中隐藏域的值


    ^(.*)$    // 提取整个response返回

     
    <input value="(.+?)".* .*My Label   // 提取My Label关联的input的值

    <input value="radio43" type="radio" name="myradio" id="long_nested_path"/> 
    <label for="long_nested_path">My Label</label> 

    "(.+:create:.+?)"                           // 提取下面link的href的值 
    <a href="?wicket:interface=:4:create::ILinkListener:"> 


    JSESSIONID=(.*);Path=/              // 从Response的Headers中抓取Cookie JSESSIONID的值
    Set-Cookie: JSESSIONID=(.*?);    // 从Headers抓取JSESSIONID,非贪婪 


    运用Jmeter正则提取器,可以从请求的响应结果中取到需要的内容,从而实现关联。本质上来说,它是使用正则表达式的提取模式来实现的。

    下面简单介绍一下Jmeter正则表达式提取器的使用方法。 

    1、添加Jmeter正则表达式提取器:在具体的Request下添加Jmeter正则表达式提取器(Jmeter正则表达式在“后置处理器”下面) 
    2、Jmeter正则表达式提取器控制面板,截图如下:



    位置1:名称及注释 
    位置2:正则表达式提取内容的范围。(关于各字段的详细说明请查阅协议的相关说明) 
    位置3:正则表达式提取的相关设置 

    • 引用名称:其他地方引用提取值的变量名称,如填写的是:str,具体的引用方式是${str}
    • 正则表达式:提取内容的正则表达式【稍注意一下:()表示提取,对于你要提前的内容需要用小括号括起来】
    • 模板:用$$引用起来,如果在正则表达式中有多个提取表达式(多个括号括起来的东东),则可以是$1$,$2$等等,表示解析到的第几个值给str,正则表达式的提取模式,值从1开始,值0对应的是整个匹配的表达式 如对于表达式s(.*) 值0对应str,值1对应tr
    • 匹配数字(0代表随机):0代表随机,-1代表所有,其余正整数代表将在已提取的内容中,第几个匹配的内容。
    • 缺省值:正则匹配失败时,取的值


    1、在使用正则表达式提取器的过程中,如果匹配数字选择的是-1,还可以通过${str_1}的方式来取第1个匹配的内容,${str_2}来取第2个匹配的内容。
    2、关于正则*和*?是不一样的,在上述的例子中使用正则<title>(.*?)</title>或者正则<title>(.*)</title>都是可行的。这个是正则中的贪婪与非贪婪模式。

          (1)引用名称:下一个请求要引用的参数名称,如填写title,则可用${title}引用它。

      (2)正则表达式:

        ():括起来的部分就是要提取的。

        .:匹配任何字符串。
        +:一次或多次。
        ?:不要太贪婪,在找到第一个匹配项后停止。

      (3)模板:用$$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$$3$等等,表示解析到的第几个值给title。如:$1$表示解析到的第1个值

      (4)匹配数字:0代表随机取值,1代表全部取值,通常情况下填0

      (5)缺省值:如果参数没有取得到值,那默认给一个值让它取。

    关于正则表达式的举例说明:

      1、提取单个字符串:
        假如想匹配Web页面的如下部分:name = "file" value = "readme.txt">并提取readme.txt。一个合适的正则表达式:name = "file" value = "(.+?)">。
          ():封装了待返回的匹配字符串。
          .:匹配任何单个字符串。
          +:一次或多次。
          ?:不要太贪婪,在找到第一个匹配项后停止。

      2、提取多个字符串:
        假如想匹配Web页面的如下部分:name = "file.name" value = "readme.txt">并提取file.name和readme.txt。一个合适的正则表达式:name = "(.+?)" value = "(.+?)"。这样就会创建2个组,分别用于$1$和$2$

      比如:

        引用名称:MYREF
        模板:$1$$2$

       如下变量的值将会被设定:
        MYREF:     file.namereadme.txt
        MYREF_g0:   name = "file.name"value = "readme.txt"
        MYREF_g1:  file.name
        MYREF_g2:  readme.txt

      在需要引用地方可以通过:${MYREF}, ${MYREF_g1进行使用。

  • 相关阅读:
    The 2019 ICPC Asia Shanghai Regional Contest H Tree Partition k、Color Graph
    回溯法、子集树、排列树、满m叉树
    顺时针打印矩阵
    单调递增的数字
    nodejs
    nodejs + express + mangodb 项目搭建
    nodejs + express 项目初始化
    星星评分功能(带小数点的那种,5颗星,10分制)
    easyui 增加删除toolbar 显示异常问题
    sql 外键级联,触发器防删
  • 原文地址:https://www.cnblogs.com/shengs/p/5010745.html
Copyright © 2011-2022 走看看