后置处理器之JSON提取器

By:授客 QQ:1033553122

测试环境

JMeter 5.4.1

插件介绍

JSON后置处理器(PostProcessor)允许使用 JSON Path 语法从JSON格式的响应中提取数据。类似正则表达式提取器,必须位于HTTP采样器、或者其它可以返回JSON数据的采样器下,作为子结点。

插件参数

Name

显示在脚本树结构中的名称

Apply to:

这用于可以生成子采样器的采样器,比如携带嵌套资源的HTTP采样器、邮件读取器或者由事务控制器控制的采样。

  • Main sample only

    仅适用于主采样

  • Sub-samples only

    仅适用于子采样

  • Main sample and sub-samples

    适用于主采样和子采样

  • JMeter Variable Name to use

    提取适用于命名变量的内容。

Names of created variables

由英文分号 ;分隔的变量名称,这些变量分别用于存储对应JSON-PATH表达提取的结果(必须匹配JSON-PATH表达式数量)。

JSON Path Expressions

由分号分号 ;分割的JSON-PATH表达式 (必须匹配变量的数量)

Default Values

如果对应变量的JSON-PATH表达式不返回任何结果时,对应变量的默认值,由英文分号 ;分隔(必须匹配变量的数量)

Match Numbers

对于每个JSON-PATH表达式,如果表达式查询到多个结果时,你可以选择提取那个值作为变量值。

  • 0 表示随机(匹配数字的默认值)
  • -1 提取所有结果,这些结果将存储到名为<variable name>_N的变量(N取值从1到提取结果的数量)
  • X 表示提取第X个结果。如果第X个结果不存在,则不会返回任何值,直接使用对应默认值作为变量。

这些匹配数字必须使用英文分号相隔,且匹配JSON-PATH表达式的数量。如果不配置匹配数字,默认使用0作为每个表达式的默认值。

注意:不管对应的JSON-PATH表达式能否查询到结果,程序都会将结果数(如果查询不到结果则设置为 0 )存储到变量 <variable name>_matchNr

Compute concatenation var

如果勾选,则表示如果对应表达式查询到多个结果,插件将使用 , 连接这些值并存储为命名为<variable name>_ALL的变量中。

插件使用示例

其中登录请求返回类似如下信息

{"token":"73ab6c33c39a46c1b27ae314b7a7eb1e","userName":"测试","warehouseList":[{"warehouseCode":"001DSC","warehouseName":"测试仓库","areas":[{"zonegroupCode":"A1","zonegroupdescr":"A1区"},{"zonegroupCode":"A2","zonegroupdescr":"A2区"},{"zonegroupCode":"A3","zonegroupdescr":"A3区"},{"zonegroupCode":"A4","zonegroupdescr":"A4区"}]}],errorMsgPrams":["SUCCESS"]}

通过Debug PostProcessor观察到提取的相关变量值如下

JMeterVariables:
areas=[{"zonegroupCode":"A1","zonegroupdescr":"A1区"},{"zonegroupCode":"A2","zonegroupdescr":"A2区"},{"zonegroupCode":"A3","zonegroupdescr":"A3区"},{"zonegroupCode":"A4","zonegroupdescr":"A4区"}]
areas_matchNr=1
token=d50350c345824a95ba8e1e4d43270fff
token_matchNr=1
zonegroupCode_1=A1
zonegroupCode_2=A2
zonegroupCode_3=A3
zonegroupCode_4=A4
zonegroupCode_5=A5
zonegroupCode_matchNr=5

JSON-PATH表达式介绍

JsonPath表达式可以使用点标记

$.store.book[0].title

或者括号标记

$['store']['book'][0]['title']

操作符

操作符 描述
$ 需要查找的根元素。所有JSON PATH表达式都以这个开头
@ 正被某个过滤谓词处理的当前节点(The current node being processed by a filter predicate)
* 通配符。可以表示一个名称或者数字
.. 深度扫描。可以表示一个名称
.<name> 获取子节点。
['<name>' (, '<name>')] 括号标记的子结点或者子孙结点
[<number> (, <number>)] 单个或多个数组索引。
[start:end] 数组切片操作符。注意,不含end
[?(<expression>)] 过滤表达式,必须为boolean表达式

函数

可以在path表达式末尾调用函数--表达式输出即为函数的输入。常见函数如下

函数 描述 输出类型
min() 获取数字数组的最小值。 Double
max() 获取数字数组的最大值。 Double
avg() 获取数字数组的平均值。 Double
stddev() 获取数字数组的标准方差。 Double
length() 获取数组长度 Integer
sum() 获取数字数组的总和。 Double
append(X) 添加一个元素到JSON-PATH表达式输出数组中 同输入

过滤器操作符

过滤器为用于过滤数组的逻辑表达式,一个典型的过滤器 [?(@.age > 18)] ,这里 @代表正被处理的当前项。可以使用逻辑操作符 &&||创建更复杂的过滤器。字符串文字必须用单引号或者双引号引起来,形如 ([?(@.color == 'blue')] 或者 [?(@.color == "blue")])

操作符 描述
== 等于
!= 不等于
< 小于
<= 小于等于
> 大于
>= 大于等于
=~ 匹配正则表达式,形如[?(@.name =~ /foo.*?/i)]
in 包含于,形如 [?(@.size in ['S', 'M'])]
nin 不包含于
subsetof 子集,形如 [?(@.sizes subsetof ['S', 'M', 'L'])]
anyof 操作符左侧值必须和右侧有交集(left has an intersection with right),形如[?(@.sizes anyof ['M', 'L'])]
noneof 操作符左侧值和右侧无交集
size 操作符左侧数组或者字符串长度必须匹配右侧
empty 操作符左侧必须为空数组或者字符串

JSON PATH示例

给定如下json

{
"store": {
"book": [
{
"category": "reference",
"author": "Nigel Rees",
"title": "Sayings of the Century",
"price": 8.95
},
{
"category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
},
{
"category": "fiction",
"author": "Herman Melville",
"title": "Moby Dick",
"isbn": "0-553-21311-3",
"price": 8.99
},
{
"category": "fiction",
"author": "J. R. R. Tolkien",
"title": "The Lord of the Rings",
"isbn": "0-395-19395-8",
"price": 22.99
}
],
"bicycle": {
"color": "red",
"price": 19.95
}
},
"expensive": 10
}
JsonPath 结果
$.store.book[*].author 表示所有书籍的作者。
$..author 表示所有作者
$.store.* 所有东西--所有书籍和自行车。
$.store..price 所有东西的价格
$..book[2] 第三本书
$..book[-2] 倒数第二本书
$..book[0,1] The first two books
$..book[:2] 索引为0到2(不含2)的所有书籍
$..book[1:2] 索引为1到2(不含2)的所有书籍
$..book[-2:] 最后两本书
$..book[2:] 索引为2及其往后的所有书籍。
$..book[?(@.isbn)] 携带isbn号的所有书籍 an ISBN number
$.store.book[?(@.price < 10)] 商店中价格低于10的所有书籍。
$..book[?(@.price <= $['expensive'])] 所有非 "expensive"的书籍
$..book[?(@.author =~ /.*REES/i)] 所有匹配正则表达式(忽略大小写)的书籍
$..* 返回所有东西
$..book.length() 书籍数量

参考连接

https://github.com/json-path/JsonPath

https://jmeter.apache.org/usermanual/component_reference.html#JSON_Extractor

JMeter 后置处理器之JSON提取器的更多相关文章

  1. jmeter后置处理器之Json提取器详解

    此提取器用于提取请求返回结果中的某个值或者某一组值,用法比正则表达式要简单,标准写法为$.key,其中key为返回结果map中的一个键,如果是多层则继续用.key进行即可,如果遇到key的value值 ...

  2. JMeter 后置处理器之正则表达式提取器详解

    后置处理器之正则表达式提取器详解   by:授客 QQ:1033553122 1. 添加正则表达式提取器 右键线程组->添加->后置处理器->正则表达式提取器 2. 提取器配置介绍 ...

  3. Jmeter后置处理器,正则表达式提取器的使用

    [使用场景]:下一个请求参数需要从上一个请求的响应数据中获取 [jmeter正则表达式说明]:使用perl正则表达式(可参考:http://www.runoob.com/perl/perl-regul ...

  4. Jmeter后置处理器之JSON Extractor

    一.使用场景 json extractor后置处理器用在返回格式为json的HTTP请求中,用来获取返回的json中的某个值.并保存成变量供后面的请求进行调用或断言等. 二.使用方法 步骤一:选择HT ...

  5. jmeter里面Dug Sampler 和json提取器的用法

    1.编写用户详情请求 2.查看结果树 一级一级往上查找父集 3.添加json提取器 步骤:点击[用户详情]请求->添加->后置处理器->json提取器 把查看结果树里面的JSON P ...

  6. 【Vlog】Jmeter之使用beanshell将json提取器中的多个值拼接为一个列表

    场景如下: json提取器返回了当前登录用户的所有好友id,然而下一个接口是把好友id拼成一个数组进行传参的,现需将所有的好友ID拼接起来,类似ID1,ID2,ID3......这样 beanshel ...

  7. jmeter数据关联_后置处理器_正则表达式提取器

  8. jmeter后置处理器之正则表达式

    一.基本用法——提取某个值 场景:提取某个值,保存成变量,供后面的接口使用 步骤: 1.运行脚本,从响应结果中查找要提取的值,找到左右边界. 例如要获取“patientInfoId”作为下一个请求的参 ...

  9. jmeter后置处理器之正則表達式提取器

    新浪围脖>@o蜗牛快跑o    使用这个组件时,注意使用带分组的正則表達式 使用正则分组方便提取干净数据.以免再次处理数据字符串 正則表達式在线工具推荐:点击打开链接 正則表達式语法參考:点击打 ...

  10. jmeter接口之json提取器应用

    在接口测试中有一个这样的场景:业务接口需要用到登录token:下个接口需要用到前个接口返回值作为参数,该怎么实现? 首先先看下登录.业务接口,本文用的jmeter版本为5.4.1 一.json提取器设 ...

随机推荐

  1. 【C#】字符串按条件替换关键字

    private string MyReplace(string json, string keyWord, string newWord, Func<string, string, bool&g ...

  2. C# WinForm控件及其子控件转成图片(支持带滚动条的长截图)

    概述(Overview) 参考了网上的分析,感觉都不太理想:1.一个控件内如果包含多个子控件时没有考虑顺序问题:2.超出控件可显示区域时不能长截图,有滚动条会多余截取了滚动条.这个随笔旨在解决这个问题 ...

  3. linux开机出现initramfs无法进入系统

    linux开机出现initramfs无法进入系统 开机后进入initramfs模式,无法进入系统时不要慌: 想一想自己根分区的文件系统名是什么,有的人的是/dev/sda1,有的人的是/dev/sda ...

  4. swap文件修复

    修复swap文件 vim -r /aaaa.swap

  5. C基本知识

    1 C基本数据类型 C基本的数据类型说明: 2 字节序 测试代码: #include <stdio.h> typedef unsigned char *byte_pointer; void ...

  6. taro 使用taro中的vue来完成小程序的开发

    网址:https://taro-docs.jd.com/taro/docs/README 2.1.简介 Taro 是一个开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发 ...

  7. 剑指Offer-48.不用加减乘除做加法(C++/Java)

    题目: 写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 分析: 将加法还原成最原始的计算方法,也就是分别计算进位和非进位的和,最后再将这两部分合起来,便是和.我们可以利 ...

  8. 关于 Elasticsearch 不同分片设置的压测报告

    摘要 为了验证当前集群经常出现索引超时以及请求拒绝的问题,现模拟线上集群环境及索引设置,通过压测工具随机生成测试数据,针对当前的 850 个分片的索引,以及减半之后的索引,以及更小分片索引的写入进行压 ...

  9. MySQL插入中文数据时发生错误或者乱码的一些坑

    最近新入职的工作,火急火燎就下了个mysql,没想到安装时配置没弄好.今天在测试数据时,插入中文数据到mysql都是问号,先后查了半天修改表结构,数据库编码,my.ini文件都没有用. 首先第一步,打 ...

  10. Pycharm import faker 和 colorlog提示“No module name faker/colorlog”

    问题: Pycharm import faker / colorlog,下划线爆红,提示"No module name faker/colorlog" 排查,检查pycharm 该 ...