前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Jmeter系列(26)- 详解 JSON 提取器

Jmeter系列(26)- 详解 JSON 提取器

作者头像
小菠萝测试笔记
发布2020-06-24 10:39:09
2.1K0
发布2020-06-24 10:39:09
举报

为什么要用 JSON 提取器

  • JSON 是目前大多数接口响应内容的数据格式
  • 在接口测试中,不同接口之间可能会有数据依赖,在 Jmeter 中可以通过后置处理器来提取接口的响应内容
  • JSON 提取器是其中一个可以用来提取响应内容的元件
JSON 提取器的应用场景
  1. 提取某个特定的值
  2. 提取多个值
  3. 按条件取值
  4. 提取值组成的列表

JSON 提取器

我们通过实际栗子去讲述理论知识点

JSON 提取器界面介绍

字段含义

字段

结果

Apply to

应用范围,选默认的 main sample only 就行了

Names of created variables

接收提取值的变量名 多个变量用 ; 分隔 必传

JSON Path expression

json path 表达式,用来提取某个值 多个表达式用 ; 分隔 必传

Match No.(0 for Random)

取第几个值,多个值用 ; 分隔 0:随机,默认 -1:所有 1:第一个值 非必传

Compute concatenation var(suffix_ALL)

如果匹配到多个值,则将它们都连接起来,不同值之间用 , 分隔 变量会自动命名为 <variable name>_ALL

Default Values

缺省值,匹配不到值的时候取该值,可写error 多个值用 ; 分隔 非必传

  • 接收提取值的变量名
  • 多个变量用 分隔

;

  • 必传

JSON Path expression

  • json path 表达式,用来提取某个值
  • 多个表达式用 分隔

;

  • 必传

Match No.(0 for Random)

  • 取第几个值,多个值用 分隔

;

  • 0:随机,默认
  • -1:所有
  • 1:第一个值
  • 非必传

Compute concatenation var(suffix_ALL)

  • 如果匹配到多个值,则将它们都连接起来,不同值之间用 分隔

,

  • 变量会自动命名为

<variable name>_ALL Default Values

  • 缺省值,匹配不到值的时候取该值,可写error
  • 多个值用 分隔

;

  • 非必传

入门栗子

栗子的前提

这个栗子,我都会以这个地址的接口来完成 JSON 提取器的实战栗子,大家可以注册个账号玩一玩哦

http://api.yesapi.cn/docs.php?keyword=%E4%BC%9A%E5%91%98&channel=api

测试计划树结构

下面多个栗子都以这个测试计划为基础哦

提取某个特定的值的栗子

登录接口响应

登录是执行其他接口的前置接口,所以要获取用户登录后的 token、uuid

提取 token

相对路径的方式

提取 uuid

绝对路径的方式

其他接口调用 token、uuid

知识点

  • 提取某个特定值的方式有两种:绝对路径、相对路径
  • 提其他接口可以通过 这种格式,来获取提取到的值

${var}

综合栗子

  • 上面讲的是使用 JSON 提取器时的一个流程
  • 在实际项目中,接口的响应内容肯定是非常复杂的,而我们需要提取的值也是多样化的,需要通过各种实战栗子来讲述清晰

JSON 字符串

这也是某个接口返回的响应内容,后面的栗子也是以这个 JSON 字符串为基础来提取各种值

感兴趣也可以自己玩一玩:http://api.yesapi.cn/docs-api-App.User.GetList.html

代码语言:javascript
复制
{
    "ret": 200,
    "msg": "V2.5.1 YesApi App.User.GetList",
    "data": {
        "total": 3,
        "err_msg": "",
        "err_code": 0,
        "users": [
            {
                "role": "user",
                "status_desc": "正常",
                "reg_time": "2020-06-22 15:19:51",
                "role_desc": "普通会员",
                "ext_info": {
                    "yesapi_nickname": "",
                    "yesapi_points": 0
                },
                "uuid": "6D5EDCB459F0917A98106E07D5438C58",
                "username": "fangjieyaossb",
                "status": 0
            },
            {
                "role": "user",
                "status_desc": "正常",
                "reg_time": "2020-06-22 14:27:17",
                "role_desc": "普通会员",
                "ext_info": {
                    "yesapi_nickname": "",
                    "yesapi_points": 0
                },
                "uuid": "0164DC0680F84DCE40D3DD4A36640ECA",
                "username": "fangjieyaossa",
                "status": 0
            },
            {
                "role": "admin",
                "status_desc": "正常",
                "reg_time": "2020-03-23 22:48:32",
                "role_desc": "管理员",
                "ext_info": {
                    "yesapi_nickname": "",
                    "yesapi_points": 0
                },
                "uuid": "079BF6BB82AFCFC7084F96AECAF0519F",
                "username": "fangjieyaoss",
                "status": 0
            }
        ]
    }
}

提取单个值

Jsonpath

结果

$.data.total

2

$..total

2

$..users[0].role

user

$..uuid

079BF6BB82AFCFC7084F96AECAF0519F

$.data.users[0].ext_info.yesapi_points

0

重点
  • 如果匹配到多个值(像 ),也只能提取到一个值

$..uuid

  • 如果想提取匹配到的所有 uuid,可以设置为 -1,结果如下图

还会告诉你匹配了多少个值 {uuid_matchNr} ,记住,调用变量时,不再是 {uuid} 而是 {uuid_1} 、 {uuid_2}

利用切片提取单个值

和 Python 切片一样的原理

Jsonpath

结果

$..users[2]

第三个 users

$..users[-2]

倒数第二个users

$..users[0,1]

前面两个users

$..users[:2]

第一、二个users

$..users[1:2]

第二个users

$..users[-2:]

倒数两个users

$..users[1:]

第二个开始的所有users

提取多个值

  • 四种写法类似,选一种方法自己熟记即可
  • 重点:提取多个值,提取器的 必须填 -1

Match No.

$.data.users[*].role

提取所有 role 字段值

[*] 表示取数组的所有元素

$..users..role_desc

提取所有 role_desc 字段值

$..reg_time

提取所有 reg_time 字段值

$..[*].username

提取所有 username 字段值

按条件提取值

有时候只需要提取某个特定条件下的参数值

语法格式
代码语言:javascript
复制
[?(expression)]
栗子

Jsonpath

结果

$..users[?(@.uuid)]

提取 users 里面包含 uuid 字段的记录

$..users[?(@.reg_time > '2020-06-01')]

提取 reg_time 字段大于 2020-06-01 的记录

$..users[?(@.role_desc =~ /.*会员.*?/i)]

提取 role_desc 字段包含会员的记录

$..users[?(@.status == 0)]

提取 status 字段等于 0 的记录

@

代表当前节点,像上面的四个栗子,@代表 users 这个列表字段

=~
  • 后面跟正则表达式,如果想提取包含指定字符的值,可以使用此正则:

/.*指定字符串.*?/i

  • 代表大小写不敏感

i

提取数据指定字段的值的栗子

提取 users 第一条记录的 uuid、username 字段的值

代码语言:javascript
复制
$..users[0].['uuid','username']
测试结果
代码语言:javascript
复制
new_1={"uuid":"6D5EDCB459F0917A98106E07D5438C58","username":"luojunjiessb"}

勾选 Compute concatenation var 的栗子

JSON 提取器
测试结果
代码语言:javascript
复制
uuid_1=6D5EDCB459F0917A98106E07D5438C58
uuid_2=0164DC0680F84DCE40D3DD4A36640ECA
uuid_3=079BF6BB82AFCFC7084F96AECAF0519F
uuid_ALL=6D5EDCB459F0917A98106E07D5438C58,0164DC0680F84DCE40D3DD4A36640ECA,079BF6BB82AFCFC7084F96AECAF0519F
uuid_matchNr=3

一个 JSON 提取器有多个 Jsonpath 的栗子

JSON 提取器
测试结果
代码语言:javascript
复制
uuid1_1=6D5EDCB459F0917A98106E07D5438C58
uuid1_2=0164DC0680F84DCE40D3DD4A36640ECA
uuid1_3=079BF6BB82AFCFC7084F96AECAF0519F
uuid1_matchNr=3
uuid2_1=6D5EDCB459F0917A98106E07D5438C58
uuid2_2=0164DC0680F84DCE40D3DD4A36640ECA
uuid2_3=079BF6BB82AFCFC7084F96AECAF0519F
uuid2_matchNr=3
知识点
  • 如果有多个 Jsonpath 的时候,每个字段都必填值,且字段值的数量要一致(像上图,每个字段都填了两个值)
  • 勾不勾 Compute concatenation var 都行
  • 字段值数量不一致则无法提取值
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-06-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么要用 JSON 提取器
    • JSON 提取器的应用场景
    • JSON 提取器
    • JSON 提取器界面介绍
      • 字段含义
      • 入门栗子
        • 栗子的前提
          • 测试计划树结构
            • 提取某个特定的值的栗子
              • 登录接口响应
              • 提取 token
              • 提取 uuid
              • 其他接口调用 token、uuid
            • 知识点
            • 综合栗子
              • JSON 字符串
                • 提取单个值
                  • 重点
                • 利用切片提取单个值
                  • 提取多个值
                    • $.data.users[*].role
                    • $..users..role_desc
                    • $..reg_time
                    • $..[*].username
                  • 按条件提取值
                    • 语法格式
                    • 栗子
                    • @
                    • =~
                    • 测试结果
                    • JSON 提取器
                    • 测试结果
                    • JSON 提取器
                    • 测试结果
                    • 知识点
                • 提取数据指定字段的值的栗子
                • 勾选 Compute concatenation var 的栗子
                • 一个 JSON 提取器有多个 Jsonpath 的栗子
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档