掌握BeanShell,輕鬆處理jmeter中的資料

季沐測試筆記發表於2021-10-19

作者:季沐測試筆記
原文地址https://www.cnblogs.com/testero/p/15425776.html
部落格主頁https://www.cnblogs.com/testero

1、BeanShell

BeanShell是java編寫的一個輕量級的指令碼語言,支援物件式的指令碼語言特性

2、BeanShell在JMeter的作用

  • (1)操作變數;

  • (2)jmeter本身也是Java開發,所以對jmeter現有的功能可進行擴充套件

3、JMeter中BeanShell常用的基本語法(登入獲取使用者資訊為例):

3.1 log:日誌列印

log.info("測試列印日誌")

例如在某個請求的後置處理器,寫入上述內容。可以在jmeter的日誌輸出欄看到一下內容

3.2 prev - (SampleResult):獲取前面的sample返回的資訊,常用方法:

(1)prev.getSamplerData() 獲取請求資料

(2)prev.getResponseDataAsString() 獲取響應資訊

(3)prev.getBodySize() 獲取響應body大小

(4)prev.getTime() 獲取此次耗時

示例:

prev.setDataEncoding("UTF-8");

String result = prev.getResponseDataAsString();

String samplerData= prev.getSamplerData();

System.out.println("--------------------------------------");

System.out.println("響應資訊為"+result);

System.out.println("--------------------------------------");

System.out.println("samplerData資訊為"+samplerData);

int getBodySize = prev.getBodySize();

System.out.println("--------------------------------------");

System.out.println("getBodySize為"+getBodySize);

int getTime = prev.getTime();

System.out.println("--------------------------------------");

System.out.println("耗時為"+getTime);

輸出結果:

3.3 vars(JMeterVariables)用於操作jmeter變數,常用方法:

 (1) vars.get("String key"):從jmeter中獲得變數值;

 (2) vars.put("String key","String value"):儲存資料存到jmeter變數中;

示例:

在上部分程式碼之後新增以下程式碼:

JSONObject response = JSON.parseObject(result);

String token = response.getString("data");

vars.put("token",token);

String getToken = vars.get("token");

System.out.println("--------------------------------------");

System.out.println("getToken為"+getToken);

在jmeter 的請求頭中設定好變數為,此段程式碼中的put方法可將上個登入介面返回的token值賦給token變數,便於後面的介面使用

get方法我們這裡採用了輸出的方法檢視是否獲取到token執行結果如圖

持續更新中~

相關文章