• jmeter后置处理器JSON Extractor


    JMeter处理responses 的json

    对于请求1返回的结果,处理以后作为请求2的参数,JMeter提供了正则表达式提取器

    如下:

    这里写图片描述

    这样也可以通过正则表达式获取responses的某个值 :  或者 "id":"(.*?)"

    但是对于大部分请求返回的结果,都是json,有一个更方便使用的插件:JSON Extractor 
    不过得首先下载插件 https://jmeter-plugins.org/wiki/JSONPathExtractor/

    下载后解压以后将lib和lib/ext中的jar包放到安装目录对应位置,重启即可

    简单介绍一下该插件怎么使用

    这里写图片描述

    该插件为:

    这里写图片描述

    Variable names : 名称 
    JSONPath Expression:JSON表达式 
    Match Numbers:匹配哪个,可为空即默认第一个 
    Default Value:未取到值的时候默认值

    比如某一请求的返回值为:

    {"statusCode":200,"data":{"userId":"4a2cbe616eb74f0d99190af072c8dea6","token":"37e7a9e198186f5a443e50e6138a5bd20bd"}}

    这里因为返回的是json数据,$.data.token,获取token的值

    但是有碰到一个坑 
    另外一个接口请求返回值为:

    {"statusCode":200,"data":[{"code":"407949","id":"aa477ad2085d492a99b877d14343d68d","name":"90一中4545"}]}

    同样,使用$.data.id去提取id的值时,发现获取到的数据为空 
    原来这个responses 的data为数组,故应为 $.data[0].id 提取第1个值

    如下:

    这里写图片描述

    备注: JSON中 data 是一个对象数组, data[0] 代表取的是第一个数组的对象,data[*] 代表取全部对象。

    .id 取的是id的值 .name取的是name的值

    例如,返回值为:

    {
    :   "status":0,
    :   "data":
    :   {
    :   :   "resources":
    :   :   [
    :   :   :   {
    :   :   :   :   "id":1,
    :   :   :   :   "name":"广告位"
    :   :   :   },
    :   :   :   {
    :   :   :   :   "id":2,
    :   :   :   :   "name":"优惠券"
    :   :   :   },
    :   :   :   {
    :   :   :   :   "id":3,
    :   :   :   :   "name":"实物赞助"
    :   :   :   }
    :   :   ],
    :   :   "trades":
    :   :   [
    :   :   :   {
    :   :   :   :   "id":546,
    :   :   :   :   "tradeName":"IT/互联网"
    :   :   :   },
    :   :   :   {
    :   :   :   :   "id":547,
    :   :   :   :   "tradeName":"游戏/动漫"
    :   :   :   },
    :   :   ],

    这里要分别取resources 和 trades 的所有id值,表达式可以写:$.data.trades[*].id 。(代表
    trades下所有子集中的id)
     
     

    jmeter后置处理器 JSON Extractor取多个变量值:

    1、需要获取响应数据的请求右键添加-后置处理器-JSON Extractor

    2、如果要获取json响应数据多个值时,设置的Variable names (后续引用变量值的变量名设置)与JSON Path expressions及Default Values的数量一定要一致;

    如json体如下:

     {
    "msg": "success", "code": "200", "data": { "total": 3, "aList": [ { "Time": 1501534900012, "id": 1 }, { "Time": 1501516732000, "id": 2 }
             ] } }

    如上定义后,

    Variable names设置为id1;id2

    JSON Path expressions定义为$.data.aList[0].id;$.data.aList[1].id

    Default Values:0;0

    变量id1取值将为2,变量id2取值为3;若取不到id1的值会根据Default Values定义默认赋值为0

    可以通过添加beanshell打印id1、id2的值验证结果

    print("id1:"+vars.get("id1"));
    print("id2:"+vars.get("id2"));

     
    转载于:http://blog.csdn.net/fu_tester/article/details/77838546
                  https://www.cnblogs.com/lxs1314/p/6894520.html
  • 相关阅读:
    财务系统重复付款case分析及解决方案
    MySQL体系结构
    安装篇九:安装wordpress(5.4版本)
    安装篇八:配置 Nginx 使其支持 MySQL 应用
    安装篇七:配置 Nginx 使其支持 PHP 应用
    安装篇六:安装PHP(7.2.29版本)
    安装篇五:安装MySQL(5.6.38版本)
    安装篇四:安装NGINX(1.4.0版本)
    安装篇三:系统初始化设置
    安装篇二:CentOS 6.9系统安装
  • 原文地址:https://www.cnblogs.com/youlanfeier/p/8617119.html
Copyright © 2020-2023  润新知