Jmeter之Json提取器详解(史上最全)
参考资料:https://www.bbsmax.com/A/D854lmBw5E/
Jsonpath在线测试:http://jsonpath.com/
实际工作中用到的一些场景:
- 提取某个特定的值
- 提取多个值
- 按条件取值
- 阵列取值(返回所有元素的列表/数组)
- 提取多个值
Jsonpath提取器需要另外安装
- 下载plugins-manager.jar加入其加入JMETER_HOME/lib/ext目录,
- 重新启动JMeter,
- 点击Options > Plugins Manager顶部菜单,
- 选择Available Plugins标签,
- 选择Json Plugins并双击应用更改并重新启动JMeter。
使用方法:
Json Path提取器应放在HTTP Sampler下。可设置的参数有:
- 变量名称:分号单独的变量名称,
- JSON Path Expressions:从json响应中提取内容的表达式,
- 匹配数字:-1对于所有,0对于随机的,n对于第n个,
- Compute concatenation var:创建一个${foo_ALL}包含所有提取值的串联的变量,
- 默认值:如果表达式不适用于正在处理的json文档,使用此处给定的默认值。
接下来用一个实际案例来演示Json提取的一些用法:
示例:有如下json
{
"code": 0,
"data": {
"total": 10,
"pageNo": 1,
"pageSize": 100,
"items": [
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560056,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735865761759234,
"createTime": 1591169490879,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560056,
"id": 1268082870707040258,
"close": 0,
"status": 2
},
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560092,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735866185383938,
"createTime": 1591169491390,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560092,
"id": 1268082872854523906,
"close": 0,
"status": 2
},
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560126,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735867363983362,
"createTime": 1591169491862,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560126,
"id": 1268082874830041089,
"close": 0,
"status": 2
},
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560164,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735867825356802,
"createTime": 1591169492296,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560164,
"id": 1268082876654563330,
"close": 0,
"status": 2
},
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560310,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735867003273217,
"createTime": 1591169493876,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560310,
"id": 1268082883277369345,
"close": 0,
"status": 2
},
{
"friendHeadLogoUrl": null,
"msg": "你好,我仰慕你的才华!",
"shield": 0,
"star": 0,
"friendNickname": "Auto",
"origin": 202,
"black": 0,
"memo": null,
"updateTime": 1591169560376,
"type": 2,
"userId": 1268082752079560705,
"friendId": 1267735868571942913,
"createTime": 1591169494629,
"blackUpdateTime": 0,
"addUpdateTime": 1591169560376,
"id": 1268082886439874561,
"close": 0,
"status": 2
}
],
"timestamp": null
},
"codeMsg": "success"
}
1、提取某个特定的值
Jsonpath | 结果 |
---|---|
$.data.total | 10 |
$..total | 10 |
$..items[1].userId | 1268082752079560705 |
2、提取多个值
- 比如要提取items列表里所有的friendId
$..friendId
$..[*].friendId
$.data.items[*].friendId
三种写法都可以,结果为:
Result[0]=1267735865761759234
Result[1]=1267735866185383938
Result[2]=1267735867363983362
Result[3]=1267735867825356802
Result[4]=1267735864650268673
Result[5]=1267735865363300353
Result[6]=1267735866688700417
Result[7]=1267735867003273217
Result[8]=1267735868232204289
Result[9]=1267735868571942913
注意:
使用时,需要用下标读取,如${friend_id_1}、${friend_id_2}........
特别说明一下,如果想要获取返回元素的数量,可以用${friend_id_matchNr}
也可以使用foreach控制器循环读取,这里不再描述。
3、按条件提取值
有时候只需要提取某个特定条件下的参数,比如现在想要提取创建时间为1591169490879的friendId
$.data.items[?(@.createTime ==1591169490879)].friendId
4、阵列提取
提取任何节点的某个key的值,比如提取friendId
$..friendId
结果为:
friend_all_1=1267735865761759234
friend_all_10=1267735868571942913
friend_all_2=1267735866185383938
friend_all_3=1267735867363983362
friend_all_4=1267735867825356802
friend_all_5=1267735864650268673
friend_all_6=1267735865363300353
friend_all_7=1267735866688700417
friend_all_8=1267735867003273217
friend_all_9=1267735868232204289
friend_all_ALL=1267735865761759234,1267735866185383938,1267735867363983362,1267735867825356802,1267735864650268673,1267735865363300353,1267735866688700417,1267735867003273217,1267735868232204289,1267735868571942913
friend_all_matchNr=10
_ALL下标是将所有元素组成一个list,像后续接口有时候参数是以数组形式来传参,这个函数就很有用,如果需要返回此函数,需要在json提取器中,勾选Compute concatenation var
5、提取多个值
json表达式:
$..['msg','friendId']
返回的变量如下:
two_1={"msg":"你好,我仰慕你的才华!","friendId":1267735865761759234}
two_10={"msg":"你好,我仰慕你的才华!","friendId":1267735868571942913}
two_2={"msg":"你好,我仰慕你的才华!","friendId":1267735866185383938}
two_3={"msg":"你好,我仰慕你的才华!","friendId":1267735867363983362}
two_4={"msg":"你好,我仰慕你的才华!","friendId":1267735867825356802}
two_5={"msg":"你好,我仰慕你的才华!","friendId":1267735864650268673}
two_6={"msg":"你好,我仰慕你的才华!","friendId":1267735865363300353}
two_7={"msg":"你好,我仰慕你的才华!","friendId":1267735866688700417}
two_8={"msg":"你好,我仰慕你的才华!","friendId":1267735867003273217}
two_9={"msg":"你好,我仰慕你的才华!","friendId":1267735868232204289}
two_ALL={"msg":"你好,我仰慕你的才华!","friendId":1267735865761759234},{"msg":"你好,我仰慕你的才华!","friendId":1267735866185383938},{"msg":"你好,我仰慕你的才华!","friendId":1267735867363983362},{"msg":"你好,我仰慕你的才华!","friendId":1267735867825356802},{"msg":"你好,我仰慕你的才华!","friendId":1267735864650268673},{"msg":"你好,我仰慕你的才华!","friendId":1267735865363300353},{"msg":"你好,我仰慕你的才华!","friendId":1267735866688700417},{"msg":"你好,我仰慕你的才华!","friendId":1267735867003273217},{"msg":"你好,我仰慕你的才华!","friendId":1267735868232204289},{"msg":"你好,我仰慕你的才华!","friendId":1267735868571942913}
two_matchNr=10
Jmeter之Json提取器详解(史上最全)的更多相关文章
- jmeter之json提取器详解
Json提取器详解 *Apply to:参照正则表达式提取器 *Names of created:自定义变量名. 变量名可以填写多个,变量名之间使用分号进行分隔. 一旦变量名有多个,则下方的json ...
- jmeter后置处理器之Json提取器详解
此提取器用于提取请求返回结果中的某个值或者某一组值,用法比正则表达式要简单,标准写法为$.key,其中key为返回结果map中的一个键,如果是多层则继续用.key进行即可,如果遇到key的value值 ...
- Java集合中List,Set以及Map等集合体系详解(史上最全)
https://blog.csdn.net/zhangqunshuai/article/details/80660974
- JMeter 后置处理器之正则表达式提取器详解
后置处理器之正则表达式提取器详解 by:授客 QQ:1033553122 1. 添加正则表达式提取器 右键线程组->添加->后置处理器->正则表达式提取器 2. 提取器配置介绍 ...
- Jmeter 正则表达式提取器详解(Regular Expression Exactor)
Jmeter 正则表达式提取器详解(Regular Expression Exactor) Name(名称):随意设置,最好有业务意义. Comments(注释):随意设置,可以为空 Apply to ...
- Jmeter之JSON提取器应用
在接口测试中有一个这样的场景:登录之后,需要进行昵称修改,怎么实现? 首先我们分别看下登录.昵称修改的接口说明: 以上业务中补充一点,昵称修改,还需要添加请求头Authorization传登录获取的t ...
- SpringBoot 默认json解析器详解和字段序列化自定义
前言 在我们开发项目API接口的时候,一些没有数据的字段会默认返回NULL,数字类型也会是NULL,这个时候前端希望字符串能够统一返回空字符,数字默认返回0,那我们就需要自定义json序列化处理 Sp ...
- [转载]DOS循环:bat/批处理for命令详解 (史上虽详尽的总结和说明~~)
--本文来源于TTT BLOG: http://www.yoyotao.net/ttt/, 原文地址:http://www.yoyotao.net/ttt/post/139.html 前言: 虽然以前 ...
- 【转】htop使用详解--史上最强(没有之一)
在管理进程时通常要借助一些工具,比较常用的就是ps和top了:不过CentOS还为我们提供了一个更加强大的工具htop,下面就来了解一下此工具的使用方法.一.安装htop htop工具在epel源中提 ...
随机推荐
- dede文章列表根据权重自定义排序
首先在这里说明一下,网上搜索织梦文章列表自定义的方式无非有以下几种: 1.修改配置文件,新增一个orderid字段,想法很好,但是!但是!!!可能是早期版本的缘故,不适合现在的v5.7系统!按照网上说 ...
- Struts2-Tiles 2.5.2 升级指南和通配符拓展
最近工程从Struts2.3.18升级Struts2.5.2导致相关联的插件都需要升级到相同版本,其中tiles的变化最大. 1.web.xml上 listener org.apache.struts ...
- unittest详解 跳过用例的执行(skip)
在执行测试用例时,有时候有些用例是不需要执行的,那我们怎么办呢?难道删除这些用例?那下次执行时如果又需要执行这些用例时,又把它补回来?这样操作就太麻烦了. unittest提供了一些跳过指定用例的方法 ...
- Java Mail 发送带有附件的邮件
1.小编用的是163邮箱发送邮件,所以要先登录163邮箱开启POP3/SMTP/IMAP服务方法: 2.下载所需的java-mail 包 https://maven.java.net/content/ ...
- React知识点整理
面试题:三大框架中数据绑定实现上有何绑定? 一.概述:是Facebook维护的一个构建用户界面的JS库,核心很精简,但是生态圈扩展很大. React:MVVM框架 React-Router:路由 Re ...
- MVC4.0接口学习
/// <summary> /// 正则验证身份证号是否合法 /// </summary> /// <param name="sIdCard"> ...
- ftp服务器搭建(二)
1.已经安装好了vsftpd 进入到根目录下的/etc目录 ls查看一下 2.拷贝一下上面的两个配置文件 我拷贝到了我新建的目录中了 3.查看现在的网络连接方式——我的是-net方式 当然其他方式也 ...
- 系统对 Device Tree Overlays 的支持方式
问题来源: 野火 iMX 6ULL 开发板资料. https://tutorial.linux.doc.embedfire.com/zh_CN/latest/linux_basis/fire-conf ...
- 五、数据类型(1):整数&&带小数点的数
1.整数 int printf("%d",...); scanf("%d",&...); 2.带小数点的数 double printf("%f ...
- Java中异常分类和Throw和Throws的区别
Java中异常分类和Throw和Throws的区别 1.异常分类 Throwable是Java中所有错误和异常的超类.它的下一级是Error和Exception 1.1 Error(错误) Error ...