• metersphere提取的字典需要修改其中某个key的值后作为下一接口入参


    在测试过程中遇到这样的一种场景,下一个接口的某个字段入参为一个json对象,该对象的值是上一个接口返回的内容,但是其中的某个值不是,需要修改后才能作为下个接口的入参整体传入

    上一个接口返回的内容如下:

    1. {
    2. "status": "SUCCESS",
    3. "code": "0000",
    4. "msg": "处理成功",
    5. "payload": [{
    6. "schemeName": "内外",
    7. "orderScheme": null,
    8. "createdDate": "2024-06-04T00:30:52.000+00:00",
    9. "list": [{
    10. "startAccount": "AAA",
    11. "targetAccount": "BBB",
    12. "accountName": "内",
    13. "orderAccount": 1,
    14. "orderScheme": null,
    15. "currency": "RMB",
    16. "amount": null
    17. },
    18. {
    19. "startAccount": "AAA",
    20. "targetAccount": "BBB",
    21. "accountName": "外",
    22. "orderAccount": 5,
    23. "orderScheme": null,
    24. "currency": "USD",
    25. "amount": null
    26. }
    27. ]
    28. }
    29. ]
    30. }

    下一个接口的入参为payload中的所有内容,但是amount的值来源另外一个接口

    解决办法如下:

    使用后置脚本beanshell实现如下

    1. import org.json.*;
    2. //获取请求返回值
    3. String response_data = prev.getResponseDataAsString();
    4. // 格式转换成json对象
    5. JSONObject data_obj = new JSONObject(response_data);
    6. if(data_obj.get("payload").equals(null)){
    7. log.info("接口返回数据为空");
    8. } else{
    9. JSONArray payload_array=data_obj.getJSONArray("payload"); //将payload转成数组
    10. log.info(data_obj.toString());
    11. // 获取payload的第一组数据:payload[0]
    12. JSONObject payload_0 = (JSONObject)payload_array.getJSONObject(0);
    13. log.info(payload_0.toString());
    14. //list转成数组
    15. JSONArray list_array=payload_0.getJSONArray("list");
    16. JSONObject list_0 = (JSONObject)list_array.getJSONObject(0);
    17. log.info("list 0 的值:");
    18. log.info(list_0.toString());
    19. Interpreter interpreter = new Interpreter();
    20. interpreter.set("list_0", list_0);
    21. // 提取上一步骤设置的金额
    22. String set_amount = vars.get("amount");
    23. log.info(set_amount);
    24. list_0.put("amount", set_amount);
    25. log.info(list_0.toString());
    26. // 将修改后的字典设置参数
    27. vars.put("currencySwapKeyPath",list_array.toString());
    28. }

  • 相关阅读:
    基于C#+MySQL的停车场管理系统设计与实现
    Tomcat加载静态资源--防止SpringMVC拦截
    csapp第三章读书笔记
    Qt开发Android环境配置
    MySQL创建表的时候建立联合索引的方法
    Windows + Git + TortoiseGit + Github
    Maven 快速入门
    ‘vue‘ 不是内部或外部命令,也不是可运行的程序或批处理文件
    高压 36V 四通道 DMOS 全桥驱动MS3988/3988N
    数据分析-Pandas数据的探查面积图
  • 原文地址:https://blog.csdn.net/weixin_46361114/article/details/139470863