这几年Jmeter用的相对比较多,自己每次在做项目时也常会去翻看以前遇到的问题,记录的一些技巧,解决方案,也一直考虑把它整理出来,一来方便自己查找,二来也希望同行可以互相切磋。我写的这些文章不是针对Jmeter小白用户,可能叙述某些步骤时会直接跳过一些解释,不明白的或者表达错误的欢迎提出。目前所用的Jmeter版本是5.3。

        通常我们在编写场景类脚本时需要引用之前提取或设置的变量,如先在线程组下右击创建一个配置元素,选择用户自定义变量,设置一个参数名为name,值为junjun。什么情况下需要用到这种配置元素?一般每次需要执行相同脚本不同参数时,如线程数量等

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_javascript

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_测试工具_02

  1.         接下来要实现beanshell中引用这个变量并打印。可能刚接触Jmeter的同学很少会用到beanshell,在面试时被问到Jmeter相关问题时也只会最基本的知道怎么建线程组,创建http请求,参数化了解一些,后置处理器也只用过正则表达式、查看结果树等等。涉及怎么调试、查看日志、函数、脚本语言十有八九是回答不出来的,这里基本组件会讲的少一点,主要是讲我实际做项目时会用到的一些知识点,beanshell会涉及较多。

        新增一个beanshell sampler,

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_测试工具_03

按如下第一种方法${}来引用,打开右上角日志,执行。查看日志中报错信息,因为log.info只能打印字符串,而在引用name时未指定字符串类型

//提取name变量值
//方法1:${}
name1=${name};
log.info(name1);

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_压力测试_04

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_jmeter_05

 修改如下,增加双引号,再执行,可以看到junjun已经打印在下方。

//提取name变量值
//方法1:${}
name1="${name}";
log.info(name1);

 

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_jmeter_06

第二种方法,使用vars.get()方法,括号里直接填写变量名,可以看到报错信息Undefined argument: name,意思是name这个参数么有定义,就是识别不了这个参数,原因是vars.get在获取变量时也需要打双引号

//方法2:vars
name2=vars.get(name);
log.info(name2);

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_javascript_07

 修改如下,再次执行结果已打印,由于vars.get()获取的变量值为字符串类型,所以在log.info()打印时可以直接输出了。

//方法2:vars
name2=vars.get("name");
log.info(name2);

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_javascript_08

2. 获取了变量后,如果要执行过程中需要修改变量后引用怎么做呢?新建一个2,输入如下再执行,又看到了熟悉的错误,分析下,name3做了一个字符串连接打印输出,再将name3的值存入一个新的变量name4并打印,报错的原因是vars.put()中指定新的变量时必须打双引号,字符串类型

name2=vars.get("name");
log.info(name2);

name3=name2+"001";
log.info(name3);
//将name3变量的值存入name4变量
vars.put(name4,name3);
log.info(vars.get("name4"));

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_压力测试_09

 修改

name2=vars.get("name");
log.info(name2);

name3=name2+"001";
log.info(name3);
//将name3变量的值存入name4变量
vars.put("name4",name3);
log.info(vars.get("name4"));

Jmeter beanshell使用java脚本处理响应 jmeter beanshell vars_压力测试_10

总结下本文主要讲的就是2点

1.在beashell中引用变量时可以用${} 也可以用vars.get(String key),需要注意的是双引号使用,获取的数据类型,本篇例子都是字符串类型

2.在beashell中设置新变量时可以用vars.put(String key,String value)