• 深入理解JMeter中的JSON Extractor


    Apache JMeter是一款出色的开源性能和功能测试工具,这款工具提供了丰富的功能和强大的扩展性,可以应对各种复杂的测试需求。当我们在进行接口测试时,经常会遇到需要从接口响应中提取信息并在后续请求中使用的情况。这时候,JMeter中的JSON Extractor就派上了用场。

    JSON Extractor是JMeter中的一个Post Processor组件,它可以根据JSON Path表达式从HTTP请求的响应结果中提取需要的信息。接下来,我们将通过一个具体的例子,详细介绍如何使用JSON Extractor。

    假设我们的HTTP请求返回了如下的JSON数据:

    1. {
    2. "dataDetail": [
    3. {
    4. "role_id": 1,
    5. "role_code": "132001",
    6. "role_name": "Administrator"
    7. },
    8. {
    9. "role_id": 2,
    10. "role_code": "132002",
    11. "role_name": "User"
    12. }
    13. ]
    14. }

    我们的任务是提取role_code为"132002"的对象的role_id。首先,在对应的HTTP请求下添加一个JSON Extractor,配置如下:

    • Names of created variables:命名提取字段的变量名。在这个例子中,我们输入my_role_id

    • JSON Path Expressions:输入对应的JSON Path表达式。在这个例子中,我们输入$.dataDetail[?(@.role_code=="132002")].role_id

    • Match No:输入匹配数字。在这个例子中,我们只关心第一个匹配的结果,因此输入1

    • Default Values:输入默认值。在这个例子中,我们可以输入NOT_FOUND作为默认值。

    下面是具体的配置:

    1. Names of created variables: my_role_id
    2. JSON Path Expressions: $.dataDetail[?(@.role_code=="132002")].role_id
    3. Match No: 1
    4. Default Values: NOT_FOUND

    配置完成后,JSON Extractor会在HTTP请求的响应结果中查找符合JSON Path表达式的值,并将找到的值保存在我们指定的变量中。在这个例子中,如果role_code为"132002"的对象存在,那么my_role_id就会保存这个对象的role_id;如果不存在,那么my_role_id的值就会是我们指定的默认值NOT_FOUND

    最后,在后续的请求中,我们就可以通过${my_role_id}的形式来使用这个提取出来的role_id了。

    总的来说,JMeter的JSON Extractor是一款极其强大的工具,只要我们正确地使用,就能轻松地从复杂的JSON响应中提取我们需要的信息。

  • 相关阅读:
    【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 数字排列游戏(200分) - 三语言AC题解(Python/Java/Cpp)
    WPF中prism模块化
    【重温基础算法】内部排序之快速排序法
    金九银十就靠它啦!共计1700页的Java岗面试核心MCA版,面试必胜!!
    腾讯云免费SSL证书申请流程_2023更新教程
    CTFSHOW菜狗杯 web
    分类树,我从2s优化到0.1s
    【Java每日一题】——第二十九题:超市购物程序设计(2023.10.13)
    echarts强制显示或不显示Y轴最大值最小值
    【应用SLAM技术建立二维栅格化地图】
  • 原文地址:https://blog.csdn.net/silgen/article/details/134405712