作者:季沐測試筆記
原文地址: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執行結果如圖