一、應用場景說明:
在一個線程組中,B請求需要使用A請求返回的數據,也就是常說的關聯,將上一個請求的響應結果作為下一個請求的參數,則需要對A請求的響應報文使用后置處理器,其中最方便最常用的就是正則表達式提取器了。
1、實例一:提取token
1)A請求響應結果:
{"code":"0","msg":"OK","info":{"token":"eyJuYW1lIjoi5pu-6LC35bmzIiwic3lzdGVtIjoiVUxQIiwiZXhwaXJhdGlvbkRhdGUiOjE2MDUzNjQzOTN9.hrTSbOOb_IF6W4c2zArVy1ZF6PgPz5zBXs5fcJdz0r2WZjhP8Cou0UWlADWMnRHRi5kYuzSsrDw2THGuTaYtqQkS4bD7ua7MW47PajfcBxv7qMseU7MI17wSuI73csilstzqq6n9xHEBRf1KfjpE7NGAxV2Po4T_lFlTYsN6Emyq8NW9d5evA8Fz4OwX0VjCSDQwuKH_G2-lK4kTSBk2YHL8i57HKEdlOGaMR5vv6Mc4yoDRJyAEZjdrXVHtUzsIOQOopZSQcX-tdcc7gUPFjzOCKZI3vVbnchVjWS2_pqUh4KhSqEk7R3MawWhYiOxpLIcCnAMKVLjOureTexFIHg","user":{"id":3764,"name":"張三}}
2)A請求正則表達式寫法如下:
3)B請求引用A請求正則表達式提取的值:
2、實例二:提取orderId
1)A請求響應結果:{"code":"0","msg":"","info":{"count":1,"list":[{"uuid":"78252251:","orderId":78252251,"orderNo":"78252251","subOrderId":"","orderNumber":null}
2)A請求正則表達式寫法如下:
注:如果想把響應結果的所有orderId都提取出來的話,匹配數字字段填-1即可
3)B請求引用A請求正則表達式提取的值:這里就不貼圖了,同上,直接用${}引用即可
3、實例三:提取url的token
4、實例四:提取字段中的某個字符
二、正則表達式提取器:
允許用戶從作用域內的sampler請求的服務器響應結果中通過正則表達式提取值所需值,生成模板字符串,並將結果存儲到給定的變量名中。
三、各配置項介紹:
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:響應信息
正則匹配:
1、引用名稱(Name of created variable):
Jmeter變量的名稱,存儲提取的結果;即下個請求需要引用的值、字段、變量名,后文中引用方法是$
2、正則表達式(Regular Expression):
使用正則表達式解析響應結果,()括號表示提取字符串中的部分值,前后是提取的邊界內容。
3、模板(Template):正則表達式的提取模式。
如果正則表達式有多個提取結果,則結果是數組形式,模板$1$,$2$等等,表示把解析到的第幾個值賦給變量;從1開始匹配,以此類推。
若只有一個結果,則只能是$1$;
4、匹配數字(Match No):
正則表達式匹配數據的結果可以看做一個數組,表示如何取值:0代表隨機取值,正數n則表示取第n個值(比如1代表取第一個值),負數則表示提取所有符合條件的值。
5、缺省值:
匹配失敗時候的默認值;通常用於后續的邏輯判斷,一般通常為特定含義的英文大寫組合,比如:ERROR等。
四、下面重點分析一下正則表達式的匹配規則及注意事項:
1、下面是常用的正則表達式操作符

2、貪婪和非貪婪
提到正則表達式,必須要說一下匹配的兩種模式:貪婪和非貪婪。
貪婪與非貪婪模式是兩種不同的表達式匹配行為,貪婪模式在整個表達式匹配成功的前提下,盡可能多的匹配,而非貪婪模式在整個表達式匹配成功的前提下,盡可能少的匹配。
1)下面舉個例子,假設有如下響應結果(只截取了其中一部分):
"code":"0","msg":"請求成功","bizSeqNo":"1804242UD01154300109392900987311" ,"result":{"bizSeqNo":"1804242UD01154300109423800987316","transactionTime":"20180424094239"
2)現在從中提取bizSeqNo的值:
"bizSeqNo":"(.*)":貪婪模式,提取結果是:1804242UD01154300109392900987311" ,"result":{"bizSeqNo":"1804242UD01154300109423800987316","transactionTime":"20180424094239
"bizSeqNo":"(.*?)":非貪婪模式,提取結果是:1804242UD01154300109392900987311
3、進階匹配問題
1)如何獲取數組結果?
如果有多個匹配的結果,則獲取到的是個數組,此時若要提取其中的內容,調用方式為${ bizSeqNo _1},$...,如果想要得到匹配出的結果的個數,用$,如果想隨機選取一個,只需要將匹配數字設為0,使用$調用即可。
2)如何獲取唯一的匹配結果?
如果想要避免上面獲取多種結果的情況,則需要注意把正則表達式寫成非貪婪模式,或者增加正則表達式的前后邊界,使結果唯一匹配既可。
注:在調試過程中可結果察看結果樹和Debug PostProcessor來幫助分析結果。