DataGear 添加 Http 数据集是请求头 JSON 的格式说明

Posted 毕小宝

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DataGear 添加 Http 数据集是请求头 JSON 的格式说明相关的知识,希望对你有一定的参考价值。

背景

玩了一下 DataGear ,添加了一个 Http 接口的数据集,由于目标接口请求必须包含 Token 信息,所以按照配置提示添加 JSON 格式的头信息时,想象成了 JSON 对象,结果预览请求始终报错。

DataGear 的后台异常信息:

org.datagear.analysis.support.HeaderContentNotNameValueObjArrayJsonException: The json must be name/value object array] with root cause

org.datagear.analysis.support.HeaderContentNotNameValueObjArrayJsonException: The json must be name/value object array

当然,在不了解源码之前,这个异常看不懂,也百度不到相关资料,没办法,下载源码来看看。

本文记录这个问题的解决过程,主要注意两个问题:

  1. Http 数据集请求头JSON的格式,提示信息很准确,竟然没看到:

    2.响应JSON路径,这个是定位数据集数组的属性,如果 http 接口响应结果直接是数组,就不需要填写。

源码下载及编译

下载源码,打包的时候单元测试很多过不了,直接跳过。

找到 datagear-analysis 模块的 HttpDataSetTest 单元测试类,改下 http 数据集为目标路径,然后再异常的代码的地方打断点调试。

最终定位到请求头信息参数配置错误,传入的是一个 JSONObject,而 DataGear 要求的是一个 JSONArray 且数组元素的 key 必须时 name/value

启示录

为什么请求头 JSON 会想到传递一个 JSON 对象呢?大概是受请求体 JSON 提示信息影响,认为就是普通的JSON对象:

两个JSON 格式其实是不一样的,提示信息很清晰,怪自己眼睛看不清晰。

细想一下,确实是用列表比较合适,直接遍历列表设置到 Header 头中,比处理不可预测的 JSON 对象方便多了,这么处理还是很有道理的!

以上是关于DataGear 添加 Http 数据集是请求头 JSON 的格式说明的主要内容,如果未能解决你的问题,请参考以下文章

DataGear 添加 Http 数据集是请求头 JSON 的格式说明

Vue3 在Axios中添加数据来自于sessionStorage的请求头(请求头添加token)

Vue3 在Axios中添加数据来自于sessionStorage的请求头(请求头添加token)

Vue3 在Axios中添加数据来自于sessionStorage的请求头(请求头添加token)

Vue3 在Axios中添加数据来自于sessionStorage的请求头(请求头添加token)

androidpost添加到请求头