Приложение Apache Axis2 / json не возвращает объект формата json для лунки - PullRequest
0 голосов
/ 07 июня 2018

У меня есть служба API, развернутая на консоли корпоративного интегратора wso2, которая отправляет запрос в БД для выбора.Он возвращает данные иерархической структуры в формате xml:

    <cdcList xmlns="http://ws.apache.org/ns/synapse">
<cdc>
<idCdc xmlns="">2</idCdc>
<idCdcParent xmlns=""/>
<cdcName xmlns="">Roma</cdcName>
<order xmlns="">1</order>
<isUsed xmlns="">false</isUsed>
<cdcList>
<cdc>
<idCdc xmlns="">5</idCdc>
<idCdcParent xmlns="">2</idCdcParent>
<cdcName xmlns="">Progetti</cdcName>
<order xmlns="">2</order>
<isUsed xmlns="">false</isUsed>
<cdcList>
<cdc>
<idCdc xmlns="">17</idCdc>
<idCdcParent xmlns="">5</idCdcParent>
<cdcName xmlns="">testGP</cdcName>
<order xmlns="">1</order>
<isUsed xmlns="">false</isUsed>
<cdcList/>
</cdc>
<cdc>
<idCdc xmlns="">18</idCdc>
<idCdcParent xmlns="">5</idCdcParent>
<cdcName xmlns="">testGPS</cdcName>
<order xmlns="">2</order>
<isUsed xmlns="">false</isUsed>
<cdcList/>
</cdc>
</cdcList>
</cdc>
</cdcList>
</cdc>
<cdc>
<idCdc xmlns="">3</idCdc>
<idCdcParent xmlns=""/>
<cdcName xmlns="">Milano</cdcName>
<order xmlns="">4</order>
<isUsed xmlns="">false</isUsed>
<cdcList>
<cdc>
<idCdc xmlns="">7</idCdc>
<idCdcParent xmlns="">3</idCdcParent>
<cdcName xmlns="">l</cdcName>
<order xmlns="">4</order>
<isUsed xmlns="">false</isUsed>
<cdcList/>
</cdc>
</cdcList>
</cdc>
<cdc>
<idCdc xmlns="">4</idCdc>
<idCdcParent xmlns=""/>
<cdcName xmlns="">Napoli</cdcName>
<order xmlns="">5</order>
<isUsed xmlns="">false</isUsed>
<cdcList>
<cdc>
<idCdc xmlns="">9</idCdc>
<idCdcParent xmlns="">4</idCdcParent>
<cdcName xmlns="">cccc</cdcName>
<order xmlns="">6</order>
<isUsed xmlns="">false</isUsed>
<cdcList/>
</cdc>
</cdcList>
</cdc>
</cdcList>

Служба использует приложение / json механизма Apache Axis2, которое преобразует выходные данные из xml в json.Проблема в том, что если родительский объект имеет более одного дочернего объекта, он работает хорошо, но если есть только один дочерний объект или его нет, он не возвращает вывод в формате json.Я попытался проверить класс java движка Apache Axis2, чтобы найти, где он управляет скобками в массиве json, но я не нашел решения.Это вывод службы API:

{"cdcList":{"cdc":[{"idCdc":2,"idCdcParent":null,"cdcName":"Roma","order":1,"isUsed":false,"cdcList":{"cdc":{"idCdc":5,"idCdcParent":2,"cdcName":"Progetti","order":2,"isUsed":false,"cdcList":{"cdc":[{"idCdc":17,"idCdcParent":5,"cdcName":"testGP","order":1,"isUsed":false,"cdcList":null},{"idCdc":18,"idCdcParent":5,"cdcName":"testGPS","order":2,"isUsed":false,"cdcList":null}]}}}},{"idCdc":3,"idCdcParent":null,"cdcName":"Milano","order":4,"isUsed":false,"cdcList":{"cdc":{"idCdc":7,"idCdcParent":3,"cdcName":"l","order":4,"isUsed":false,"cdcList":null}}},{"idCdc":4,"idCdcParent":null,"cdcName":"Napoli","order":5,"isUsed":false,"cdcList":{"cdc":{"idCdc":9,"idCdcParent":4,"cdcName":"cccc","order":6,"isUsed":false,"cdcList":null}}}]}}

, и вот как я хотел бы, чтобы это было:

{
"cdcList": [{
        "idCdc": 2,
        "idCdcParent": null,
        "cdcName": "Roma",
        "order": 1,
        "isUsed": false,
        "cdcList": [{
            "idCdc": 5,
            "idCdcParent": 2,
            "cdcName": "Progetti",
            "order": 2,
            "isUsed": false,
            "cdcList": [{
                    "idCdc": 17,
                    "idCdcParent": 5,
                    "cdcName": "testGP",
                    "order": 1,
                    "isUsed": false,
                    "cdcList": null
                },
                {
                    "idCdc": 18,
                    "idCdcParent": 5,
                    "cdcName": "testGPS",
                    "order": 2,
                    "isUsed": false,
                    "cdcList": null
                }
            ]



        }]
    },
    {
        "idCdc": 3,
        "idCdcParent": null,
        "cdcName": "Milano",
        "order": 4,
        "isUsed": false,
        "cdcList": [{

            "idCdc": 7,
            "idCdcParent": 3,
            "cdcName": "l",
            "order": 4,
            "isUsed": false,
            "cdcList": null
        }]
    },
    {
        "idCdc": 4,
        "idCdcParent": null,
        "cdcName": "Napoli",
        "order": 5,
        "isUsed": false,
        "cdcList": [{

            "idCdc": 9,
            "idCdcParent": 4,
            "cdcName": "cccc",
            "order": 6,
            "isUsed": false,
            "cdcList": null
        }]
    }
]

}

Обратите внимание на скобки иотсутствие элементов "cdc".Спасибо.

1 Ответ

0 голосов
/ 07 июня 2018

Как вы, вероятно, знаете, проблема в том, что конвертер XML в JSON не может определить, является ли один элемент XML преднамеренным и должен ли он быть преобразован в объект JSON, или это список из одного, и должен ли объект оборачиваться в список.

Самый простой способ сделать это - использовать XSLT-преобразование для добавления инструкций обработки xml-несколько перед каждым элементом cdcList.

Вы хотите, чтобы XML выглядел так, прежде чем преобразовывать его в JSON.

<?xml-multiple cdcList?>
<cdcList xmlns="http://ws.apache.org/ns/synapse">
    <cdc>
        <idCdc xmlns="">2</idCdc>
        <idCdcParent xmlns=""/>
        <cdcName xmlns="">Roma</cdcName>
        <order xmlns="">1</order>
        <isUsed xmlns="">false</isUsed>
        <?xml-multiple cdcList?>
        <cdcList>
            <cdc>
                <idCdc xmlns="">5</idCdc>
                <idCdcParent xmlns="">2</idCdcParent>
                <cdcName xmlns="">Progetti</cdcName>
                <order xmlns="">2</order>
                <isUsed xmlns="">false</isUsed>
                <?xml-multiple cdcList?>
                <cdcList>
                    <cdc>
                        <idCdc xmlns="">17</idCdc>
                        <idCdcParent xmlns="">5</idCdcParent>
                        ... etc
...