在jmeter中,通常使用beanshell去处理一些属性的设置和获取的操作,而这些操作也是有一定的规则的。
- 设置属性时,在属性名上要加双引号,这代表它不是一个需要用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.
- 通过props.put()设置的属性值 之前认为只能通过props.get()方法获取,但其实也能通过属性函数${__property()}和 ${__P()}获取【这个做法在beanshell或jsr223 sampler中不适用】,例子如下
在jsr223 sampler或Beanshell脚本里不适用。不知道什么原因,可能是jmeter不够完善的地方吧。
把脚本里的取属性的写法写成和debug sampler标题上的写法一致,结果报错,编译通不过。
这里的原因是:我的思考:因为这里刚通过props.put()设置了属性,直接调用属性函数来取行不通,因为脚本的执行和debug sampler的执行走的是不同的路径。所以,每次在beanshell sampler中用属性函数去获取值时,都会报错。
要注意的是 ,在属性函数里,属性名切记不要加双引号,因为属性函数中默认属性名是字符串格式。