掌握BeanShell,轻松处理jmeter中的数据
作者:季沐测试笔记
原文地址://www.cnblogs.com/testero/p/15425776.html
博客主页://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运行结果如图