1、接口響應結果,通常為HTML、JSON格式的數據,對於HTML的響應結果的提取,可以通過正則表達式,也可以通過XPath 來提取。
2、對於JSON格式的數據,可以通過正則表達式、JSON Extractor插件、BeanShell 來提取。
如何通過JSON Extractor 插件來提取JSON響應結果。
需要下載插件,下載地址為:https://jmeter-plugins.org/wiki/JSONPathExtractor/
下載后解壓以后將lib和lib/ext中的jar包放到安裝目錄對應位置,重啟即可。
場景一:
需要提起的字符串是APP登錄接口的響應內容中的autoToken
Variable names : 名稱
JSONPath Expression:JSON表達式
Match Numbers:匹配哪個,可為空即默認第一個
Default Value:未取到值的時候默認值
這里因為返回的是json數據,$.data.autoToken
,獲取autoToken的值
調試:
場景1適合返回的json的autoToken只有一個的場景
場景2:
案例如下:
如果還是按照1中的方法
使用$.data.id
去提取id的值時,發現獲取到的數據為空
原來這個responses 的data為數組,故應為 $.data[0].id
提取第1個值
備注: JSON中 data 是一個對象數組, data[0] 代表取的是第一個數組的對象,data[*] 代表取全部對象。
.id 取的是id的值 .name取的是name的值
這里要分別取resources 和 trades 的所有id值,表達式可以寫:$.data.trades[*].id (代表trades下所有子集中的id)
jmeter后置處理器 JSON Extractor取多個變量值
1、需要獲取響應數據的請求右鍵添加-后置處理器-JSON Extractor
2、如果要獲取json響應數據多個值時,設置的Variable names (后續引用變量值的變量名設置)與JSON Path expressions及Default Values的數量一定要一致;
如json體如下:
{
"msg": "success", "code": "200", "data": { "total": 3, "aList": [ { "Time": 1501534900012, "id": 1 }, { "Time": 1501516732000, "id": 2 }
] } }
如上定義后,
Variable names設置為id1;id2
JSON Path expressions定義為$.data.aList[0].id;$.data.aList[1].id
Default Values:0;0
變量id1取值將為2,變量id2取值為3;若取不到id1的值會根據Default Values定義默認賦值為0
可以通過添加beanshell打印id1、id2的值驗證結果
print("id1:"+vars.get("id1"));
print("id2:"+vars.get("id2"));
以上是通過JSON Extractor插件提取的
下面通過正則提取: