记录jmeter使用beanshell断言获取复杂的json字符串参数值
实战示例
测试场景
- 电商系统经常会涉及到商品的库存数量的压测,在用户下单前需要先做库存余量的判断,当余量不足时用户无法下单,保证商品的有效售卖
库存余量查询响应结果
- 响应结果一般是json字符串的形式,响应示例如下:
2、期望获取的结果
通过上面响应结果,想获取参数为periods数组下的period_stock参数值和back_periods数组period_stock参数值。
标注如下:
3、jmeter bea
测试获取建议操作
- 由于jmeter中beanshell断言中书写代码没有提示(超不方便),不过可提前在IEDA工具中先调试获取结果再复制到beanshell中。
- IDEA调试结果如下:
然后就只把把代码复制到beanshell中即可。在jmeter中可以打印下获取的库存余量,结果如下:

- 附测试脚本(当back_periods库存值=0时,beanshell断言生效,可及时查看订单创建数量是否与库存数量一致)
import org.json.*;
//获取上一个请求的返回值
String response = prev.getResponseDataAsString();
//将返回值转换为json
JSONObject responseJson = new JSONObject(response);
//获取responseMessage
JSONArray data = responseJson.getJSONObject("data").getJSONArray("ticket_periods");
JSONObject ticket_periods = (JSONObject)data.get(0);
JSONObject periods =(JSONObject)(ticket_periods.getJSONArray("periods").get(0));
Integer period_stock = periods.getInt("period_stock");
JSONObject back_periods=(JSONObject)(ticket_periods.getJSONArray("back_periods").get(0));
Integer period_stock_back = back_periods.getInt("period_stock");
log.info("==========获取库存开始===========");
log.info("periods内余量值:" + period_stock);
log.info("back_periods内余量值:" +period_stock_back);
log.info("==========获取库存结束===========");
//beanshell断言
if(period_stock == 0){
Failure = true;
FailureMessage = "period_stock的值:" + period_stock +"警告:已无库存,请注意查看"+ "||period_id的值为:"+period_stock_back+"警告:已无库存,请注意查看";
}
- 获取所有数组内的参数值,这个需要进行遍历操作

附遍历代码
public void testCase() throws IOException {
// //将返回值转换为json
// JSONObject responseJson = new JSONObject(str);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
Map map = objectMapper.readValue(str, Map.class);
Map dataMap = (Map) map.get("data");
List<Map<String, Object>> list = (List<Map<String, Object>>) dataMap.get("ticket_periods");
list.stream().forEach(item ->{
List<Map<String, Object>> periodsList = (List<Map<String, Object>>) item.get("periods");
periodsList.stream().forEach(periods ->{
System.out.println("当前period_stock的值:"+periods.get("period_stock"));
});
});
}
- 另外使用jmeter的beanshell功能经常会用到以下方式传递变量
1、在beanshell中如果拿到响应结果的某个值,可以通过赋值方式传入,然后通过变量取值即可
vars.put赋值,格式为 vars.put("key","value")
vars.get 获取变量,vars.get("period_stock")
2、特别说明:如果想把Integer类型通过vars放入的话需要加上toString()方法,上面需要把Integer 类型period_stock作为变量传递,示例
vars.put("period_stock",period_stock.toString());
其它接口可通过变量名取值:{"period_stock":"${period_stock}"}
传递结果
GET http://127.0.0.1:8080/test
GET data:
{"period_stock":"80"}
[no cookies]
Request Headers:
Connection: keep-alive
Content-Type: application/json
Content-Length: 21
Host: 127.0.0.1:8080
User-Agent: Apache-HttpClient/4.5.5 (Java/1.8.0_181)
- 常用变量总结:
- vars: 实际引用Jmeter线程的局部变量, 连通Jmeter 和 beanshell
vars.get(String key) //获取变量值
vars.put(String key, String value) //存储value到变量key - log: 写入信息到日志中,log.info(""),括号放置需要的变量
- prev:获取当前响应结果和响应状态;
getResponseDataAsString()
getResponseCode() - props:class java.util.Properties
变量属性复制给变量props.put("some_variable",vars.get("some_variable"))
- vars: 实际引用Jmeter线程的局部变量, 连通Jmeter 和 beanshell
- 更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

记录jmeter使用beanshell断言获取复杂的json字符串参数值的更多相关文章
- JMeter之BeanShell断言---获取时间戳
1.创建线程组,创建一个BeanShell Sampler,在其中编写BeanShell脚本. 2.在Jmeter中,可以利用${__time(,)}时间戳函数来获取十位的时间戳,如: vars.pu ...
- jmeter之beanshell断言---数据处理
在做接口测试时,对响应数据的校验是非常重要的部分:在使用Jmeter进行接口测试时,有多种respone校验方式,比如响应断言.BeanShell断言等等,BeanShell断言可以自定义断言,自由灵 ...
- Jmeter之BeanShell断言使用
1.Bean Shell常用内置变量 JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下: log:用来记录日志文件,写入到j ...
- 『动善时』JMeter基础 — 31、JMeter中BeanShell断言详解
目录 1.BeanShell简介 2.Beanshell的内置变量和方法 3.BeanShell断言界面详解 4.BeanShell断言的使用 (1)测试计划内包含的元件 (2)登陆接口请求界面内容 ...
- JMeter中BeanShell断言使用一
Jmeter Ant Task如何让beanshell断言失败的详细信息展示在report里面 首先必须给beanshell断言添加FailureMessage if(${TotalClient_SS ...
- jmeter之beanshell断言实例
.首先储存一个接口的响应结果,比如在http请求的后面添加beanshell后置处理器(BeanShell PostProcessor)来储存http请求的响应结果: import org.json. ...
- jmeter使用BeanShell断言
1. 首先存储一个接口的响应结果,如在http请求的BeanShell PostProcessor: import java.io.UnsupportedEncodingException; Syst ...
- Jmeter之BeanShell 断言
作者:季沐测试笔记 原文地址:https://www.cnblogs.com/testero/p/15436864.html 博客主页:https://www.cnblogs.com/testero ...
- Jmeter通过BeanShell Sampler获取Jmeter的Bin路径,并存入变量供后面的脚本调用
Jmeter的Bin路径是其运行路径,当把自动化测试的脚本放在Bin目录下时,为了将存储CSV的数据文件以及脚本的路径都设置成相对路径,我们需要获取到Jmeter的运行路径: 通过BeanShell ...
随机推荐
- 使用PowerShell连接Ubuntu
Ubuntu安装PowerShell Ubuntu安装PowerShell帮助文档 # Download the Microsoft repository GPG keys wget -q https ...
- Appium学习笔记
1.创建Maven项目 2.POM文件添加java-client依赖坐标 3.修改脚本,执行脚本 UIAutomator2(自动装置引擎) 4723:Appium服务器端口,用来监听脚本发送过来的指令 ...
- 华为SEO搜索引擎主管招聘内容
http://www.wocaoseo.com/thread-166-1-1.html 华为SEO搜索引擎主管招聘内容: 职位职责 1. 提出全站的SEO策略和实施计划,推动和监督计划实施:负责提升各 ...
- Photon PUN 二 大厅 & 房间
一, 简介 玩过 LOL , dota2, 王者荣耀 等MOBA类的游戏,就很容易理解大厅和房间了. LOL中一个服务器就相当与一个大厅; 什么电一,电二 ,,, 联通一区等 每一个区就相当于一个大厅 ...
- Fitness - 07.07
倒计时177天 运动53分钟,共计8组半,5.5公里.拉伸5分钟. 每组跑步5分钟(6.5KM/h),走路1分钟(5.5KM/h). 感冒+姨妈耽搁了大半月的时间 终于进入第六周的训练了~~!加油~! ...
- SpringBoot 拦截器获取http请求参数
SpringBoot 拦截器获取http请求参数-- 所有骚操作基础 目录 SpringBoot 拦截器获取http请求参数-- 所有骚操作基础 获取http请求参数是一种刚需 定义拦截器获取请求 为 ...
- Jmeter逻辑控制器,简单操作
1. 2. 循环控制器可以设置请求的循环次数或永久循环, . 作用:改控制器下的取样器请求可以循环运行. 3. 请求需要拖拽到循环控制器里, 4.循环次数乘以线程数 得到如下图: 成功了 二. 事务 ...
- 操作DOM对象
操作DOM对象 目录 操作DOM对象 1. 核心 2. 获得Dom节点 3. 更新节点 1. 操作文本 2. 操作CSS 4. 删除节点 5. 插入节点 1. 追加(将已存在的节点移到后面) 2. 创 ...
- hacker101 CTF 学习记录(二)
前言 无 Easy-Postbook 拿到功能有点多,先扫一遍目录 .Ds_Store没有啥东西,page是个静态页面 随便注册个账号,登录后已经有2篇文章,第一篇文章的id是1 自己创建文章,将ur ...
- Effective Objective-C 的读书笔记
本文主要是摘录了 <Effective Objective-C 2.0>一书中提到的编写高质量iOS 代码的几个方法. 1 熟悉Objective -C 1.1 OC 起源 OC 为C语言 ...