簡介
如果有這樣的情況:一個完整的操作流程,需要先完成某個操作,獲得某個值或數(shù)據(jù)信息,然后才能進行下一步的操作(也就是常說的關(guān)聯(lián)/將上一個請求的響應(yīng)結(jié)果作為下一個請求的參數(shù));
在jmeter中,可以利用正則表達式提取器來幫助我們完成這一動作
正則表達式提取器界面

操作
后置處理器:在請求結(jié)束或者返回響應(yīng)結(jié)果時發(fā)揮作用
正則表達式提取器:允許用戶從服務(wù)器的響應(yīng)中通過使用perl的正則表達式提取值。該元素會作用在指定范圍取樣器,用正則表達式提取所需值,生成模板字符串,并將結(jié)果存儲到給定的變量名中。
APPly to:作用范圍(返回內(nèi)容的斷言范圍)
Main sample and sub-samples:作用于父節(jié)點的取樣器及對應(yīng)子節(jié)點的取樣器
Main sample only:僅作用于父節(jié)點的取樣器
Sub-samples only:僅作用于子節(jié)點的取樣器
JMeter Variable:作用于jmeter變量(輸入框內(nèi)可輸入jmeter的變量名稱)
要檢查的響應(yīng)字段:需要檢查的響應(yīng)報文的范圍
主體:響應(yīng)報文的主體
Body(unescaped):主體,響應(yīng)的主體內(nèi)容且替換了所有的html轉(zhuǎn)義符,注意html轉(zhuǎn)義符處理時不考慮上下文,因此可能有不正確的轉(zhuǎn)換,不太建議使用
Body as a Document:從不同類型的文件中提取文本,注意這個選項比較影響性能
Response Headers:響應(yīng)信息頭
Request Headers:請求信息頭
URL:統(tǒng)一資源定位符,即Internet上用來描述信息資源的字符串
Response Code:響應(yīng)狀態(tài)碼,比如200、404等
Response Message:響應(yīng)信息
引用名稱(Reference Name):Jmeter變量的名稱,存儲提取的結(jié)果;即下個請求需要引用的值、字段、變量名(例子中我提取的是SOCIAL_NO)
引用方法:引用方法:${引用名稱}
正則表達式(Regular Expression):使用正則表達式解析響應(yīng)結(jié)果,“()”表示提取字符串中的部分值,請不要使用“||”,除非你本身需要匹配這個字符。
下面是常用的正則表達式操作符:

模板(Template):從匹配的結(jié)果中創(chuàng)建一個字符串,這是通過正則表達式匹配出來的一組值,意為使用提取到的第幾個值(可能有多個值匹配,因此使用模板);從1開始匹配,以此類推.
參數(shù)可以在取值模板組合使用,例如:“1-2”作為模板得到的值是使用“-”連接的第一個待匹配內(nèi)容與第二個待匹配內(nèi)容組合而成的字符串。
匹配數(shù)字(Match No):正則表達式匹配數(shù)據(jù)的結(jié)果可以看做一個數(shù)組,表示如何取值:0代表隨機取值,正數(shù)n則表示取第n個值(比如1代表取第一個值),負數(shù)則表示提取所有符合條件的值。
缺省值:匹配失敗時候的默認值;通常用于后續(xù)的邏輯判斷,一般通常為特定含義的英文大寫組合,比如:ERROR
最后,根據(jù)上面的說明,完成配置,然后可以先添加一個監(jiān)視器(查看結(jié)果樹),檢查是否取到了對應(yīng)的值;
提取到的參數(shù),調(diào)用時用${SOCIAL_NO_1},${SOCIAL_NO_2}...,如果想要得到匹配出的參數(shù)的個數(shù),用${SOCIAL_NO_matchNr},如果想隨機選取一個,只需要將
匹配數(shù)字設(shè)為0,使用${SOCIAL_NO}調(diào)用即可。
XPath Extractor界面

操作
XPath Extractor的使用方法與正則表達式提取器(Regular Expression Extractor)類似,只不過該Expression中指定的不是正則表達式,而是給定的XPath路徑。
APPly to:作用范圍(返回內(nèi)容的斷言范圍)
Main sample and sub-samples:作用于父節(jié)點的取樣器及對應(yīng)子節(jié)點的取樣器
Main sample only:僅作用于父節(jié)點的取樣器
Sub-samples only:僅作用于子節(jié)點的取樣器
JMeter Variable:作用于jmeter變量(輸入框內(nèi)可輸入jmeter的變量名稱)
XML Parsing Options:要解析的XML參數(shù)
Use Tidy:當需要處理的頁面是HTML格式時,必須選中該選項;如果是XML或XHTML格式(例如RSS返回),則取消選中;
Quiet表示只顯示需要的HTML頁面,Report errors表示顯示響應(yīng)報錯,Show warnings表示顯示警告;
Use Namespaces:如果啟用該選項,后續(xù)的XML解析器將使用命名空間來分辨;
Validate XML:根據(jù)頁面元素模式進行檢查解析;
Ignore Whitespace:忽略空白內(nèi)容;
Fetch external DTDs:如果選中該項,外部將使用DTD規(guī)則來獲取頁面內(nèi)容;
Return entire XPath fragment of text content:返回文本內(nèi)容的整個XPath片段;
Reference Name:存放提取出的值的參數(shù)。
XPath Query:用于提取值的XPath表達式。
Default Value:參數(shù)的默認值。
PS:XPath是XML/XHTML中常用的選取給定節(jié)點和節(jié)點集的方法。
總結(jié)
正則表達式提取器和XPath Extractor的區(qū)別:
①正則表達式提取器可以用于對頁面任何文本的提取,提取的內(nèi)容是根據(jù)正則表達式在頁面內(nèi)容中進行文本匹配;
②XPath Extractor則可以提取返回頁面任意元素的任意屬性;
③如果需要提取的文本是頁面上某元素的屬性值,建議使用XPath Extractor;
④如果需要提取的文本在頁面上的位置不固定,或者不是元素的屬性,建議使用正則表達式提取器。