【问题标题】:Convert XML to JSON with additional id added in between将 XML 转换为 JSON,并在其间添加额外的 id
【发布时间】:2014-01-13 05:38:09
【问题描述】:

我正在使用 Mule ESB 3.5,这就是我想要做的:

XML -> 将其转换为对象 -> 使用 id 丰富此对象 -> 将其转换为 JSON。 为此,我使用 XML 到对象和对象到 Json 组件。 在将对象转换为 JSON 之前,使用 transactionId 填充对象的最佳方法应该是什么。

【问题讨论】:

    标签: xml json mule esb


    【解决方案1】:

    您可以直接转换为 JSON,然后使用 JavaScript 组件插入值。这在 MEL 中可能是可能的,但我不这么认为。这是一个将 transactionId 字段插入 JSON 数组的第一个元素的简单流程。应该让您知道如何做到这一点。

    <flow name="xmltojsontransformerFlow1" doc:name="xmltojsontransformerFlow1">
        <quartz:inbound-endpoint jobName="job"
                                 repeatInterval="0" repeatCount="0" startDelay="300" responseTimeout="10000"
                                 doc:name="Quartz">
            <quartz:event-generator-job />
        </quartz:inbound-endpoint>
        <parse-template
                location="/Users/tjs/MuleStudio/workspace3/xmltojsontransformer/src/main/resources/cd_catalog.xml"
                doc:name="Parse Template" />
        <custom-transformer class="cc.notsoclever.mule.XmlToJsonTransformer"
                            doc:name="XmlToJson" />
        <scripting:component doc:name="JavaScript">
            <scripting:script engine="JavaScript"><![CDATA[
    json = JSON.parse(payload);
    json[0].transactionId = "ABC123";
    payload = JSON.stringify(json);]]></scripting:script>
        </scripting:component>
        <logger message="#[payload]" level="INFO" doc:name="Logger" />
    </flow>
    

    上面使用了我写的transformer例子

    Mule: Is there simple way of converting XML to JSON

    【讨论】:

    • 我也使用了一个自定义转换器。谢谢
    • 在我将其标记为答案之前,我需要尝试您的方法
    猜你喜欢
    • 2020-04-15
    • 1970-01-01
    • 2022-01-10
    • 2021-01-05
    • 1970-01-01
    • 2020-11-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多