0

Mule を使用して JSON オブジェクトを XML オブジェクトに変換しようとしていますDataweave。以下は、入力 JSON です。

{
    "root": {
        "OBJECT1": {
            "PARAM1": "PARAM1VALUE",
            "PARAM2": "PARAM2VALUE"
        },
        "OBJECT2": [{
            "KEY": "PARAMROWKEYVALUE1",
            "VALUE": "PARAMROWVALUEVAL1"
        }, {
            "KEY": "PARAMROWKEYVALUE2",
            "VALUE": "PARAMROWVALUEVAL2"
        }],
        "OBJECT3": {
            "PARAM3": "PARAM3VALUE",
            "PARAM4": "PARAM4VALUE"
        }
    }
}

上記を以下の XML に変換したい:

<root>
    <node1>PARAM1VALUE PARAM2VALUE</node1>
    <args>
        <paramrow>
            <KEY>PARAMROWKEYVALUE1</KEY>
            <VALUE>PARAMROWVALUEVAL1</VALUE>
        </paramrow>
        <paramrow>
            <KEY>PARAMROWKEYVALUE2</KEY>
            <VALUE>PARAMROWVALUEVAL2</VALUE>
        </paramrow>
    </args>
    <details>
        <PARAM3>PARAM3VALUE</PARAM3>
    </details>
</root>

しかし、この JSON をサンプル入力として使用すると、「マッピングの検証」というエラーがスローされます。

%dw 1.0
%output application/xml
---
payload

これらのオブジェクト要素を XML にマップするにはどうすればよいですか?

4

3 に答える 3

1

次のDataWeaveを試してください

%dw 1.0
%output application/xml
---
{
    root: {
        node1: payload.root.OBJECT1.PARAM1 ++ ' ' ++ payload.root.OBJECT1.PARAM2,
        args: {
            (payload.root.OBJECT2 map {
                paramrow: {
                    KEY: $.KEY,
                    VALUE: $.VALUE
                }
            })
        },
        details: {
            (payload.root.OBJECT3 mapObject {
                '$$': $
            })
        }
    }
}
于 2016-02-29T21:00:12.777 に答える