掌握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运行结果如图

持续更新中~