在使用Jmeter過程中,或多或少都會接觸些BeanShell,它會使工具的使用,變得更靈活。
Jmeter中關於BeanShell的有:
1.BeanShell Sampler 取樣器:完成Beanshell請求組件中定義的腳本功能;
2.BeanShell PostProcessor 後置處理器:可通過編程方式獲取對應請求的響應結果;
3.BeanShell PreProcessor 前置處理器:可通過編程方式在發起請求以前做預處理,比如編碼或者加密;
4.Beanshell 斷言:可通過編程方式實現複雜的斷言邏輯;
5.Beanshell 計時器:編碼實現條件定時功能;
6.BeanShell Listener 監聽器:監聽Beanshell運行結果。
目前我使用較多的是前三種元件。使用過程中,就會使用一些內置變量,所以這也是今天的主要內容。
vars
vars 在 JMeter 內部,映射 org.apache.jmeter.threads 的 JMeterVariables 類,官方文檔:https://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterVariables.html
注意點:
- vars 提供了對當前線程變量的讀寫能力
- 所有的 JMeter 變量都是 java字符串
- 把數據存放到一個 JMeter 變量中,需要先將它轉換成字符串
getThreadName
方法聲明
public String getThreadName()
功能
獲取當前運行線程名
String threadName = vars.getThreadName();
log.info("threadName:" + threadName);
getIteration
方法聲明
public int getIteration()
功能
獲取線程當前的迭代號
int itNum = vars.getIteration();
String num = String.valueOf(itNum);
log.info("itNum:" + num);
這裏有個注意點,就是在開始時候提到的,數據放到變量中,需要將數據轉換成String類型。
put
方法聲明
public void put(String key, String value)
Parameters:
key - the variable name
value - the variable value
功能
創建或更新字符串變量
創建變量
vars.put("name","溫一壺清酒");
vars.put("age","5");
String varsName = vars.get("name");
log.info("varsName:"+ varsName);
String varsAge = vars.get("age");
log.info("varsAge:"+ varsAge);
注意點:age字段值5,需要是字符串類型,否則會報錯。
Error in method invocation: Method put( java.lang.String, int ) not found in class'org.apache.jmeter.threads.JMeterVariables'
修改變量
vars.put("name","溫一壺清酒 博客園");
String varsName = vars.get("name");
log.info("varsName:"+ varsName);
get
方法聲明
public String get(String key)
功能
獲取變量的值並將其轉換爲字符串,若變量存在則將值轉換爲字符串,否則返回 null
String varsSex = vars.get("sex");
log.info("varsSex:"+ varsSex);
在put方法中,已經使用了get的方法,這裏列舉個獲取不到變量的情況,返回null
putObject
方法聲明
public void putObject(String key,Object value)
Parameters:
key - the variable name
value - the variable value
功能
創建或更新一個非字符串變量。
vars.putObject("number",8);
vars.putObject("list",[2,4,6,8,10]);
vars.putObject("array",[1,3,5,7,9,11] as int[]);
vars.putObject("map",["name":"溫一壺清酒","source":"博客園"]);
log.info("number:"+ vars.getObject("number").toString());
log.info("list:"+ vars.getObject("list").size());
log.info("array:"+ vars.getObject("array").length);
log.info("map:"+ vars.getObject("map").get("name"));
getObject
方法聲明
public Object getObject(String key)
功能
獲取變量的值(不轉換爲字符串)。若變量不存在則返回null
remove
方法聲明
public Object remove(String key)
功能
刪除一個變量,並返回變量的值,若變量不存在則返回 null
vars.put("name","溫一壺清酒 博客園");
vName = vars.remove("name");
log.info("vName:"+ vName);
vSex = vars.remove("sex");
log.info("vSex:"+ vSex);
props
props 映射 java.util 的 Properties 類。java.util.Properties 這個類是線程安全的;多個線程可以共享一個 Properties 對象
vars跟props的區別
- vars 是對變量進行讀寫操作, 而 props 主要是對屬性進行讀寫操作
- vars 只能在當前線程組內使用,props 可以跨線程組使用 ,因爲屬性可以跨線程組但是變量不行
- vars 只能保存 String 或者 Object,props 可以是 Hashtable 或者 Object
getProperty
方法聲明
public String getProperty(String key)
public String getProperty(String key, String defaultValue):當 key 不存在則返回默認值
功能
用指定的key在此屬性列表中搜索屬性,如果在此屬性列表中未找到該key,則接着遞歸檢查默認屬性列表及其默認值。如果未找到屬性,則此方法返回 null
timeFormat = props.getProperty("jmeter.save.saveservice.timestamp_format");
log.info("timeFormat:"+ timeFormat);
propsTest = props.getProperty("jmeter.save.saveservice.timestamp");
log.info("propsTest:"+ propsTest);
propsTest = props.getProperty("jmeter.save.saveservice.timestamp","溫一壺清酒 博客園");
log.info("propsTest:"+ propsTest);
get
方法聲明
public synchronized V get(Object key)
功能
獲取屬性值,跟 getProperty 類似
pTimeFormat = props.get("jmeter.save.saveservice.timestamp_format");
log.info("pTimeFormat:"+ pTimeFormat);
pPropsTest = props.get("jmeter.save.saveservice.timestamp");
log.info("pPropsTest:"+ pPropsTest);
setProperty
方法聲明
public Object setProperty(String key,String value)
功能
設置屬性值
props.setProperty("pName","溫一壺清酒");
propsName = props.getProperty("pName");
log.info("propsName:"+ propsName);
put
方法聲明
public synchronized V put(Object key)
功能
設置屬性值,跟 setProperty 類似
props.put("pName","溫一壺清酒");
pPropsName = props.get("pName");
log.info("pPropsName:"+ pPropsName);
propertyNames
方法聲明
public Enumeration<?> propertyNames()
功能
返回屬性列表中所有key的枚舉,如果在主屬性列表中未找到同名的key,則包括默認屬性列表中不同的key
propsNames = props.propertyNames();
propsNames.each{
log.info(it)
}
size
方法聲明
public int size()
功能
返回有多少個屬性
pPropsCount = props.size();
log.info("pPropsCount:"+ pPropsCount);
remove
方法聲明
public synchronized V remove(Object key)
功能
刪除一個變量,並返回變量的值,若變量不存在則返回 null
props.put("pName","溫一壺清酒");
rName = props.remove("pName");
log.info("rName:"+ rName);
rSex = props.remove("sex");
log.info("rSex:"+ rSex);
prev
prev 提供對當前取樣器結果的訪問能力,映射 org.apache.jmeter.samplers 的 SampleResult 類
官方文檔: https://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html
getResponseCode
方法聲明
public String getResponseCode()
功能
獲取響應狀態碼
responseCode = prev.getResponseCode() ;
log.info("responseCode:" + responseCode);
2022-10-04 15:34:29,057 INFO o.a.j.u.BeanShellTestElement: responseCode:200
isResponseCodeOK
方法聲明
public boolean isResponseCodeOK()
功能
判斷響應狀態碼是否爲OK對應的狀態碼(200),結果只有true和false
responseCodeBoolean = prev.isResponseCodeOK();
log.info("responseCodeBoolean:" + responseCodeBoolean);
2022-10-04 15:36:35,077 INFO o.a.j.u.BeanShellTestElement: responseCodeBoolean:true
getThreadName
方法聲明
public String getThreadName()
功能
獲取線程名
prevThreadName = prev.getThreadName();
log.info("prevThreadName:" + prevThreadName);
2022-10-04 15:39:17,955 INFO o.a.j.u.BeanShellTestElement: prevThreadName:prevThreadName
getResponseDataAsString
方法聲明
public String getResponseDataAsString()
功能
獲取String類型的響應結果
prevResponse = prev.getResponseDataAsString();
log.info("prevResponse:" + prevResponse);
getStartTime
獲取請求開始時間
getEndTime
獲取請求結束時間
getSamplerData
獲取請求內容
好了,以上就是平時經常用到的一些內置變量的方法,還有其他的方法,可以參考源碼或官方文檔。