91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jmeter學習指南之關聯

發布時間:2020-06-10 09:40:40 來源:網絡 閱讀:2500 作者:小強測試 欄目:軟件技術

JMeter后置處理器中的正則表達式提取器也是最常使用的一個元件,非常簡單方便,功能也很強大。


**在jmeter4.0中增加了Boundary Extractor元件,可以代替正則表達式提取器,而且使用更簡單更方便**

最近我在調腳本時對它又有了更深刻的認識,發現jmeter的每個看似普通的元件都做的非常出色,值得用心研究。在此總結個人經驗分享給大家。
jmeter學習指南之關聯

jmeter學習指南之關聯
應用場景:

      在一個線程組中,B請求需要使用A請求返回的數據,也就是常說的關聯,將上一個請求的響應結果作為下一個請求的參數,則需要對A請求的響應報文使用后置處理器,其中最方便最常用的就是正則表達式提取器了。

正則表達式提取器:

      允許用戶從作用域內的sampler請求的request或response中通過正則表達式提取值所需值,生成模板字符串,并將結果存儲到給定的變量名中。

各配置項介紹:

Apply to:作用范圍(返回內容的斷言范圍),一般情況下保持默認就行

1、Main sample and sub-samples:作用于主節點的取樣器及對應子節點的取樣器

2、Main sample only:僅作用于主節點的取樣器,默認選項

3、Sub-samples only:僅作用于子節點的取樣器

4、JMeter Variable:作用于jmeter變量(輸入框內可輸入jmeter的變量名稱),從指定變量值中提取需要的值。

Field to check:要檢查的響應報文的范圍

1、主體:響應報文的主體,最常用

2、Body(unescaped):主體,是替換了所有的html轉義符的響應主體內容,注意html轉義符處理時不考慮上下文,因此可能有不正確的轉換,不太建議使用 

3、Body as a Document:從不同類型的文件中提取文本,注意這個選項比較影響性能 

4、Response Headers:響應信息頭(如果你使用的是中文版的Jmeter,會看到這一項是信息頭,這是中文翻譯問題,應以英文為準)

5、Request Headers:請求信息頭

6、URL:請求url

7、Response Code:響應狀態碼,比如200、404等

8、Response Message:響應信息

***可以看出,這里已經提供了各種場景下的提取功能,非常全面!

引用名稱(Reference Name):

     Jmeter變量的名稱,存儲提取的結果;

     即下個請求需要引用的值、字段、變量名,后文中引用方法是${引用名稱}

正則表達式(Regular Expression):

      使用正則表達式解析響應結果,()括號表示提取字符串中的部分值,前后是提取的邊界內容。

***正則的基本使用方法可參考正則表達式的官方說明,本文下方也會有更詳細介紹。

模板(Template):正則表達式的提取模式

      如果正則表達式有多個提取結果,則結果是數組形式,模板$1$,$2$等等,表示把解析到的第幾個值賦給變量;從1開始匹配,以此類推。

     若只有一個結果,則只能是$1$;

匹配數字(Match No):

       正則表達式匹配數據的結果可以看做一個數組,表示如何取值:0代表隨機取值,正數n則表示取第n個值(比如1代表取第一個值),負數則表示提取所有符合條件的值。

缺省值:

     匹配失敗時候的默認值;通常用于后續的邏輯判斷,一般通常為特定含義的英文大寫組合,比如:ERROR等。

下面重點分析一下正則表達式的匹配規則及注意事項:

一、下面是常用的正則表達式操作符
jmeter學習指南之關聯
二、貪婪和非貪婪

提到正則表達式,必須要說一下匹配的兩種模式:貪婪和非貪婪。

1、貪婪與非貪婪模式是兩種不同的表達式匹配行為,貪婪模式在整個表達式匹配成功的前提下,盡可能多的匹配,而非貪婪模式在整個表達式匹配成功的前提下,盡可能少的匹配。

2、下面舉個例子,假設有如下響應結果(只截取了其中一部分):

"code":"0","msg":"請求成功","bizSeqNo":"1804242UD01154300109392900987311" ,"result":{"bizSeqNo":"1804242UD01154300109423800987316","transactionTime":"20180424094239"

3、現在從中提取bizSeqNo的值:

"bizSeqNo":"(.*)":貪婪模式,提取結果是:1804242UD01154300109392900987311" ,"result":{"bizSeqNo":"1804242UD01154300109423800987316","transactionTime":"20180424094239

"bizSeqNo":"(.*?)":非貪婪模式,提取結果是:1804242UD01154300109392900987311

大家可以自行體會一下其中的差別。

三、進階匹配問題

1、如何獲取數組結果?

如果有多個匹配的結果,則獲取到的是個數組,此時若要提取其中的內容,調用方式為${ bizSeqNo _1},${bizSeqNo _2}...,如果想要得到匹配出的結果的個數,用${bizSeqNo _matchNr},如果想隨機選取一個,只需要將匹配數字設為0,使用${bizSeqNo}調用即可。

2、如何獲取唯一的匹配結果?

如果想要避免上面獲取多種結果的情況,則需要注意把正則表達式寫成非貪婪模式,或者增加正則表達式的前后邊界,使結果唯一匹配既可。

最后告訴大家一個小技巧:

在調試過程中可結果察看結果樹和Debug PostProcessor來幫助分析結果。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

景谷| 忻城县| 当雄县| 原平市| 武城县| 九寨沟县| 东兴市| 秭归县| 灵武市| 石门县| 麟游县| 曲靖市| 洮南市| 和平区| 临泽县| 绥棱县| 东方市| 体育| 阳城县| 休宁县| 隆回县| 澄江县| 临高县| 精河县| 阿拉尔市| 中超| 深圳市| 灌南县| 额济纳旗| 格尔木市| 射洪县| 封丘县| 景谷| 新野县| 新乐市| 噶尔县| 进贤县| 巴楚县| 团风县| 正定县| 锦州市|