jmeter在beanshell中使用props.put()方法的注意事项

在jmeter中,通常使用beanshell去处理一些属性的设置和获取的操作,而这些操作也是有一定的规则的。

  1. 设置属性时,在属性名上要加双引号,这代表它不是一个需要用var去声明的变量

这种设置属性的方式才是有效可行的,在用props.get()获取的时候,就用和用props.put()方法设置时用到的属性名一样的属性名去获取值才不会错。

出错的方式有:

如果获取值时用到的属性和设置时用到的属性不一致,就会出现如下错误,未定义的参数currtime,它把currtime看成是一个变量参数,而变量是需要被声明定义的。

出错方式2:

如果我们把属性用声明的变量来表示,脚本如下,

运行脚本会发现,这样去设置属性值根本行不通,因为props.put()方法的运行规则要求属性名是有双引号引起的。

这里指示props.put()方法的调用出了问题。所以不能用变量去设置属性名,行不通。这可能是jmeter不太完善的地方。

出错方式3:

关于使用props.put()方法去设置属性值,对属性的value这个参数是有要求的,例子如下

这里调用${__time()}函数来作为属性的value, 但是这里有个问题,单独使用这个函数的时候,对于格式不加双引号没问题,但是这里使用的时候不加双引号,就报错了。报错如下:

改过来,都不带双引号

报错如下:

因为变量nowTime没有声明定义,所以要声明定义一下

可见,即使声明了,也报错,还是如错误方式1一样,关于属性参数这个参数,不能用变量。

应对方式:把{__time(yyyy-MM-dd HH:mm:ss)}函数里的格式加上双引号,就不再报错了。

运行结果:

这样就成功运行了time函数的值,也把值赋给了属性nowTime.

  1. 通过props.put()设置的属性值 之前认为只能通过props.get()方法获取,但其实也能通过属性函数{__property()}和 {__P()}获取【这个做法在beanshell或jsr223 sampler中不适用】,例子如下

在jsr223 sampler或Beanshell脚本里不适用。不知道什么原因,可能是jmeter不够完善的地方吧。

把脚本里的取属性的写法写成和debug sampler标题上的写法一致,结果报错,编译通不过。

这里的原因是:我的思考:因为这里刚通过props.put()设置了属性,直接调用属性函数来取行不通,因为脚本的执行和debug sampler的执行走的是不同的路径。所以,每次在beanshell sampler中用属性函数去获取值时,都会报错。

要注意的是在属性函数里,属性名切记不要加双引号,因为属性函数中默认属性名是字符串格式。

相关推荐
llm2009094 分钟前
Jmeter的JDBC数据库连接
数据库·jmeter
程序媛_7 小时前
【JMeter】执行SQL
数据库·sql·jmeter
颜挺锐1 天前
在 JMeter 中,将日期字符串(如 2025-06-07 00:00:00)转换为时间戳(毫秒级),可以使用以下两种方法
jmeter
财神爷首席大弟子2 天前
jmeter做跨线程组
jmeter
程序媛_2 天前
【JMeter】跨线程组传递参数
jmeter
测试杂货铺9 天前
Jmeter(六):json断言元件,jmeter参数化实现
jmeter·json
Moshow郑锴20 天前
JMeter API 并发性能测试计划JMX文件解析
jmeter
qq_49244844621 天前
java项目打包成jar包,并给jmeter使用
java·jmeter·jar
kanyun12321 天前
Jmeter使用过程中的一些总结
jmeter
無_爲21 天前
JavaEE:使用JMeter进行接口并发测试
java·jmeter·java-ee