JMeter前置处理器-Beanshell前置处理器详解

简介: JMeter的Beanshell前置处理器允许用Java-like语法执行测试前的自定义逻辑,如参数化和数据处理。要添加它,右键点击HTTP请求,选择“添加”->“前置处理器”->“Beanshell前置处理器”。内置变量如`vars`, `ctx`, `log`和`props`提供与JMeter变量、上下文、日志和属性的交互。例如,`vars.get("key")`用于获取变量,`log.info()`用于记录日志。使用这些工具,测试者能增强性能测试的复杂性和准确性。

image.png

前言

在JMeter中,前置处理器用于在发送HTTP请求之前执行特定的操作。Beanshell前置处理器是一种非常强大的前置处理器,它允许您使用Java语言编写脚本来实现各种复杂的逻辑。本文将介绍如何使用Beanshell前置处理器来执行自定义操作以增强性能测试。

什么是Beanshell前置处理器?

Beanshell前置处理器是JMeter提供的一种前置处理器,它使用Beanshell脚本语言编写。Beanshell是一种类似于Java的脚本语言,它允许您使用Java语法编写代码,并且可以与Java类和库进行交互。这使得Beanshell前置处理器非常灵活,可以执行各种自定义逻辑,如参数化、数据处理、计算等。

如何在JMeter中添加Beanshell前置处理器?

要在JMeter中添加Beanshell前置处理器,我们可以按照以下步骤操作:

  • 打开JMeter,并打开您的测试计划。
  • 在添加Beanshell前置处理器的HTTP请求之前,右键单击目标HTTP请求,选择“添加” -> “前置处理器” -> “Beanshell 前置处理器”。

image.png

Beanshell的内置变量操作

  1. vars变量:用来操作Jmeter的变量值得,常用的方法有:
  • vars.get("key"):从Jmeter变量中获取指定键的值
  • vars.put("key","value"):向Jmeter变量设置变量键值对

示例如下:

image.png

代码如下:

string name = vars.get("name") //此处获取的jmeter变量值转换成Java变量
log.info("获取到的变量值为:="+name);//打印一下获取的变量值

vars.put("phone","13201100123"); //向Jmeter变量中设置一个phone变量
log.info("设置phone的变量值为:="+vars.get("phone")); //打印一下设置的phone值
  1. ctx变量:用来获取当前线程的上下文信息,常用的方法有:
  • ctx.getVariables().get("key"):等价于vars.get("key"),从Jmeter变量中获取指定键的值
  • ctx.getProperties().getProperty("key"):获取Jmeter的属性,这里可以获取Jmeter.properties配置文件下的属性
  • ctx.getThreadNum():获取当前线程组编号

示例如下:

image.png

代码如下:

log.info("=通过ctx形式获取一下Jmeter存储的变量:="+ctx.getVariables().get("name"));
log.info("=通过ctx形式获取一下Jmeter属性:="+ctx.getProperties().getProperty("sampleresult.default.encoding")); //此处验证我们配置的编码属性
log.info("=====通过ctx形式获取一下当前线程编号:="+ctx.getThreadNum());
  1. log变量:用来记录日志,会写进jmeter.log文件中,常用的方法有:
  • log.info():打印普通日志
  • log.warn():打印警告日志
  • log.error():打印错误日志

实例如下:

image.png

代码如下:

log.info("这是一条普通的日志");
log.warn("这是一条警告信息");
log.error("发生报错,请检查一下问题");
  1. props变量:用来操作jmeter的属性的,常用的方法有:
  • props.get("propName"):获取Jmeter的指定属性信息
  • props.put("propName","propValue"):给Jmeter设置属性
  • props.containsKey("key"):判断Jmeter是否存在指定key的属性
  • props.contains("values"):判断Jmeter是否存在指定value的属性

示例如下:

image.png

代码如下:

log.info("通过props变量获取下Jmeter的编码属性:"+props.get("sampleresult.default.encoding"));
log.info("通过props变量判断下Jmeter的编码属性是否存在:"+props.containsKey("sampleresult.default.encoding"));

实际使用

了解了各种变量之后,我们可以在执行测试时,实际使用Beanshell前置处理器,比如我们要在执行测试时,添加上时间变量,我们可以如下设置:

vars.put("time", "${__time(,)}");
log.info("时间参数:"+vars.get("time"));

运行脚本,查看结果树,如下:

image.png

总结

在本文中,我们介绍了如何使用Beanshell前置处理器来执行自定义操作以增强JMeter性能测试。通过编写Beanshell脚本,可以实现各种复杂的逻辑,从简单的参数化到数据处理和计算。Beanshell前置处理器为性能测试提供了更大的灵活性和可扩展性,使我们能够更好地模拟真实的使用场景,并发现潜在的性能问题。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
12-Jmeter前置、后置处理器简介
12-Jmeter前置、后置处理器简介
|
1月前
|
测试技术
JMeter前置处理器-用户参数详解
JMeter是一款开源性能测试工具,其前置处理器功能强大,能模拟真实用户行为。本文聚焦于用户参数这一重要前置处理器,阐述了用户参数的作用域规则:全局(测试计划)、线程组或请求级别。通过实例展示了如何定义单个或多个用户值,并说明了“每次迭代更新一次”选项的影响。用户参数与用户定义变量的主要区别在于,前者可为参数分配多个值,且在变量名冲突时优先级更高。理解这些概念有助于优化JMeter的性能测试效率。
24 1
|
4月前
|
Java
Jmeter 的 Beanshell基本用法
Jmeter 的 Beanshell基本用法
|
10月前
|
JSON 数据安全/隐私保护 数据格式
|
存储 JSON 测试技术
JMeter 后置处理器之JSON提取器
JMeter 后置处理器之JSON提取器
354 0
|
存储 Apache 索引
JMeter 后置处理器之正则表达式提取器详解
JMeter 后置处理器之正则表达式提取器详解
75 0
|
JSON 搜索推荐 Java
Jmeter常用断言之BeanShell断言详解
BeanShell断言可以使用beanshell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用beanshell脚本。在这里主要通过 Failure 和 FailureMessage来设置断言结果。 Failure = false;-----表示断言成功 FailureMessage = “......";---自定义的成功信息 Failure = true;----表示断言失败 FailureMessage="=".....";---自定义的失败信息
297 0
Jmeter常用断言之BeanShell断言详解
|
7月前
|
XML 前端开发 测试技术
使用 jMeter 对 SAP Spartacus 进行并发性能测试
使用 jMeter 对 SAP Spartacus 进行并发性能测试
73 0
|
8月前
|
JSON 监控 测试技术
性能测试--InfluxDB+Grafana+Jmeter搭建性能监控平台 (二)
性能测试--InfluxDB+Grafana+Jmeter搭建性能监控平台