Jmeter_实现Excel文件导出到本地
Posted 天使未必在场
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jmeter_实现Excel文件导出到本地相关的知识,希望对你有一定的参考价值。
一般而言,对于页面的“导出”操作,主要经历如下两个操作:①根据数据库的内容,将文件导出到应用服务器上;②将服务器上的文件下载到本地电脑;
Jmeter同LoadRunner类似,只能记录服务端与客户端之间的数据流转,而不能记录本地操作,因此对于含有导出功能的性能需求,将服务端的文件下载到本地电脑,需要我们手工加入代码实现(上面所述的步骤②)。
【1.导出请求分析】“导出”操作对应的两个请求如下:
【2.获取文件的服务端路径】
在请求“97”下使用“后置处理器→正则表达式”,提取导出文件的名称。
【3.获取文件的内容并写入本地】
在请求“98”下使用“BeanShell PostProcessor”,获取导出文件的内容,并写入本地(Java)。
注:①仅以文件名作为filepath的值,则导出的文件会默认保存在Jmeter安装路径的bin(即JVM的启动路径);
//备注:BeanShell PostProcessor中代码如下: //JMeter的内置API:prev.getResponseData()获取请求的响应内容 byte[] responseData = prev.getResponseData(); //①仅以文件名作为filepath的值,则导出的文件会默认保存在Jmeter安装路径的bin(即JVM的启动路径); //private String filePath = "${ExportExcelName}"; //②指定绝对路径 private String filePath = "D:/JMeterTest/Wy/${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(); } } }
以上是关于Jmeter_实现Excel文件导出到本地的主要内容,如果未能解决你的问题,请参考以下文章