Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >JMeter 后置处理器之JSON提取器

JMeter 后置处理器之JSON提取器

作者头像
授客
发布于 2022-09-26 07:24:37
发布于 2022-09-26 07:24:37
1.1K00
代码可运行
举报
文章被收录于专栏:授客的专栏授客的专栏
运行总次数:0
代码可运行

后置处理器之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的变量中。

插件使用示例

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{"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观察到提取的相关变量值如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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表达式可以使用点标记

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$.store.book[0].title

或者括号标记

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$['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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
    "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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-08-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
JMeter之Json提取器详解
Json提取器属于JMeter的后置处理器, 所谓后置提取器就是请求结束后, 对响应结果进行变量提取, 提取变量是为了验证变量是否符合预期或者将变量值作为全局变量, 以供其他请求使用.
louiezhou001
2020/07/22
8.5K0
JSONPath 学习笔记
JSONPath 是一种类似于 XPath 的查询语言,用于在 JSON 数据中定位和提取特定部分的数据。它提供了一种简洁而强大的方式来导航和检索 JSON 结构中的元素,使得我们可以轻松地从复杂的 JSON 数据中提取所需的信息。
授客
2024/12/14
1540
JSONPath 表达式
大家好,又见面了,我是你们的朋友全栈君。JSONPath 是参照,xpath表达式来解析xml文档的方式,json数据结构通常是匿名的并且不一定需要有根元素。JSONPaht 用一个抽象的名字$来表示最外层对象。
全栈程序员站长
2022/07/04
5060
介绍一款python解析json格式的利器(接口测试平台开发必备)
我们在python解析复杂的json一文中呢,是自己去封装了一个简单的json处理的代码,但是有时候还是不能满足需求。那么我们今天去介绍一捆json解析的利器--jsonpath。
雷子
2022/05/21
8760
介绍一款python解析json格式的利器(接口测试平台开发必备)
JsonPath实践(一)
最近团队开发了一个平台,功能界面类似postman,用例都还是单接口的用例,就是可以绑定一个用户的登录状态和一些常量。验证功能主要分为两类:1、系统验证(包括请求异常、HTTP状态码、通用响应结构验证);2、功能验证(包括业务code、文本内容等)。都是通过字符串解析和正则匹配来完成的。
FunTester
2020/08/13
1.5K0
推荐一款接口自动化测试数据提取神器 JSonPath
在之前分享中,给大家介绍过一篇:如何快速审核接口返回值全部字段解决方案,详见原文:接口自动化测试,一键快速校验接口返回值全部字段 。当时,提到解决这类问题,市面上常见的解决方案有两种:
测试开发技术
2021/06/24
1.4K0
推荐几个评价非常高的Python库
Python的标准库模块和类型太多,时区转换麻烦,而Arrow是一个更加智能的Python时间处理库。它实现并更新日期时间类型,支持创建、操作、格式化和转换日期、时间和时间戳,可以使用更少导入和代码处理日期和时间。
吾非同
2021/07/12
7420
JsonPath使用和示例
虫无涯
2023/08/14
3830
jsonPath-快速获取/设置json指定位置
在一些特殊场景中,可能 一串json有几个甚至上万个节点,那么要去获取里面某一个节点或者说设置某个json指定key的值,那就非常麻烦了,一般我们是通过递归来进行获取,获取后还需要再通过递归进行遍历设置值,所以相当来说非常麻烦。是否有已有现成的工具进行设置呢?
逍遥壮士
2022/06/15
2.2K0
jsonPath-快速获取/设置json指定位置
JsonPath实践(二)
本期接一下如何使用JSonpath标记语法处理,json对象中的数组主要内容是提取数组中对象和对象集合。
FunTester
2020/08/19
5240
【JMeter-4】JMeter关联:JMeter正则表达式提取器与JSON提取器
关于JMeter的使用,花费大量精力写了JMeter的一系列文章,有图有案例,一方面总结起来作为备忘,一方面希望能给初学者一些帮助。觉得有所帮助的朋友,请点个赞,对于疏漏之处也欢迎指教。
云深i不知处
2020/09/16
2.6K0
25.后置处理器之JSON提取器
JSON提取器用于提取请求的结果是json格式数据中的某个值或者某一组值。标准写法为$.key,其中key为返回结果json中的一个键,如果是多层则继续用.key进行即可,如果遇到key的value值为一个数组,则使用.key[n],其中n为数组中元素的index。
BUG弄潮儿
2020/06/15
7150
25.后置处理器之JSON提取器
Jmeter之json条件提取实战(三)
之前写过2篇json提取的文章【Jmeter篇】后置处理器之正则提取器、Json提取器Jmeter之json提取器实战(二)有时我们想通过接口响应数据中的默写条件进行提取对应的字段,这时,就可以用到json条件提取,可以提取对应的值进行使用或迭代。
王大力测试进阶之路
2020/02/10
1.3K0
JsonPath工具类封装
在经历过一些波折之后,总算是把JsonPath工具类的封装类写好了,时间仓促。没有太严格的测试,等有机会我再用Groovy进行单元测试框架spock写一些单测来验证一下。
FunTester
2020/09/08
1.8K0
JsonPath基本用法
本文主要介绍JsonPath的基本语法,并演示如何在Newtonsoft.Json中进行使用。
拓荒者IT
2019/09/24
3.1K0
JsonPath实践(五)
今天分享的内容是JSonpath过滤数据的API。这部分API分成两类:一类是运算符,例如:==、>、=~这些,一类是方法或者函数,例如:in、nin、anyof等等。
FunTester
2020/08/27
4710
自动化测试数据校验神器!
jsonpath和常规的json有哪些区别呢?在Python中,json是用于处理JSON数据的内置模块,而jsonpath是用于从JSON数据中提取特定数据的查询语言和相关库。
测试开发技术
2023/11/22
2950
自动化测试数据校验神器!
你真的会写接口自动化测试断言吗?
在接口测试中,断言是一项非常重要的操作,它是用来校验接口返回结果是否符合预期的一种手段。一般来说,接口测试断言大致可以分为以下几类:
一个正经的AI
2024/01/22
5300
你真的会写接口自动化测试断言吗?
Jmeter(十七) - 从入门到精通 - JMeter后置处理器 -上篇(详解教程)
后置处理器是在发出“取样器请求”之后执行一些操作。取样器用来模拟用户请求,有时候服务器的响应数据在后续请求中需要用到,我们的势必要对这些响应数据进行处理,后置处理器就是来完成这项工作的。例如系统登录成功以后我们需要获取SessionId,在后面的业务操作中服务器会验证这个SessionId,获取SessionId这个功能过程就可以用后置处理器中的正则表达式提取器来完成。
北京-宏哥
2020/07/16
2.9K0
JsonPath文档
本文翻译自官方文档,JsonPath表达式通常是用来路径检索或设置Json的。其表达式可以接受“dot–notation”和“bracket–notation”格式,例如.store.book[0].title、[‘store’][‘book’][0][‘title’]
全栈程序员站长
2022/07/02
3.4K0
JsonPath文档
相关推荐
JMeter之Json提取器详解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验