jmeter接口导出文件实例

通过接口测试导出Excel文件,需添加后置处理器

代码如下:路径用\\或者/

import java.io.*;
byte[] result = prev.getResponseData();    //这个是获取请求返回的数据,prev是获取上个请求的返回
String fileNameExport = "F:\\study\\FansP\\MemberDetail.xlsx";
File file = new File(fileNameExport);
FileOutputStream out = new FileOutputStream(file);
out.write(result);
out.close();
import java.io.*;
byte[] result = prev.getResponseData();    //这个是获取请求返回的数据,prev是获取上个请求的返回
String fileNameExport = "F:/study/FansP/MemberDetail.xlsx";
File file = new File(fileNameExport);
FileOutputStream out = new FileOutputStream(file);
out.write(result);
out.close()

导出的结果如下,内容是json格式。不是我想要的内容,应该怎样处理咧?

期望结果如下图

 

原来一开始的思路错了,因为页面的“导出”操作,主要经历如下两个操作:(注意:HTTP信息头管理器  要添加请求内容哦)

①根据数据库的内容,将文件导出到应用服务器上;

②将服务器上的文件下载到本地电脑。

jmeter只能记录服务端与客户端之间的数据流转,而不能记录本地操作,因此对于含有导出功能的性能需求,将服务端的文件下载到本地电脑,需要我们手工加入代码实现(上面所述的步骤②)

1、首先根据导出接口 ,将文件导出到服务器上;

获取文件的服务端路径:根据正则表达式提取文件名称,如下图二。

 

 

2、获取文件的内容并写入本地

注意:每次获取文件的文件名都不一样,在路径这里要添加参数,不然会报403。我在这里折腾了半天。

 

 在请求“导出文件服务器路径”下使用“BeanShell PostProcessor”,获取导出文件的内容,并写入本地

 代码如下:


//备注:BeanShell PostProcessor中代码如下:
//JMeter的内置API:prev.getResponseData()获取请求的响应内容
byte[] responseData = prev.getResponseData(); 
 
//①仅以文件名作为filepath的值,则导出的文件会默认保存在Jmeter安装路径的bin(即JVM的启动路径);
//private String filePath = "${ExportExcelName}";
 
//②指定绝对路径
private String filePath = "F:/study/FansP/会员抽奖导出-${ExportExcelName}";  //正则表达式提取时的引用名称
BufferedOutputStream bos = null;
FileOutputStream fos = null;
File file = null;
try {
   File file = new File(filePath);
   fos = new FileOutputStream(file); //不添加参数true,以非追加的方式添加内容
   bos = new BufferedOutputStream(fos);
   bos.write(responseData);
} catch (Exception e) {
   e.printStackTrace();
} finally {
   if (bos != null) {
      try {
         bos.close();
      } catch (IOException e1) {
         e1.printStackTrace();
      }
   }
   if (fos != null) {
      try {
         fos.close();
      } catch (IOException e1) {
         e1.printStackTrace();
      }
   }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值