WSO2 конвертировать XML в JSON с массивом - PullRequest
0 голосов
/ 30 октября 2019

Я пытаюсь конвертировать xml в json, используя xslt. Когда у меня есть один узел, вывод JSON не содержит массив, но когда он имеет несколько узлов, он будет отображаться как массив

Если у меня одна запись отчета, то вывод JSON будет следующим (отсутствует массив):

XML:

<Report_Data>
    <Report_Entry>
        <ID>0025440</ID>
    </Report_Entry>
</Report_Data>

Результаты:

{
    "Report_Data": {
        "Report_Entry": 
            {  "ID": "0025440" }
    }
}

Когда у меня есть несколько записей в XML, вывод будет следующим (массив существует):

XML:

<Report_Data>
    <Report_Entry>
        <ID>0025440</ID>
    </Report_Entry>
    <Report_Entry>
        <ID>00254401</ID>
    </Report_Entry>
</Report_Data>

Результаты:

{
    "Report_Data": {
        "Report_Entry": [
            { "ID": "0025440" },
            { "ID": "0025441" }
        ]
    }
}

Это образец входного файла XML, пытающегося добавить массивы в WSo2. Не удается добавить массивы в вывод JSON.

a345ea1b59d c867b9511fa201

CCH2 c867b9511fa201 c867b9511fa201 5005854

                    <xyz:AStatus xyz:Descriptor="Pending">
                        <xyz:ID xyz:type="ID">5e3ae98c7e4b4af9836cd</xyz:ID>
                        <xyz:ID xyz:type="DID">PENDING</xyz:ID>
                    </xyz:AStatus>

                    <xyz:Net>0</xyz:Net>
                    <xyz:AMoment>2019-10-10</xyz:AMoment>
                </xyz:Report_Entry>
            </xyz:Report_Data>
        </env:Body>
    </env:Envelope>
</xyz:Body> </xyz:Envelope>
*1027* *1028*

Правильно отформатирован в этом формателюбые проблемы, поскольку у него несколько записей отчета:

a345ea1b59d c867b9511fa201

CCH2 c867b9511fa201 c867b9511fa201 5005854

                    <xyz:AStatus xyz:Descriptor="Pending">
                        <xyz:ID xyz:type="ID">5e3ae98c7e4b4af9836cd</xyz:ID>
                        <xyz:ID xyz:type="DID">PENDING</xyz:ID>
                    </xyz:AStatus>

                    <xyz:Net>0</xyz:Net>
                    <xyz:AMoment>2019-10-10</xyz:AMoment>
                </xyz:Report_Entry>
               <xyz:Report_Entry>
                    <xyz:BusinessAsset xyz:Descriptor="12">
                        <xyz:ID xyz:type="ID">a345ea1b59d</xyz:ID>
                    </xyz:BusinessAsset>
                    <xyz:CH xyz:Descriptor="UCCH2">
                        <xyz:ID xyz:type="ID">c867b9511fa201</xyz:ID>
                        <xyz:ID xyz:type="OID"
                            >CCH2</xyz:ID>
                        <xyz:ID xyz:type="CID"
                            >CCH2</xyz:ID>
                    </xyz:CH>
                    <xyz:CH xyz:Descriptor="UCCH3">
                        <xyz:ID xyz:type="ID">c867b9511fa201</xyz:ID>
                        <xyz:ID xyz:type="OID"
                            >CCH3</xyz:ID>
                        <xyz:ID xyz:type="CID"
                            >CCH3</xyz:ID>
                    </xyz:CH>
                  <xyz:CH xyz:Descriptor="UCCH4">
                        <xyz:ID xyz:type="ID">c867b9511fa201</xyz:ID>
                        <xyz:ID xyz:type="OID"
                            >CCH4</xyz:ID>
                        <xyz:ID xyz:type="CID"
                            >CCH4</xyz:ID>
                    </xyz:CH>
                    <xyz:AID>5005854</xyz:AID>

                    <xyz:AStatus xyz:Descriptor="Pending">
                        <xyz:ID xyz:type="ID">5e3ae98c7e4b4af9836cd</xyz:ID>
                        <xyz:ID xyz:type="DID">PENDING</xyz:ID>
                    </xyz:AStatus>

                    <xyz:Net>0</xyz:Net>
                    <xyz:AMoment>2019-10-10</xyz:AMoment>
                </xyz:Report_Entry>
            </xyz:Report_Data>
        </env:Body>
    </env:Envelope>
</xyz:Body> </xyz:Envelope>

Ответы [ 2 ]

0 голосов
/ 30 октября 2019

Вы можете попробовать это:

    <?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    exclude-result-prefixes="xs"
    version="2.0">
    <xsl:output method="text" omit-xml-declaration="yes" indent="yes"/>
    <xsl:template match="Report_Data">
        <xsl:text>{</xsl:text>
        <xsl:text>&#x0A;</xsl:text>
        <xsl:text>&#x2003;"</xsl:text><xsl:value-of select="local-name()"/><xsl:text>":</xsl:text>
        <xsl:for-each select="Report_Entry">
            <xsl:text>{</xsl:text><xsl:text>&#x0A;</xsl:text>
            <xsl:text>&#x2003;&#x2003;"</xsl:text><xsl:value-of select="local-name()"/><xsl:text>":</xsl:text>
            <xsl:for-each select="ID">
                <xsl:if test="following-sibling::* and position()=1">[&#x0A;</xsl:if>
                <xsl:if test="not(following-sibling::*) and position()=1"><xsl:text>&#x0A;</xsl:text></xsl:if>
                <xsl:text>&#x2003;&#x2003;&#x2003;{</xsl:text><xsl:text>"</xsl:text><xsl:value-of select="local-name()"/><xsl:text>": </xsl:text><xsl:value-of select="concat('&quot;',.,'&quot;')"/><xsl:text>}</xsl:text><xsl:text>&#x0A;</xsl:text>
                <xsl:if test="preceding-sibling::* and position()=last()">&#x2003;&#x2003;]&#x0A;</xsl:if>
            </xsl:for-each>
            <xsl:text>&#x2003;}</xsl:text><xsl:text>&#x0A;</xsl:text>
        </xsl:for-each>
        <xsl:text>}</xsl:text>
    </xsl:template>
</xsl:stylesheet>
0 голосов
/ 30 октября 2019

Если вы хотите представить «Report_Entry» в виде массива JSON, независимо от того, имеет ли он один или несколько элементов, это необходимо сделать внутри XSLT-файла и включить нижеприведенную инструкцию обработки XML.

<xsl:processing-instruction name="xml-multiple">Report_Entry</xsl:processing-instruction>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...