背景:
在日常的功能测试或者性能测试的时候,需要把结果中指定的数据保存到指定的文件,进行使用,发现 jmeter 自带的文件写入,没有自己需要的,默认只支持 XML 的结果保存,那么接下来我们围绕 beanshell 来实现这个功能。
下面从两个方面来实现:
一、保存接口返回指定的数据
二、从数据库用 SQL 语句取数据,保存结果到指定文件中
一、保存接口返回指定的数据
接口:登录
需求:提取 token 值
1、新建 HTTP 请求
![bdb199e49536aec8a8cee3c996ab5ec4.png](https://img-blog.csdnimg.cn/img_convert/bdb199e49536aec8a8cee3c996ab5ec4.png)
请求返回的结果,这里直接用 JSON 显示:
![e1015cc3a8273422e66fe2b5c86dbab3.png](https://img-blog.csdnimg.cn/img_convert/e1015cc3a8273422e66fe2b5c86dbab3.png)
2、新建 JSON 提取器
![5bc3652996dac8f50de4ff0f21b261e9.png](https://img-blog.csdnimg.cn/img_convert/5bc3652996dac8f50de4ff0f21b261e9.png)
3、调试,看有没有获取到值
添加 debug sampler
![736c21136557fa9ec206bb1088900e28.png](https://img-blog.csdnimg.cn/img_convert/736c21136557fa9ec206bb1088900e28.png)
4、运行,查看 debug sampler 响应数据里面 token 有没有取到值
![4430087ec5772655d5d6efe6e044ae6e.png](https://img-blog.csdnimg.cn/img_convert/4430087ec5772655d5d6efe6e044ae6e.png)
5、添加 beanshell 取样器
![3339a55ed4829b46e9af297d5c3391a7.png](https://img-blog.csdnimg.cn/img_convert/3339a55ed4829b46e9af297d5c3391a7.png)
6、上代码
//指定需要写入到哪个文件,格式:TXT,csv
FileWriter file = new FileWriter("D:apache-jmeter-5.0token_num.txt",true);
//创建一个字符缓存输出流
BufferedWriter out = new BufferedWriter(file);
//写文件内容
//vars.get:获取 jmeter 中的变量值
out.write(vars.get("token")+"n");
//关闭写数据流
out.close();
//关闭文件
file.close();
![8e90aa666f1aaf12231f01b7eee38434.png](https://img-blog.csdnimg.cn/img_convert/8e90aa666f1aaf12231f01b7eee38434.png)
7、运行,可以循环多次写入数据
![21618dc06875501567a08e7004d50868.png](https://img-blog.csdnimg.cn/img_convert/21618dc06875501567a08e7004d50868.png)
![cc0f8c7f5d7bef7f7a9a1bb3d4b3ebe2.png](https://img-blog.csdnimg.cn/img_convert/cc0f8c7f5d7bef7f7a9a1bb3d4b3ebe2.png)
二、从数据库用 SQL 语句取数据,保存结果到指定文件中
需求:用 SQ 语句查询出数据,保存结果到文件中
1、添加 SQL 语句的配置元件
![dd74166d3af48f52db6e7d4ed1c2af93.png](https://img-blog.csdnimg.cn/img_convert/dd74166d3af48f52db6e7d4ed1c2af93.png)
![2552e5dfde8a6899674fd3b3701affc5.png](https://img-blog.csdnimg.cn/img_convert/2552e5dfde8a6899674fd3b3701affc5.png)
2、添加 SQL 语句取样器
![9844e939a586652248e5d403e15c2266.png](https://img-blog.csdnimg.cn/img_convert/9844e939a586652248e5d403e15c2266.png)
![acba51130f0427767641e8771ad6fb4e.png](https://img-blog.csdnimg.cn/img_convert/acba51130f0427767641e8771ad6fb4e.png)
--提取 token 的值,并指定 token 输出的左边界值,这里取出 5 行数据
SELECT CONCAT('"token_num":',token,'') FROM cb_account LIMIT 5
![4ad00a07ed30db9de97ffc53e41dfa40.png](https://img-blog.csdnimg.cn/img_convert/4ad00a07ed30db9de97ffc53e41dfa40.png)
3、添加正则表达式,提取 SQL 执行之后返回的结果值
![2ba8c42225df28d1d48e38601c7d226b.png](https://img-blog.csdnimg.cn/img_convert/2ba8c42225df28d1d48e38601c7d226b.png)
引用名称:token_num
正则表达式:"token_num":(.+)
模板:$1$
匹配数字:-1 (取出所有的值)
![1e49807de13907cf606dae923c0306cc.png](https://img-blog.csdnimg.cn/img_convert/1e49807de13907cf606dae923c0306cc.png)
4、调试,看有没有获取到值
添加 debug sampler
![736c21136557fa9ec206bb1088900e28.png](https://img-blog.csdnimg.cn/img_convert/736c21136557fa9ec206bb1088900e28.png)
5、运行,可以看到获取到了所有的查询结果
![30ad96f75f4339f6d211c172436367e1.png](https://img-blog.csdnimg.cn/img_convert/30ad96f75f4339f6d211c172436367e1.png)
![8ec3754ecc1371cfcab9a1a86f4cdfb4.png](https://img-blog.csdnimg.cn/img_convert/8ec3754ecc1371cfcab9a1a86f4cdfb4.png)
可以看到在引用变量后面加上数字,从 2 开始,那么下面要怎么做呢?
6、添加 beanshell 取样器
![3339a55ed4829b46e9af297d5c3391a7.png](https://img-blog.csdnimg.cn/img_convert/3339a55ed4829b46e9af297d5c3391a7.png)
代码:
//指定需要写入到哪个文件,格式:TXT,csv
FileWriter fstream = new FileWriter("D:apache-jmeter-5.0token_num.csv",true);
//创建一个字符缓存输出流
BufferedWriter out = new BufferedWriter(fstream);
//返回的结果有值从数字 2 开始,一共有 5 次,那么我们这里就小于等于 6
for(int num=2; num<=6; num++){
//拼接变量名称
token_num = "token_num"+"_"+num;
System.out.println(token_num);
//把拼接的名称赋值给 token_num
vars.put("token_num",token_num);
System.out.println(vars.get(token_num));
//vars.get()获取到变量名称,并和上面返回的 token_num_(2,3,4,5,6)名称一致,取到变量的值
out.write(vars.get(token_num)+"n");
}
out.close();
fstream.close();
![e4c1f01b0589daf76b5858c31a540615.png](https://img-blog.csdnimg.cn/img_convert/e4c1f01b0589daf76b5858c31a540615.png)
7、运行查看结果:
![02ac61b7d30fbb9b687de8fd97928c55.png](https://img-blog.csdnimg.cn/img_convert/02ac61b7d30fbb9b687de8fd97928c55.png)
本文作者:mike.liu;
本文来源:柠檬班社区;
原文链接:轻松搞定把 jmeter 结果数据写入到指定文件 - 测试派