我正在尝试使用JOLT规范转换输入JSON。我的输入中包含一个response元素,可以包含单个文本(案例1)值,也可以是JSON元素(案例2),如下所示:
JOLT规范:
recursive
Input(非JSON响应元素)。 ----案例1
[
{
"operation": "shift",
"spec": {
"@(1,status)": {
"@(2,output)": {
"response": "statusMessage"
},
"TERMINATED": {
"@(2,status)": "statusMessage"
},
"FAILED": {
"@(2,response)": "statusMessage"
},
"COMPLETED": {
"@(2,status)": "statusMessage"
}
},
"status": "status"
}
}
]
Input(JSON响应元素)。 ----案例2
{
"createTime": 1555623377858,
"updateTime": 1555623378681,
"status": "FAILED",
"output": {
"response": "Connection error."
}
}
在响应具有JSON元素的情况下,如果要为statusMessage分配“ reasonPhrase”,如何指定JOLT规范?
我的输出应如下所示
{
"createTime": 1555623377858,
"updateTime": 1555623378681,
"status": "FAILED",
"output": {
"response": {
"headers": {
"ETag": [
"W/\"5-fy9qFc+NorJ+Wkr0e1jnrXHAs9k\""
],
"Connection": [
"keep-alive"
],
"Content-Length": [
"5"
],
"Date": [
"Thu, 18 Apr 2019 21:36:18 GMT"
],
"Content-Type": [
"text/html; charset=utf-8"
],
"X-Powered-By": [
"Express"
]
},
"reasonPhrase": "Internal Server Error",
"body": "Error",
"statusCode": 500
}
}
}
答案 0 :(得分:2)
我认为我可以使用以下任一规范:
1)
[
{
"operation": "modify-overwrite-beta",
"spec": {
"statusMessage": "@(1,output.response)"
}
},
{
"operation": "modify-overwrite-beta",
"spec": {
"statusMessage": "@(1,output.response.reasonPhrase)"
}
},
{
"operation": "shift",
"spec": {
"status": "status",
"statusMessage": "statusMessage"
}
}
]
该链中的第一个规范会将响应值存储到statusMessage
字段中。第二个将使用嵌套的statusMessage
值(如果存在)覆盖reasonPhrase
字段。链中的最后一个规范仅保留了status
和statusMessage
字段。
2)
[
{
"operation": "shift",
"spec": {
"output": {
"response": {
"@(1,response)": "statusMessage[]",
"headers": {
"@(1,reasonPhrase)": "statusMessage[]"
}
}
},
"status": "status"
}
},
{
"operation": "modify-overwrite-beta",
"spec": {
"statusMessage": "=lastElement(@(1,statusMessage))"
}
}
]
它将创建一个名为statusMessage
的数组,如果response
是字符串,则该数组中将有一个元素,如果嵌套,则该数组中将有两个元素,第二个元素是所需的状态消息。因此,第二个规范用其数组中的最后一个元素覆盖了statusMessage
字段。