Jmeter之后置处理器BeanShell PostProcessor与二进制响应

来源:互联网 发布:简历java电商项目经验 编辑:程序博客网 时间:2024/06/05 15:48

读取二进制文件

下载必要的jar包

http://tika.apache.org/download.html
笔者的百度云盘
链接:http://pan.baidu.com/s/1bpctAr1 密码:o0wm
放到lib目录下后须重启jmeter

准备xls文件

这里写图片描述

构建脚本

这里写图片描述

查看http的file响应

注意text切换到Document模式
这里写图片描述

正则提取及结果

正则:
这里写图片描述
查看debugSampler
这里写图片描述
因而需要对结果进行转码-beanshell后置处理器

BeanShell

代码1

import org.apache.jmeter.util.Document;//导入官方jar包String converted = Document.getTextFromDocument(data);//静态方法不用生成对象,参见API:jmeter.apache.org/api/index.html//data是该响应在BeanShell中的本地变量,是个字符数组,本质就是那个读取的那个file,会用就行不用懂vars.put("response0820",converted);

这里写图片描述

这里写图片描述

查看结果树

这里写图片描述

这里写图片描述

代码2

适合有一定基础的童鞋

import org.apache.jmeter.threads.JMeterVariables;import org.apache.poi.ss.usermodel.Cell;import org.apache.poi.ss.usermodel.Row;import org.apache.poi.ss.usermodel.Sheet;import org.apache.poi.ss.usermodel.Workbook;import org.apache.poi.xssf.usermodel.XSSFWorkbook;InputStream in = new ByteArrayInputStream(data);//打开流文件Workbook wb = new XSSFWorkbook(in);//多态,生成对象wb存储这个二进制响应结果in.close();//关闭流文件Sheet sheet1 = wb.getSheet("Sheet1");//对象wb调用getSheet方法,获取对应的Sheet,这里是1Row row = sheet1.getRow(0);//取第0行放入rowCell a1 = row.getCell(0);//取row的第0列Cell b1 = row.getCell(1);//取作row的第1列vars.put("A1",a1.getStringCellValue());vars.put("B1",b1.getStringCellValue());//log.info("+++++++++++++");

这里写图片描述

这里写图片描述