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

举报
Tester_muller 发表于 2024/04/01 17:28:45 2024/04/01
【摘要】 前言在JMeter中,前置处理器用于在发送HTTP请求之前执行特定的操作。Beanshell前置处理器是一种非常强大的前置处理器,它允许您使用Java语言编写脚本来实现各种复杂的逻辑。本文将介绍如何使用Beanshell前置处理器来执行自定义操作以增强性能测试。 什么是Beanshell前置处理器?Beanshell前置处理器是JMeter提供的一种前置处理器,它使用Beanshell脚本...

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前置处理器为性能测试提供了更大的灵活性和可扩展性,使我们能够更好地模拟真实的使用场景,并发现潜在的性能问题。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。