簡介
如果有這樣的情況:一個完整的操作流程简烘,需要先完成某個操作烹卒,獲得某個值或數(shù)據(jù)信息嘴秸,然后才能進(jìn)行下一步的操作(也就是常說的關(guān)聯(lián)/將上一個請求的響應(yīng)結(jié)果作為下一個請求的參數(shù))措嵌;
在jmeter中,可以利用正則表達(dá)式提取器來幫助我們完成這一動作
正則表達(dá)式提取器界面
操作
后置處理器:在請求結(jié)束或者返回響應(yīng)結(jié)果時發(fā)揮作用
正則表達(dá)式提取器:允許用戶從服務(wù)器的響應(yīng)中通過使用perl的正則表達(dá)式提取值蔬捷。該元素會作用在指定范圍取樣器,用正則表達(dá)式提取所需值榔袋,生成模板字符串周拐,并將結(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)
引用方法:引用方法:${引用名稱}
正則表達(dá)式(Regular Expression):使用正則表達(dá)式解析響應(yīng)結(jié)果,“()”表示提取字符串中的部分值生真,請不要使用“||”沉噩,除非你本身需要匹配這個字符。
下面是常用的正則表達(dá)式操作符:
模板(Template):從匹配的結(jié)果中創(chuàng)建一個字符串柱蟀,這是通過正則表達(dá)式匹配出來的一組值川蒙,意為使用提取到的第幾個值(可能有多個值匹配,因此使用模板)长已;從1開始匹配畜眨,以此類推.
參數(shù)可以在取值模板組合使用,例如:“1-2”作為模板得到的值是使用“-”連接的第一個待匹配內(nèi)容與第二個待匹配內(nèi)容組合而成的字符串术瓮。
匹配數(shù)字(Match No):正則表達(dá)式匹配數(shù)據(jù)的結(jié)果可以看做一個數(shù)組康聂,表示如何取值:0代表隨機(jī)取值,正數(shù)n則表示取第n個值(比如1代表取第一個值)胞四,負(fù)數(shù)則表示提取所有符合條件的值恬汁。
缺省值:匹配失敗時候的默認(rèn)值;通常用于后續(xù)的邏輯判斷辜伟,一般通常為特定含義的英文大寫組合氓侧,比如:ERROR
最后,根據(jù)上面的說明游昼,完成配置甘苍,然后可以先添加一個監(jiān)視器(查看結(jié)果樹),檢查是否取到了對應(yīng)的值烘豌;
提取到的參數(shù)载庭,調(diào)用時用${SOCIAL_NO_1},${SOCIAL_NO_2}...廊佩,如果想要得到匹配出的參數(shù)的個數(shù)囚聚,用${SOCIAL_NO_matchNr},如果想隨機(jī)選取一個标锄,只需要將
匹配數(shù)字設(shè)為0顽铸,使用${SOCIAL_NO}調(diào)用即可。
XPath Extractor界面
操作
XPath Extractor的使用方法與正則表達(dá)式提取器(Regular Expression Extractor)類似料皇,只不過該Expression中指定的不是正則表達(dá)式谓松,而是給定的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:當(dāng)需要處理的頁面是HTML格式時,必須選中該選項鬼譬;如果是XML或XHTML格式(例如RSS返回)娜膘,則取消選中;
Quiet表示只顯示需要的HTML頁面优质,Report errors表示顯示響應(yīng)報錯竣贪,Show warnings表示顯示警告;
Use Namespaces:如果啟用該選項巩螃,后續(xù)的XML解析器將使用命名空間來分辨演怎;
Validate XML:根據(jù)頁面元素模式進(jìn)行檢查解析;
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表達(dá)式扇住。
Default Value:參數(shù)的默認(rèn)值春缕。
PS:XPath是XML/XHTML中常用的選取給定節(jié)點和節(jié)點集的方法。
總結(jié)
正則表達(dá)式提取器和XPath Extractor的區(qū)別:
①正則表達(dá)式提取器可以用于對頁面任何文本的提取艘蹋,提取的內(nèi)容是根據(jù)正則表達(dá)式在頁面內(nèi)容中進(jìn)行文本匹配锄贼;
②XPath Extractor則可以提取返回頁面任意元素的任意屬性;
③如果需要提取的文本是頁面上某元素的屬性值女阀,建議使用XPath Extractor;
④如果需要提取的文本在頁面上的位置不固定宅荤,或者不是元素的屬性,建議使用正則表達(dá)式提取器浸策。