jmeter正則表達式提取器--關聯

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

  • 引用名稱:其餘地方引用提取值的變量名稱,如填寫的是:str,具體的引用方式是${str}
  • 正則表達式:提取內容的正則表達式【稍注意一下:()表示提取,對於你要提早的內容須要用小括號括起來】
  • 模板:用$$引用起來,若是在正則表達式中有多個提取表達式(多個括號括起來的東東),則能夠是$1$,$2$等等,表示解析到的第幾個值給str,正則表達式的提取模式,值從1開始,值0對應的是整個匹配的表達式 如對於表達式s(.*) 值0對應str,值1對應tr
  • 匹配數字(0表明隨機):0表明隨機,-1表明全部,其他正整數表明將在已提取的內容中,第幾個匹配的內容。
  • 缺省值:正則匹配失敗時,取的值


一、在使用正則表達式提取器的過程當中,若是匹配數字選擇的是-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進行使用。

相關文章
相關標籤/搜索