JMeter-BeanShell预处理程序和BeanShell后置处理程序的应用

Posted 那年故乡的明月

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JMeter-BeanShell预处理程序和BeanShell后置处理程序的应用相关的知识,希望对你有一定的参考价值。

一、什么是BeanShell?

BeanShell是用Java写成的,一个小型的、免费的、可以下载的、嵌入式的Java源代码解释器,JMeter性能测试工具也充分接纳了BeanShell解释器,封装成了可配置的BeanShell前置和后置处理器,分别是

BeanShell Preprocessor(BeanShell预处理程序)和BeanShell Postprocessor(BeanShell后置处理程序),能通过编写代码的方式更好的处理接口性能测试中的请求前置入参和后置数据的获取等等。BeanShell配置原件在JMeter的位置如下图:

BeanShell Preprocessor(BeanShell预处理程序)

 

 

 BeanShell Postprocessor(BeanShell后置处理程序)

 

 

 二、BeanShell Preprocessor(BeanShell预处理程序)的基本应用

在进行接口性能测试时,往往经常用到的场景就是每次api请求的入参都是变化的,比如有些接口请求参数有时间戳、或者很多时候后台为了保证接口请求的安全性,需要请求携带sign入参甚至这个sign是通过加密算法得到的。也就是说,这样的接口基本都是每次请求前需要构建不同的入参数据。因此在对这样的接口做并发测试时就需要参数化请求入参,BeanShell Preprocessor(BeanShell预处理程序)这样的前置处理器就可以很方便构建参数化入参。看看如下实例:可以参数化时间戳、参数化sign签名。

添加BeanShell Preprocessor前置处理器,在脚本编辑框中编辑如下代码:

// 导入MD5加密需要用到的jar包。
import org.apache.commons.codec.digest.DigestUtils;

// 声明你需要拼接的字符串
//String requestTime = "1680089472000"; //生成时间戳
String requestTime = "$__time(,)"; //生成时间戳
log.info("=====请求时间戳:=====>>"+requestTime);

String yan = "N[8HXx!57Ivy%)#R";
//拼接需要加密的字符串
String str = yan + requestTime;
// 加密已拼接的字符串
String sign = DigestUtils.md5Hex(str);
log.info("=====sign签名:=====>>"+sign);

vars.put("sign",sign); //设置变量,将md5加密后的值传递给变量sign

vars.put("requestTime", requestTime); //将时间传递给变量requestTime

 如上的BeanShell脚本中,定义了两个字符串:requestTime 和sign,设置了它们的取值,其中requestTime的值是$__time(,),该函数可以按当前时间生成时间戳,sign的值是进行了md5加密后生成了一个32位小写的字符串,并将值传给变量requestTime 和sign用于后续接口请求参数化,然后脚本中也加入了日志打印,接口请求后可以在日志查看中输出参数日志信息

效果如下图:

 

 这样就完成了BeanShell预处理脚本的编写,然后我们将脚本中的requestTime 和sign参数引入接口请求中,如下图:

 

 最后,BeanShell预处理脚本以及请求参数化配置好后,我们运行JMeter看看请求效果和日志打印,请求2次接口:

 

 可以看到每次请求的时间戳和sign值都不一样,请求响应结果都是返回正确的。这样就完成了jmeter并发请求每次都是不一样的请求入参。

 三、BeanShell Postprocessor(BeanShell后置处理程序)的基本应用

BeanShell Postprocessor(BeanShell后置处理程序)其实就是通过脚本来获取响应相关的数据,用于做一些和其他接口有交互的场景,如接口A的响应结果的某个字段用于接口B的入参的时候,就可以通过BeanShell Postprocessor(BeanShell后置处理程序)来提取到接口A的响应结果的数据,然后参数化传递给接口B或者将提取的数据写入文件等。当然JMeter也提供了类似正则表达式提取器、json提取器等后置处理元件来提取响应或者请求数据,BeanShell Postprocessor(BeanShell后置处理程序)可能更方便通过脚本来自定义获取想要的数据。

添加BeanShell Postprocessor后置处理器,比如我们想要获取请求后的响应状态码、响应头响应体等数据都是可以的。在脚本编辑框中编辑脚本,如下图:

 

 这样我们就可以得到响应状态码、响应体、响应头等数据,用于后续接口响应断言等测试验证,运行结果如下:

 

 如上就是BeanShell Postprocessor后置处理器的基本应用了,当然还可以编写更加适用于测试场景的脚本和逻辑满足测试需要。

 

NoClassDefFoundError: bea/jmapi/MethodProfileData 使用 JRockit Mission Control 分析应用程序时

【中文标题】NoClassDefFoundError: bea/jmapi/MethodProfileData 使用 JRockit Mission Control 分析应用程序时【英文标题】:NoClassDefFoundError: bea/jmapi/MethodProfileData when profiling app using JRockit Mission Control 【发布时间】:2013-08-06 19:21:54 【问题描述】:

我们正在尝试使用 Mission Control 分析运行在 JBoss 7.1.1 上、与 JRockit VM 一起运行的应用程序。管理服务器使用 jrcmd 启动,我们可以使用 MC 控制台连接并查看 VM 统计信息等,但如果我们尝试使用方法分析器,应用程序开始抛出如下异常:

NoClassDefFoundError: bea/jmapi/MethodProfileData

有没有人知道是什么原因造成的?我猜这与 JBoss 中的模块系统有关,但如果您有任何见解,我将不胜感激。

【问题讨论】:

【参考方案1】:

好的,找到答案了。我只需要将它添加到standalone.conf:

JBOSS_MODULES_SYSTEM_PKGS="bea.jmapi"

【讨论】:

以上是关于JMeter-BeanShell预处理程序和BeanShell后置处理程序的应用的主要内容,如果未能解决你的问题,请参考以下文章

Jmeter-BeanShell PostProcessor提取请求及响应结果并保存到本地文件

Jmeter-BeanShell Sampler调用java代码

jmeter-beanshell参数调取

jmeter-beanshell断言

jmeter-beanshell本地文件写入多列数据--for循环

Jmeter-BeanShell断言:将数据库结果封装成list作为参数