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

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

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

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