NIFI:FlowFile中的Json内容解析

时间:2017-08-17 13:41:23

标签: json groovy apache-nifi

我在GenerateFlowfile处理器中有text属性,如下所示:

[{
  "status": {
    "runStatus": "STOPPED"
  },
  "component": {
    "state": "STOPPED",
    "id": "ea5db028-015d-1000-5ad5-80fd006dda92"
  },

  "revision": {
    "version": 46,
    "clientId": "ef592126-015d-1000-bf4f-93c7cf7eedc0"
  }
} ]

和我的ExecuteScript处理器中的相关groovy脚本:

import org.apache.commons.io.IOUtils
import java.nio.charset.*
def flowFile = session.get();
if (flowFile == null) {
    return;
}

def slurper = new groovy.json.JsonSlurper()
def attrs = [:] as Map<String,String>

session.read(flowFile,
    { inputStream ->
        def text = IOUtils.toString(inputStream, StandardCharsets.UTF_8)
        text=flowFile.getAttribute('text')
        def obj = slurper.parseText(text)

        obj.each {k,v ->
           attrs[k] = v.toString()
        }
    } as InputStreamCallback)
flowFile = session.putAllAttributes(flowFile, attrs)
session.transfer(flowFile, REL_SUCCESS)

但是我的处理器仍然向我显示这样的异常,我应该改变什么? enter image description here

1 个答案:

答案 0 :(得分:2)

json的根元素是数组的问题

并尝试按地图.each{k,v-> ... }

进行迭代

可能你想让第一张地图像下面的代码一样迭代它

def obj=[ [a:1] ]

//this line will throw exception:
//obj.each{k,v-> println "$k->$v" }

//but this one not
obj[0].each{k,v-> println "$k->$v" }

fyi:有一个EvaluateJsonPath处理器可以从json流文件内容中提取属性并将结果放入属性