作者:季沐测试笔记
原文地址:https://www.cnblogs.com/testero/p/15425776.html
博客主页:https://www.cnblogs.com/testero
BeanShell是java编写的一个轻量级的脚本语言,支持对象式的脚本语言特性
(1)操作变量;
(2)jmeter本身也是Java开发,所以对jmeter现有的功能可进行扩展
log.info("测试打印日志")
例如在某个请求的后置处理器,写入上述内容。可以在jmeter的日志输出栏看到一下内容
(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);
输出结果:
(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运行结果如图