http://desert3.iteye.com/blog/1394934html
一、http://www.cnblogs.com/quange/archive/2010/06/11/1756260.html
二、http://blog.csdn.net/zhangren07/archive/2010/10/15/5944158.aspx正则表达式
<input type="hidden" name="hidName" value="(.*)"> // 提取HTML中隐藏域的值.net
^(.*)$ // 提取整个response返回htm
<input value="(.+?)".*\n.*My Label // 提取My Label关联的input的值blog
<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正则表达式提取器的使用方法。
一、添加Jmeter正则表达式提取器:在具体的Request下添加Jmeter正则表达式提取器(Jmeter正则表达式在“后置处理器”下面)
二、Jmeter正则表达式提取器控制面板,截图以下:get
位置1:名称及注释
位置2:正则表达式提取内容的范围。(关于各字段的详细说明请查阅协议的相关说明)
位置3:正则表达式提取的相关设置 input
一、在使用正则表达式提取器的过程当中,若是匹配数字选择的是-1,还能够经过${str_1}的方式来取第1个匹配的内容,${str_2}来取第2个匹配的内容。
二、关于正则*和*?是不同的,在上述的例子中使用正则<title>(.*?)</title>或者正则<title>(.*)</title>都是可行的。这个是正则中的贪婪与非贪婪模式。it
(1)引用名称:下一个请求要引用的参数名称,如填写title,则可用${title}引用它。io
(2)正则表达式:
():括起来的部分就是要提取的。
(3)模板:用$$引用起来,若是在正则表达式中有多个正则表达式,则能够是$2$$3$等等,表示解析到的第几个值给title。如:$1$表示解析到的第1个值
(4)匹配数字:0表明随机取值,1表明所有取值,一般状况下填0
(5)缺省值:若是参数没有取获得值,那默认给一个值让它取。
关于正则表达式的举例说明:
一、提取单个字符串:
假如想匹配Web页面的以下部分:name = "file" value = "readme.txt">并提取readme.txt。一个合适的正则表达式:name = "file" value = "(.+?)">。
():封装了待返回的匹配字符串。
.:匹配任何单个字符串。
+:一次或屡次。
?:不要太贪婪,在找到第一个匹配项后中止。
二、提取多个字符串:
假如想匹配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进行使用。