JMeter组件之BeanShell PostProcessor的使用
JMeter组件之BeanShell PostProcessor的使用
2018年06月13日 10:48:44 aduocd 阅读数:3302
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/aduocd/article/details/80351719
背景:JMeter3.2 + fastjson-1.2.47,使用BeanShell PostProcessor组件获取Response中的内容
步骤:直接上代码
- 场景一:获取请求响应中的数据,并保存
import com.alibaba.fastjson.*; // 引入包。这个包需要先放在:<安装目录>\apache-jmeter-3.2\lib\ext中
// 获取数据
String response = prev.getResponseDataAsString(); // 获取Response
JSONObject responseObj = JSON.parseObject(response); // 整个Response作为JSON对象
JSONObject resObj = responseObj.getJSONObject(“res”); // 获取某一部分对象。即,json串中{}的内容
JSONArray listArray = resObj.getJSONArray(“list”); // 获取列表。即,json串中[]的内容
// 保存数据
// 1) 列表
int len = listArray.size();
for(int i=0; i<len; i++){
temp[i] = listArray.get(i).getString("name");
}
vars.put(“names”, Arrays.toString(temp)); // 保存到JMeter变量中,vars.put只能保存字符串,因此这里使用了toString()进行转换
// 2) String类型
String id = resObj.get(“id”); // 获取对象中某一字符串的内容。
vars.put(“id”, id); // 保存到JMeter变量中,后面的组件可以使用
// 3) Integer类型
Integer no = resObj.get(“id”); // 获取对象中某一整型的内容。
vars.put(“no”, no.toString()); // 保存到JMeter变量中,vars.put只能保存字符串,因此这里使用了toString()进行转换
- 场景二:获取数据库中查询到的数据,并保存
前提:在JDBC Request中已经获取到数据,详见《JDBCRequest的用法》。
select total_cash from t_cash where user_name=“tom”;
在Result variable name中的值为:result
String cash_new = vars.getObject(“result”).get(0).get(“total_cash”).toString();
vars.put(“cash_new”, cash_new); // 操作前与此步骤相同,不再赘述。保存的变量名为cash_old
上一篇: 通过JSON的方式后台数据返回到前端
下一篇: Maven阿里云仓库镜像地址