PHP convert XML to JSON





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







125















I am trying to convert xml to json in php. If I do a simple convert using simple xml and json_encode none of the attributes in the xml show.



$xml = simplexml_load_file("states.xml");
echo json_encode($xml);


So I am trying to manually parse it like this.



foreach($xml->children() as $state)
{
$states= array('state' => $state->name);
}
echo json_encode($states);


and the output for state is {"state":{"0":"Alabama"}} rather than {"state":"Alabama"}



What am I doing wrong?



XML:



<?xml version="1.0" ?>
<states>
<state id="AL">
<name>Alabama</name>
</state>
<state id="AK">
<name>Alaska</name>
</state>
</states>


Output:



[{"state":{"0":"Alabama"}},{"state":{"0":"Alaska"}


var dump:



object(SimpleXMLElement)#1 (1) {
["state"]=>
array(2) {
[0]=>
object(SimpleXMLElement)#3 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AL"
}
["name"]=>
string(7) "Alabama"
}
[1]=>
object(SimpleXMLElement)#2 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AK"
}
["name"]=>
string(6) "Alaska"
}
}
}









share|improve this question

























  • please post input and output. please var_dump $xml as well.

    – David Chan
    Jan 12 '12 at 5:39











  • Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

    – nikc.org
    Jan 12 '12 at 5:39











  • added input, output and var_dump

    – Bryan Hadlock
    Jan 12 '12 at 6:15











  • Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

    – Peter Krauss
    Oct 6 '16 at 14:19




















125















I am trying to convert xml to json in php. If I do a simple convert using simple xml and json_encode none of the attributes in the xml show.



$xml = simplexml_load_file("states.xml");
echo json_encode($xml);


So I am trying to manually parse it like this.



foreach($xml->children() as $state)
{
$states= array('state' => $state->name);
}
echo json_encode($states);


and the output for state is {"state":{"0":"Alabama"}} rather than {"state":"Alabama"}



What am I doing wrong?



XML:



<?xml version="1.0" ?>
<states>
<state id="AL">
<name>Alabama</name>
</state>
<state id="AK">
<name>Alaska</name>
</state>
</states>


Output:



[{"state":{"0":"Alabama"}},{"state":{"0":"Alaska"}


var dump:



object(SimpleXMLElement)#1 (1) {
["state"]=>
array(2) {
[0]=>
object(SimpleXMLElement)#3 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AL"
}
["name"]=>
string(7) "Alabama"
}
[1]=>
object(SimpleXMLElement)#2 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AK"
}
["name"]=>
string(6) "Alaska"
}
}
}









share|improve this question

























  • please post input and output. please var_dump $xml as well.

    – David Chan
    Jan 12 '12 at 5:39











  • Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

    – nikc.org
    Jan 12 '12 at 5:39











  • added input, output and var_dump

    – Bryan Hadlock
    Jan 12 '12 at 6:15











  • Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

    – Peter Krauss
    Oct 6 '16 at 14:19
















125












125








125


66






I am trying to convert xml to json in php. If I do a simple convert using simple xml and json_encode none of the attributes in the xml show.



$xml = simplexml_load_file("states.xml");
echo json_encode($xml);


So I am trying to manually parse it like this.



foreach($xml->children() as $state)
{
$states= array('state' => $state->name);
}
echo json_encode($states);


and the output for state is {"state":{"0":"Alabama"}} rather than {"state":"Alabama"}



What am I doing wrong?



XML:



<?xml version="1.0" ?>
<states>
<state id="AL">
<name>Alabama</name>
</state>
<state id="AK">
<name>Alaska</name>
</state>
</states>


Output:



[{"state":{"0":"Alabama"}},{"state":{"0":"Alaska"}


var dump:



object(SimpleXMLElement)#1 (1) {
["state"]=>
array(2) {
[0]=>
object(SimpleXMLElement)#3 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AL"
}
["name"]=>
string(7) "Alabama"
}
[1]=>
object(SimpleXMLElement)#2 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AK"
}
["name"]=>
string(6) "Alaska"
}
}
}









share|improve this question
















I am trying to convert xml to json in php. If I do a simple convert using simple xml and json_encode none of the attributes in the xml show.



$xml = simplexml_load_file("states.xml");
echo json_encode($xml);


So I am trying to manually parse it like this.



foreach($xml->children() as $state)
{
$states= array('state' => $state->name);
}
echo json_encode($states);


and the output for state is {"state":{"0":"Alabama"}} rather than {"state":"Alabama"}



What am I doing wrong?



XML:



<?xml version="1.0" ?>
<states>
<state id="AL">
<name>Alabama</name>
</state>
<state id="AK">
<name>Alaska</name>
</state>
</states>


Output:



[{"state":{"0":"Alabama"}},{"state":{"0":"Alaska"}


var dump:



object(SimpleXMLElement)#1 (1) {
["state"]=>
array(2) {
[0]=>
object(SimpleXMLElement)#3 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AL"
}
["name"]=>
string(7) "Alabama"
}
[1]=>
object(SimpleXMLElement)#2 (2) {
["@attributes"]=>
array(1) {
["id"]=>
string(2) "AK"
}
["name"]=>
string(6) "Alaska"
}
}
}






php xml json






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 12 '12 at 6:04







Bryan Hadlock

















asked Jan 12 '12 at 5:36









Bryan HadlockBryan Hadlock

1,23621014




1,23621014













  • please post input and output. please var_dump $xml as well.

    – David Chan
    Jan 12 '12 at 5:39











  • Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

    – nikc.org
    Jan 12 '12 at 5:39











  • added input, output and var_dump

    – Bryan Hadlock
    Jan 12 '12 at 6:15











  • Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

    – Peter Krauss
    Oct 6 '16 at 14:19





















  • please post input and output. please var_dump $xml as well.

    – David Chan
    Jan 12 '12 at 5:39











  • Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

    – nikc.org
    Jan 12 '12 at 5:39











  • added input, output and var_dump

    – Bryan Hadlock
    Jan 12 '12 at 6:15











  • Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

    – Peter Krauss
    Oct 6 '16 at 14:19



















please post input and output. please var_dump $xml as well.

– David Chan
Jan 12 '12 at 5:39





please post input and output. please var_dump $xml as well.

– David Chan
Jan 12 '12 at 5:39













Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

– nikc.org
Jan 12 '12 at 5:39





Please include a snippet of the XML and the final array structure you have after parsing it. (A var_dump works fine.)

– nikc.org
Jan 12 '12 at 5:39













added input, output and var_dump

– Bryan Hadlock
Jan 12 '12 at 6:15





added input, output and var_dump

– Bryan Hadlock
Jan 12 '12 at 6:15













Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

– Peter Krauss
Oct 6 '16 at 14:19







Some applications need "perfec XML-to-JSON map", that is jsonML, see solution here.

– Peter Krauss
Oct 6 '16 at 14:19














17 Answers
17






active

oldest

votes


















392














Json & Array from XML in 3 lines:



$xml = simplexml_load_string($xml_string);
$json = json_encode($xml);
$array = json_decode($json,TRUE);





share|improve this answer





















  • 12





    Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

    – Antonio Max
    Oct 15 '13 at 22:21






  • 2





    This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

    – Gauthier
    Nov 7 '13 at 4:23






  • 45





    This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

    – Jake Wilson
    Jan 26 '15 at 19:57






  • 11





    $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

    – txyoji
    Jul 14 '15 at 17:29






  • 18





    @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

    – AlexanderMP
    Feb 7 '17 at 16:12



















33














Sorry for answering an old post, but this article outlines an approach that is relatively short, concise and easy to maintain. I tested it myself and works pretty well.



http://lostechies.com/seanbiefeld/2011/10/21/simple-xml-to-json-with-php/



<?php   
class XmlToJson {
public function Parse ($url) {
$fileContents= file_get_contents($url);
$fileContents = str_replace(array("n", "r", "t"), '', $fileContents);
$fileContents = trim(str_replace('"', "'", $fileContents));
$simpleXml = simplexml_load_string($fileContents);
$json = json_encode($simpleXml);

return $json;
}
}
?>





share|improve this answer



















  • 7





    You shoud be prude for answering old question not sorry!

    – PHPst
    May 23 '13 at 6:47








  • 3





    This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

    – ethree
    Nov 7 '13 at 20:50






  • 3





    Also doesn't appear to work for CDATA contents.

    – jsleuth
    May 7 '14 at 22:59



















29














I figured it out. json_encode handles objects differently than strings. I cast the object to a string and it works now.



foreach($xml->children() as $state)
{
$states= array('state' => (string)$state->name);
}
echo json_encode($states);





share|improve this answer































    15














    I guess I'm a bit late to the party but I have written a small function to accomplish this task. It also takes care of attributes, text content and even if multiple nodes with the same node-name are siblings.



    Dislaimer:
    I'm not a PHP native, so please bear with simple mistakes.



    function xml2js($xmlnode) {
    $root = (func_num_args() > 1 ? false : true);
    $jsnode = array();

    if (!$root) {
    if (count($xmlnode->attributes()) > 0){
    $jsnode["$"] = array();
    foreach($xmlnode->attributes() as $key => $value)
    $jsnode["$"][$key] = (string)$value;
    }

    $textcontent = trim((string)$xmlnode);
    if (count($textcontent) > 0)
    $jsnode["_"] = $textcontent;

    foreach ($xmlnode->children() as $childxmlnode) {
    $childname = $childxmlnode->getName();
    if (!array_key_exists($childname, $jsnode))
    $jsnode[$childname] = array();
    array_push($jsnode[$childname], xml2js($childxmlnode, true));
    }
    return $jsnode;
    } else {
    $nodename = $xmlnode->getName();
    $jsnode[$nodename] = array();
    array_push($jsnode[$nodename], xml2js($xmlnode, true));
    return json_encode($jsnode);
    }
    }


    Usage example:



    $xml = simplexml_load_file("myfile.xml");
    echo xml2js($xml);


    Example Input (myfile.xml):



    <family name="Johnson">
    <child name="John" age="5">
    <toy status="old">Trooper</toy>
    <toy status="old">Ultrablock</toy>
    <toy status="new">Bike</toy>
    </child>
    </family>


    Example output:



    {"family":[{"$":{"name":"Johnson"},"child":[{"$":{"name":"John","age":"5"},"toy":[{"$":{"status":"old"},"_":"Trooper"},{"$":{"status":"old"},"_":"Ultrablock"},{"$":{"status":"new"},"_":"Bike"}]}]}]}


    Pretty printed:



    {
    "family" : [{
    "$" : {
    "name" : "Johnson"
    },
    "child" : [{
    "$" : {
    "name" : "John",
    "age" : "5"
    },
    "toy" : [{
    "$" : {
    "status" : "old"
    },
    "_" : "Trooper"
    }, {
    "$" : {
    "status" : "old"
    },
    "_" : "Ultrablock"
    }, {
    "$" : {
    "status" : "new"
    },
    "_" : "Bike"
    }
    ]
    }
    ]
    }
    ]
    }


    Quirks to keep in mind:
    Several tags with the same tagname can be siblings. Other solutions will most likely drop all but the last sibling. To avoid this each and every single node, even if it only has one child, is an array which hold an object for each instance of the tagname. (See multiple "" elements in example)



    Even the root element, of which only one should exist in a valid XML document is stored as array with an object of the instance, just to have a consistent data structure.



    To be able to distinguish between XML node content and XML attributes each objects attributes are stored in the "$" and the content in the "_" child.



    Edit:
    I forgot to show the output for your example input data



    {
    "states" : [{
    "state" : [{
    "$" : {
    "id" : "AL"
    },
    "name" : [{
    "_" : "Alabama"
    }
    ]
    }, {
    "$" : {
    "id" : "AK"
    },
    "name" : [{
    "_" : "Alaska"
    }
    ]
    }
    ]
    }
    ]
    }





    share|improve this answer
























    • Can it parse large XML data?

      – Volatil3
      Mar 1 '16 at 18:09











    • This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

      – Peter Krauss
      Oct 6 '16 at 4:27













    • Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

      – Peter Krauss
      Oct 6 '16 at 4:57



















    8














    A common pitfall is to forget that json_encode() does not respect elements with a textvalue and attribute(s). It will choose one of those, meaning dataloss.
    The function below solves that problem. If one decides to go for the json_encode/decode way, the following function is advised.



    function json_prepare_xml($domNode) {
    foreach($domNode->childNodes as $node) {
    if($node->hasChildNodes()) {
    json_prepare_xml($node);
    } else {
    if($domNode->hasAttributes() && strlen($domNode->nodeValue)){
    $domNode->setAttribute("nodeValue", $node->textContent);
    $node->nodeValue = "";
    }
    }
    }
    }

    $dom = new DOMDocument();
    $dom->loadXML( file_get_contents($xmlfile) );
    json_prepare_xml($dom);
    $sxml = simplexml_load_string( $dom->saveXML() );
    $json = json_decode( json_encode( $sxml ) );


    by doing so, <foo bar="3">Lorem</foo> will not end up as {"foo":"Lorem"} in your JSON.






    share|improve this answer


























    • Does not compile and does not produce the described output if syntax-errors are corrected.

      – Richard Kiefer
      Jan 21 '15 at 10:36











    • What is $dom? Where did that come from?

      – Jake Wilson
      Jan 26 '15 at 20:20











    • $dom = new DOMDocument(); is where it comes from

      – Scott
      Nov 25 '15 at 21:28






    • 1





      Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

      – Charlie Smith
      Feb 29 '16 at 2:46













    • Definite +1 for this - very important point!

      – Tom Folk
      Apr 18 '16 at 10:09



















    6














    Try to use this



    $xml = ... // Xml file data

    // first approach
    $Json = json_encode(simplexml_load_string($xml));

    ---------------- OR -----------------------

    // second approach
    $Json = json_encode(simplexml_load_string($xml, "SimpleXMLElement", LIBXML_NOCDATA));

    echo $Json;


    Or



    You can use this library : https://github.com/rentpost/xml2array






    share|improve this answer

































      3














      I've used Miles Johnson's TypeConverter for this purpose. It's installable using Composer.



      You could write something like this using it:



      <?php
      require 'vendor/autoload.php';
      use mjohnsonutilityTypeConverter;

      $xml = file_get_contents("file.xml");
      $arr = TypeConverter::xmlToArray($xml, TypeConverter::XML_GROUP);
      echo json_encode($arr);





      share|improve this answer































        3














        Optimizing Antonio Max answer:



        $xmlfile = 'yourfile.xml';
        $xmlparser = xml_parser_create();

        // open a file and read data
        $fp = fopen($xmlfile, 'r');
        //9999999 is the length which fread stops to read.
        $xmldata = fread($fp, 9999999);

        // converting to XML
        $xml = simplexml_load_string($xmldata, "SimpleXMLElement", LIBXML_NOCDATA);

        // converting to JSON
        $json = json_encode($xml);
        $array = json_decode($json,TRUE);





        share|improve this answer



















        • 1





          I used this approach, but JSON is empty. XML is valid.

          – ryabenko-pro
          Jan 9 '18 at 19:07



















        2














        This is an improvement of the most upvoted solution by Antonio Max, which also works with XML that has namespaces (by replacing the colon with an underscore). It also has some extra options (and does parse <person my-attribute='name'>John</person> correctly).



        function parse_xml_into_array($xml_string, $options = array()) {
        /*
        DESCRIPTION:
        - parse an XML string into an array
        INPUT:
        - $xml_string
        - $options : associative array with any of these keys:
        - 'flatten_cdata' : set to true to flatten CDATA elements
        - 'use_objects' : set to true to parse into objects instead of associative arrays
        - 'convert_booleans' : set to true to cast string values 'true' and 'false' into booleans
        OUTPUT:
        - associative array
        */

        // Remove namespaces by replacing ":" with "_"
        if (preg_match_all("|</([\w\-]+):([\w\-]+)>|", $xml_string, $matches, PREG_SET_ORDER)) {
        foreach ($matches as $match) {
        $xml_string = str_replace('<'. $match[1] .':'. $match[2], '<'. $match[1] .'_'. $match[2], $xml_string);
        $xml_string = str_replace('</'. $match[1] .':'. $match[2], '</'. $match[1] .'_'. $match[2], $xml_string);
        }
        }

        $output = json_decode(json_encode(@simplexml_load_string($xml_string, 'SimpleXMLElement', ($options['flatten_cdata'] ? LIBXML_NOCDATA : 0))), ($options['use_objects'] ? false : true));

        // Cast string values "true" and "false" to booleans
        if ($options['convert_booleans']) {
        $bool = function(&$item, $key) {
        if (in_array($item, array('true', 'TRUE', 'True'), true)) {
        $item = true;
        } elseif (in_array($item, array('false', 'FALSE', 'False'), true)) {
        $item = false;
        }
        };
        array_walk_recursive($output, $bool);
        }

        return $output;
        }





        share|improve this answer


























        • One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

          – AlexanderMP
          Feb 7 '17 at 16:19











        • I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

          – TheStoryCoder
          Feb 13 '17 at 21:39











        • The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

          – AlexanderMP
          May 9 '17 at 17:41











        • The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

          – AlexanderMP
          May 9 '17 at 17:48





















        1














        If you would like to only convert a specific part of the XML to JSON, you can use XPath to retrieve this and convert that to JSON.



        <?php
        $file = @file_get_contents($xml_File, FILE_TEXT);
        $xml = new SimpleXMLElement($file);
        $xml_Excerpt = @$xml->xpath('/states/state[@id="AL"]')[0]; // [0] gets the node
        echo json_encode($xml_Excerpt);
        ?>


        Please note that if you Xpath is incorrect, this will die with an error. So if you're debugging this through AJAX calls I recommend you log the response bodies as well.






        share|improve this answer































          0














          Looks like the $state->name variable is holding an array. You can use



          var_dump($state)


          inside the foreach to test that.



          If that's the case, you can change the line inside the foreach to



          $states= array('state' => array_shift($state->name)); 


          to correct it.






          share|improve this answer
























          • looks like the attributes are arrays but not $state->name

            – Bryan Hadlock
            Jan 12 '12 at 6:11



















          0














          The question doesn't say it, but usually PHP is returning JSON to a web page.



          I find it much easier to convert the XML to JSON in the browser/page via a JS lib, for example:



          https://code.google.com/p/x2js/downloads/detail?name=x2js-v1.1.3.zip





          share|improve this answer































            0














            All solutions here have problems!



            ... When the representation need perfect XML interpretation (without problems with attributes) and to reproduce all text-tag-text-tag-text-... and order of tags. Also good remember here that JSON object "is an unordered set" (not repeat keys and the keys can't have predefined order)... Even ZF's xml2json is wrong (!) because not preserve exactly the XML structure.



            All solutions here have problems with this simple XML,



                <states x-x='1'>
            <state y="123">Alabama</state>
            My name is <b>John</b> Doe
            <state>Alaska</state>
            </states>


            ... @FTav solution seems better than 3-line solution, but also have little bug when tested with this XML.



            Old solution is the best (for loss-less representation)



            The solution, today well-known as jsonML, is used by Zorba project and others, and was first presented in ~2006 or ~2007, by (separately) Stephen McKamey and John Snelson.



            // the core algorithm is the XSLT of the "jsonML conventions"
            // see https://github.com/mckamey/jsonml
            $xslt = 'https://raw.githubusercontent.com/mckamey/jsonml/master/jsonml.xslt';
            $dom = new DOMDocument;
            $dom->loadXML('
            <states x-x='1'>
            <state y="123">Alabama</state>
            My name is <b>John</b> Doe
            <state>Alaska</state>
            </states>
            ');
            if (!$dom) die("nERROR!");
            $xslDoc = new DOMDocument();
            $xslDoc->load($xslt);
            $proc = new XSLTProcessor();
            $proc->importStylesheet($xslDoc);
            echo $proc->transformToXML($dom);


            Produce



            ["states",{"x-x":"1"},
            "nt ",
            ["state",{"y":"123"},"Alabama"],
            "nttMy name is ",
            ["b","John"],
            " Doent ",
            ["state","Alaska"],
            "nt"
            ]


            See http://jsonML.org or github.com/mckamey/jsonml. The production rules of this JSON are based on the element JSON-analog,



            enter image description here



            This syntax is a element definition and recurrence, with
            element-list ::= element ',' element-list | element.






            share|improve this answer


























            • Very unusual xml structure that I doubt would have real life use cases.

              – TheStoryCoder
              Feb 13 '17 at 21:49



















            0














            After researching a little bit all of the answers, I came up with a solution that worked just fine with my JavaScript functions across browsers (Including consoles / Dev Tools) :



            <?php

            // PHP Version 7.2.1 (Windows 10 x86)

            function json2xml( $domNode ) {
            foreach( $domNode -> childNodes as $node) {
            if ( $node -> hasChildNodes() ) { json2xml( $node ); }
            else {
            if ( $domNode -> hasAttributes() && strlen( $domNode -> nodeValue ) ) {
            $domNode -> setAttribute( "nodeValue", $node -> textContent );
            $node -> nodeValue = "";
            }
            }
            }
            }

            function jsonOut( $file ) {
            $dom = new DOMDocument();
            $dom -> loadXML( file_get_contents( $file ) );
            json2xml( $dom );
            header( 'Content-Type: application/json' );
            return str_replace( "@", "", json_encode( simplexml_load_string( $dom -> saveXML() ), JSON_PRETTY_PRINT ) );
            }

            $output = jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' );

            echo( $output );

            /*
            Or simply
            echo( jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' ) );
            */

            ?>


            It basically creates a new DOMDocument, loads and XML file into it and traverses through each one of the nodes and children getting the data / parameters and exporting it into JSON without the annoying "@" signs.



            Link to the XML file.






            share|improve this answer































              0














              This solution handles namespaces, attributes, and produces consistent result with repeating elements (always in array, even if there is only one occurrence).
              Inspired by ratfactor's sxiToArray().



              /**
              * <root><a>5</a><b>6</b><b>8</b></root> -> {"root":[{"a":["5"],"b":["6","8"]}]}
              * <root a="5"><b>6</b><b>8</b></root> -> {"root":[{"a":"5","b":["6","8"]}]}
              * <root xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy"><a>123</a><wsp:b>456</wsp:b></root>
              * -> {"root":[{"xmlns:wsp":"http://schemas.xmlsoap.org/ws/2004/09/policy","a":["123"],"wsp:b":["456"]}]}
              */
              function domNodesToArray(array $tags, DOMXPath $xpath)
              {
              $tagNameToArr = ;
              foreach ($tags as $tag) {
              $tagData = ;
              $attrs = $tag->attributes ? iterator_to_array($tag->attributes) : ;
              $subTags = $tag->childNodes ? iterator_to_array($tag->childNodes) : ;
              foreach ($xpath->query('namespace::*', $tag) as $nsNode) {
              // the only way to get xmlns:*, see https://stackoverflow.com/a/2470433/2750743
              if ($tag->hasAttribute($nsNode->nodeName)) {
              $attrs = $nsNode;
              }
              }

              foreach ($attrs as $attr) {
              $tagData[$attr->nodeName] = $attr->nodeValue;
              }
              if (count($subTags) === 1 && $subTags[0] instanceof DOMText) {
              $text = $subTags[0]->nodeValue;
              } elseif (count($subTags) === 0) {
              $text = '';
              } else {
              // ignore whitespace (and any other text if any) between nodes
              $isNotDomText = function($node){return !($node instanceof DOMText);};
              $realNodes = array_filter($subTags, $isNotDomText);
              $subTagNameToArr = domNodesToArray($realNodes, $xpath);
              $tagData = array_merge($tagData, $subTagNameToArr);
              $text = null;
              }
              if (!is_null($text)) {
              if ($attrs) {
              if ($text) {
              $tagData['_'] = $text;
              }
              } else {
              $tagData = $text;
              }
              }
              $keyName = $tag->nodeName;
              $tagNameToArr[$keyName] = $tagData;
              }
              return $tagNameToArr;
              }

              function xmlToArr(string $xml)
              {
              $doc = new DOMDocument();
              $doc->loadXML($xml);
              $xpath = new DOMXPath($doc);
              $tags = $doc->childNodes ? iterator_to_array($doc->childNodes) : ;
              return domNodesToArray($tags, $xpath);
              }


              Example:



              php > print(json_encode(xmlToArr('<root a="5"><b>6</b></root>')));
              {"root":[{"a":"5","b":["6"]}]}





              share|improve this answer































                -1














                $templateData =  $_POST['data'];

                // initializing or creating array
                $template_info = $templateData;

                // creating object of SimpleXMLElement
                $xml_template_info = new SimpleXMLElement("<?xml version="1.0"?><template></template>");

                // function call to convert array to xml
                array_to_xml($template_info,$xml_template_info);

                //saving generated xml file
                $xml_template_info->asXML(dirname(__FILE__)."/manifest.xml") ;

                // function defination to convert array to xml
                function array_to_xml($template_info, &$xml_template_info) {
                foreach($template_info as $key => $value) {
                if(is_array($value)) {
                if(!is_numeric($key)){
                $subnode = $xml_template_info->addChild($key);
                if(is_array($value)){
                $cont = 0;
                foreach(array_keys($value) as $k){
                if(is_numeric($k)) $cont++;
                }
                }

                if($cont>0){
                for($i=0; $i < $cont; $i++){
                $subnode = $xml_body_info->addChild($key);
                array_to_xml($value[$i], $subnode);
                }
                }else{
                $subnode = $xml_body_info->addChild($key);
                array_to_xml($value, $subnode);
                }
                }
                else{
                array_to_xml($value, $xml_template_info);
                }
                }
                else {
                $xml_template_info->addChild($key,$value);
                }
                }
                }





                share|improve this answer
























                • It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                  – Octavio Perez Gallegos
                  Jun 30 '16 at 22:45








                • 1





                  In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                  – Dan Roche
                  Jun 30 '16 at 22:54











                • Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                  – Octavio Perez Gallegos
                  Jul 26 '16 at 17:45



















                -1














                $xml = simplexml_load_string($xml_string);
                $json = json_encode($xml);
                $array = json_decode($json,TRUE);


                just add those three lines you will get the correct output:-)






                share|improve this answer
























                  Your Answer






                  StackExchange.ifUsing("editor", function () {
                  StackExchange.using("externalEditor", function () {
                  StackExchange.using("snippets", function () {
                  StackExchange.snippets.init();
                  });
                  });
                  }, "code-snippets");

                  StackExchange.ready(function() {
                  var channelOptions = {
                  tags: "".split(" "),
                  id: "1"
                  };
                  initTagRenderer("".split(" "), "".split(" "), channelOptions);

                  StackExchange.using("externalEditor", function() {
                  // Have to fire editor after snippets, if snippets enabled
                  if (StackExchange.settings.snippets.snippetsEnabled) {
                  StackExchange.using("snippets", function() {
                  createEditor();
                  });
                  }
                  else {
                  createEditor();
                  }
                  });

                  function createEditor() {
                  StackExchange.prepareEditor({
                  heartbeatType: 'answer',
                  autoActivateHeartbeat: false,
                  convertImagesToLinks: true,
                  noModals: true,
                  showLowRepImageUploadWarning: true,
                  reputationToPostImages: 10,
                  bindNavPrevention: true,
                  postfix: "",
                  imageUploader: {
                  brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                  contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                  allowUrls: true
                  },
                  onDemand: true,
                  discardSelector: ".discard-answer"
                  ,immediatelyShowMarkdownHelp:true
                  });


                  }
                  });














                  draft saved

                  draft discarded


















                  StackExchange.ready(
                  function () {
                  StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f8830599%2fphp-convert-xml-to-json%23new-answer', 'question_page');
                  }
                  );

                  Post as a guest















                  Required, but never shown

























                  17 Answers
                  17






                  active

                  oldest

                  votes








                  17 Answers
                  17






                  active

                  oldest

                  votes









                  active

                  oldest

                  votes






                  active

                  oldest

                  votes









                  392














                  Json & Array from XML in 3 lines:



                  $xml = simplexml_load_string($xml_string);
                  $json = json_encode($xml);
                  $array = json_decode($json,TRUE);





                  share|improve this answer





















                  • 12





                    Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                    – Antonio Max
                    Oct 15 '13 at 22:21






                  • 2





                    This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                    – Gauthier
                    Nov 7 '13 at 4:23






                  • 45





                    This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                    – Jake Wilson
                    Jan 26 '15 at 19:57






                  • 11





                    $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                    – txyoji
                    Jul 14 '15 at 17:29






                  • 18





                    @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                    – AlexanderMP
                    Feb 7 '17 at 16:12
















                  392














                  Json & Array from XML in 3 lines:



                  $xml = simplexml_load_string($xml_string);
                  $json = json_encode($xml);
                  $array = json_decode($json,TRUE);





                  share|improve this answer





















                  • 12





                    Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                    – Antonio Max
                    Oct 15 '13 at 22:21






                  • 2





                    This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                    – Gauthier
                    Nov 7 '13 at 4:23






                  • 45





                    This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                    – Jake Wilson
                    Jan 26 '15 at 19:57






                  • 11





                    $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                    – txyoji
                    Jul 14 '15 at 17:29






                  • 18





                    @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                    – AlexanderMP
                    Feb 7 '17 at 16:12














                  392












                  392








                  392







                  Json & Array from XML in 3 lines:



                  $xml = simplexml_load_string($xml_string);
                  $json = json_encode($xml);
                  $array = json_decode($json,TRUE);





                  share|improve this answer















                  Json & Array from XML in 3 lines:



                  $xml = simplexml_load_string($xml_string);
                  $json = json_encode($xml);
                  $array = json_decode($json,TRUE);






                  share|improve this answer














                  share|improve this answer



                  share|improve this answer








                  edited Nov 23 '18 at 2:13









                  Ali Khaki

                  8081520




                  8081520










                  answered Oct 15 '13 at 21:36









                  Antonio MaxAntonio Max

                  6,10653740




                  6,10653740








                  • 12





                    Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                    – Antonio Max
                    Oct 15 '13 at 22:21






                  • 2





                    This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                    – Gauthier
                    Nov 7 '13 at 4:23






                  • 45





                    This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                    – Jake Wilson
                    Jan 26 '15 at 19:57






                  • 11





                    $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                    – txyoji
                    Jul 14 '15 at 17:29






                  • 18





                    @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                    – AlexanderMP
                    Feb 7 '17 at 16:12














                  • 12





                    Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                    – Antonio Max
                    Oct 15 '13 at 22:21






                  • 2





                    This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                    – Gauthier
                    Nov 7 '13 at 4:23






                  • 45





                    This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                    – Jake Wilson
                    Jan 26 '15 at 19:57






                  • 11





                    $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                    – txyoji
                    Jul 14 '15 at 17:29






                  • 18





                    @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                    – AlexanderMP
                    Feb 7 '17 at 16:12








                  12




                  12





                  Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                  – Antonio Max
                  Oct 15 '13 at 22:21





                  Why the downvote? This is works flawlessly with fewer lines than any other example here. No libs, no nothing, just plain PHP!

                  – Antonio Max
                  Oct 15 '13 at 22:21




                  2




                  2





                  This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                  – Gauthier
                  Nov 7 '13 at 4:23





                  This is exactly what I was looking for, however I think the question wanted special parsing. Taking certain sub-elements and moving them up the tree ( a custom parser ), instead of a 1 to 1 conversion.

                  – Gauthier
                  Nov 7 '13 at 4:23




                  45




                  45





                  This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                  – Jake Wilson
                  Jan 26 '15 at 19:57





                  This solution is not flawless. It completely discards XML attributes. So <person my-attribute='name'>John</person> is interpreted as <person>John</person>.

                  – Jake Wilson
                  Jan 26 '15 at 19:57




                  11




                  11





                  $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                  – txyoji
                  Jul 14 '15 at 17:29





                  $xml = simplexml_load_string($xml_string,'SimpleXMLElement',LIBXML_NOCDATA); to flatten cdata elements.

                  – txyoji
                  Jul 14 '15 at 17:29




                  18




                  18





                  @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                  – AlexanderMP
                  Feb 7 '17 at 16:12





                  @JakeWilson maybe it's the 2 years that have passed, and various version fixes, but on PHP 5.6.30, this method produces ALL of the data. Attributes are stored in the array under the @attributes key, so it works absolutely flawlessly, and beautifully. 3 short lines of code solve my problem beautifully.

                  – AlexanderMP
                  Feb 7 '17 at 16:12













                  33














                  Sorry for answering an old post, but this article outlines an approach that is relatively short, concise and easy to maintain. I tested it myself and works pretty well.



                  http://lostechies.com/seanbiefeld/2011/10/21/simple-xml-to-json-with-php/



                  <?php   
                  class XmlToJson {
                  public function Parse ($url) {
                  $fileContents= file_get_contents($url);
                  $fileContents = str_replace(array("n", "r", "t"), '', $fileContents);
                  $fileContents = trim(str_replace('"', "'", $fileContents));
                  $simpleXml = simplexml_load_string($fileContents);
                  $json = json_encode($simpleXml);

                  return $json;
                  }
                  }
                  ?>





                  share|improve this answer



















                  • 7





                    You shoud be prude for answering old question not sorry!

                    – PHPst
                    May 23 '13 at 6:47








                  • 3





                    This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                    – ethree
                    Nov 7 '13 at 20:50






                  • 3





                    Also doesn't appear to work for CDATA contents.

                    – jsleuth
                    May 7 '14 at 22:59
















                  33














                  Sorry for answering an old post, but this article outlines an approach that is relatively short, concise and easy to maintain. I tested it myself and works pretty well.



                  http://lostechies.com/seanbiefeld/2011/10/21/simple-xml-to-json-with-php/



                  <?php   
                  class XmlToJson {
                  public function Parse ($url) {
                  $fileContents= file_get_contents($url);
                  $fileContents = str_replace(array("n", "r", "t"), '', $fileContents);
                  $fileContents = trim(str_replace('"', "'", $fileContents));
                  $simpleXml = simplexml_load_string($fileContents);
                  $json = json_encode($simpleXml);

                  return $json;
                  }
                  }
                  ?>





                  share|improve this answer



















                  • 7





                    You shoud be prude for answering old question not sorry!

                    – PHPst
                    May 23 '13 at 6:47








                  • 3





                    This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                    – ethree
                    Nov 7 '13 at 20:50






                  • 3





                    Also doesn't appear to work for CDATA contents.

                    – jsleuth
                    May 7 '14 at 22:59














                  33












                  33








                  33







                  Sorry for answering an old post, but this article outlines an approach that is relatively short, concise and easy to maintain. I tested it myself and works pretty well.



                  http://lostechies.com/seanbiefeld/2011/10/21/simple-xml-to-json-with-php/



                  <?php   
                  class XmlToJson {
                  public function Parse ($url) {
                  $fileContents= file_get_contents($url);
                  $fileContents = str_replace(array("n", "r", "t"), '', $fileContents);
                  $fileContents = trim(str_replace('"', "'", $fileContents));
                  $simpleXml = simplexml_load_string($fileContents);
                  $json = json_encode($simpleXml);

                  return $json;
                  }
                  }
                  ?>





                  share|improve this answer













                  Sorry for answering an old post, but this article outlines an approach that is relatively short, concise and easy to maintain. I tested it myself and works pretty well.



                  http://lostechies.com/seanbiefeld/2011/10/21/simple-xml-to-json-with-php/



                  <?php   
                  class XmlToJson {
                  public function Parse ($url) {
                  $fileContents= file_get_contents($url);
                  $fileContents = str_replace(array("n", "r", "t"), '', $fileContents);
                  $fileContents = trim(str_replace('"', "'", $fileContents));
                  $simpleXml = simplexml_load_string($fileContents);
                  $json = json_encode($simpleXml);

                  return $json;
                  }
                  }
                  ?>






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Mar 11 '13 at 9:47









                  CoreusCoreus

                  3,43422742




                  3,43422742








                  • 7





                    You shoud be prude for answering old question not sorry!

                    – PHPst
                    May 23 '13 at 6:47








                  • 3





                    This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                    – ethree
                    Nov 7 '13 at 20:50






                  • 3





                    Also doesn't appear to work for CDATA contents.

                    – jsleuth
                    May 7 '14 at 22:59














                  • 7





                    You shoud be prude for answering old question not sorry!

                    – PHPst
                    May 23 '13 at 6:47








                  • 3





                    This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                    – ethree
                    Nov 7 '13 at 20:50






                  • 3





                    Also doesn't appear to work for CDATA contents.

                    – jsleuth
                    May 7 '14 at 22:59








                  7




                  7





                  You shoud be prude for answering old question not sorry!

                  – PHPst
                  May 23 '13 at 6:47







                  You shoud be prude for answering old question not sorry!

                  – PHPst
                  May 23 '13 at 6:47






                  3




                  3





                  This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                  – ethree
                  Nov 7 '13 at 20:50





                  This will not work if you have multiple instances of the same tag in your XML, json_encode will end up only serializing the last instance of the tag.

                  – ethree
                  Nov 7 '13 at 20:50




                  3




                  3





                  Also doesn't appear to work for CDATA contents.

                  – jsleuth
                  May 7 '14 at 22:59





                  Also doesn't appear to work for CDATA contents.

                  – jsleuth
                  May 7 '14 at 22:59











                  29














                  I figured it out. json_encode handles objects differently than strings. I cast the object to a string and it works now.



                  foreach($xml->children() as $state)
                  {
                  $states= array('state' => (string)$state->name);
                  }
                  echo json_encode($states);





                  share|improve this answer




























                    29














                    I figured it out. json_encode handles objects differently than strings. I cast the object to a string and it works now.



                    foreach($xml->children() as $state)
                    {
                    $states= array('state' => (string)$state->name);
                    }
                    echo json_encode($states);





                    share|improve this answer


























                      29












                      29








                      29







                      I figured it out. json_encode handles objects differently than strings. I cast the object to a string and it works now.



                      foreach($xml->children() as $state)
                      {
                      $states= array('state' => (string)$state->name);
                      }
                      echo json_encode($states);





                      share|improve this answer













                      I figured it out. json_encode handles objects differently than strings. I cast the object to a string and it works now.



                      foreach($xml->children() as $state)
                      {
                      $states= array('state' => (string)$state->name);
                      }
                      echo json_encode($states);






                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered Jan 13 '12 at 3:56









                      Bryan HadlockBryan Hadlock

                      1,23621014




                      1,23621014























                          15














                          I guess I'm a bit late to the party but I have written a small function to accomplish this task. It also takes care of attributes, text content and even if multiple nodes with the same node-name are siblings.



                          Dislaimer:
                          I'm not a PHP native, so please bear with simple mistakes.



                          function xml2js($xmlnode) {
                          $root = (func_num_args() > 1 ? false : true);
                          $jsnode = array();

                          if (!$root) {
                          if (count($xmlnode->attributes()) > 0){
                          $jsnode["$"] = array();
                          foreach($xmlnode->attributes() as $key => $value)
                          $jsnode["$"][$key] = (string)$value;
                          }

                          $textcontent = trim((string)$xmlnode);
                          if (count($textcontent) > 0)
                          $jsnode["_"] = $textcontent;

                          foreach ($xmlnode->children() as $childxmlnode) {
                          $childname = $childxmlnode->getName();
                          if (!array_key_exists($childname, $jsnode))
                          $jsnode[$childname] = array();
                          array_push($jsnode[$childname], xml2js($childxmlnode, true));
                          }
                          return $jsnode;
                          } else {
                          $nodename = $xmlnode->getName();
                          $jsnode[$nodename] = array();
                          array_push($jsnode[$nodename], xml2js($xmlnode, true));
                          return json_encode($jsnode);
                          }
                          }


                          Usage example:



                          $xml = simplexml_load_file("myfile.xml");
                          echo xml2js($xml);


                          Example Input (myfile.xml):



                          <family name="Johnson">
                          <child name="John" age="5">
                          <toy status="old">Trooper</toy>
                          <toy status="old">Ultrablock</toy>
                          <toy status="new">Bike</toy>
                          </child>
                          </family>


                          Example output:



                          {"family":[{"$":{"name":"Johnson"},"child":[{"$":{"name":"John","age":"5"},"toy":[{"$":{"status":"old"},"_":"Trooper"},{"$":{"status":"old"},"_":"Ultrablock"},{"$":{"status":"new"},"_":"Bike"}]}]}]}


                          Pretty printed:



                          {
                          "family" : [{
                          "$" : {
                          "name" : "Johnson"
                          },
                          "child" : [{
                          "$" : {
                          "name" : "John",
                          "age" : "5"
                          },
                          "toy" : [{
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Trooper"
                          }, {
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Ultrablock"
                          }, {
                          "$" : {
                          "status" : "new"
                          },
                          "_" : "Bike"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }


                          Quirks to keep in mind:
                          Several tags with the same tagname can be siblings. Other solutions will most likely drop all but the last sibling. To avoid this each and every single node, even if it only has one child, is an array which hold an object for each instance of the tagname. (See multiple "" elements in example)



                          Even the root element, of which only one should exist in a valid XML document is stored as array with an object of the instance, just to have a consistent data structure.



                          To be able to distinguish between XML node content and XML attributes each objects attributes are stored in the "$" and the content in the "_" child.



                          Edit:
                          I forgot to show the output for your example input data



                          {
                          "states" : [{
                          "state" : [{
                          "$" : {
                          "id" : "AL"
                          },
                          "name" : [{
                          "_" : "Alabama"
                          }
                          ]
                          }, {
                          "$" : {
                          "id" : "AK"
                          },
                          "name" : [{
                          "_" : "Alaska"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }





                          share|improve this answer
























                          • Can it parse large XML data?

                            – Volatil3
                            Mar 1 '16 at 18:09











                          • This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                            – Peter Krauss
                            Oct 6 '16 at 4:27













                          • Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                            – Peter Krauss
                            Oct 6 '16 at 4:57
















                          15














                          I guess I'm a bit late to the party but I have written a small function to accomplish this task. It also takes care of attributes, text content and even if multiple nodes with the same node-name are siblings.



                          Dislaimer:
                          I'm not a PHP native, so please bear with simple mistakes.



                          function xml2js($xmlnode) {
                          $root = (func_num_args() > 1 ? false : true);
                          $jsnode = array();

                          if (!$root) {
                          if (count($xmlnode->attributes()) > 0){
                          $jsnode["$"] = array();
                          foreach($xmlnode->attributes() as $key => $value)
                          $jsnode["$"][$key] = (string)$value;
                          }

                          $textcontent = trim((string)$xmlnode);
                          if (count($textcontent) > 0)
                          $jsnode["_"] = $textcontent;

                          foreach ($xmlnode->children() as $childxmlnode) {
                          $childname = $childxmlnode->getName();
                          if (!array_key_exists($childname, $jsnode))
                          $jsnode[$childname] = array();
                          array_push($jsnode[$childname], xml2js($childxmlnode, true));
                          }
                          return $jsnode;
                          } else {
                          $nodename = $xmlnode->getName();
                          $jsnode[$nodename] = array();
                          array_push($jsnode[$nodename], xml2js($xmlnode, true));
                          return json_encode($jsnode);
                          }
                          }


                          Usage example:



                          $xml = simplexml_load_file("myfile.xml");
                          echo xml2js($xml);


                          Example Input (myfile.xml):



                          <family name="Johnson">
                          <child name="John" age="5">
                          <toy status="old">Trooper</toy>
                          <toy status="old">Ultrablock</toy>
                          <toy status="new">Bike</toy>
                          </child>
                          </family>


                          Example output:



                          {"family":[{"$":{"name":"Johnson"},"child":[{"$":{"name":"John","age":"5"},"toy":[{"$":{"status":"old"},"_":"Trooper"},{"$":{"status":"old"},"_":"Ultrablock"},{"$":{"status":"new"},"_":"Bike"}]}]}]}


                          Pretty printed:



                          {
                          "family" : [{
                          "$" : {
                          "name" : "Johnson"
                          },
                          "child" : [{
                          "$" : {
                          "name" : "John",
                          "age" : "5"
                          },
                          "toy" : [{
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Trooper"
                          }, {
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Ultrablock"
                          }, {
                          "$" : {
                          "status" : "new"
                          },
                          "_" : "Bike"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }


                          Quirks to keep in mind:
                          Several tags with the same tagname can be siblings. Other solutions will most likely drop all but the last sibling. To avoid this each and every single node, even if it only has one child, is an array which hold an object for each instance of the tagname. (See multiple "" elements in example)



                          Even the root element, of which only one should exist in a valid XML document is stored as array with an object of the instance, just to have a consistent data structure.



                          To be able to distinguish between XML node content and XML attributes each objects attributes are stored in the "$" and the content in the "_" child.



                          Edit:
                          I forgot to show the output for your example input data



                          {
                          "states" : [{
                          "state" : [{
                          "$" : {
                          "id" : "AL"
                          },
                          "name" : [{
                          "_" : "Alabama"
                          }
                          ]
                          }, {
                          "$" : {
                          "id" : "AK"
                          },
                          "name" : [{
                          "_" : "Alaska"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }





                          share|improve this answer
























                          • Can it parse large XML data?

                            – Volatil3
                            Mar 1 '16 at 18:09











                          • This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                            – Peter Krauss
                            Oct 6 '16 at 4:27













                          • Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                            – Peter Krauss
                            Oct 6 '16 at 4:57














                          15












                          15








                          15







                          I guess I'm a bit late to the party but I have written a small function to accomplish this task. It also takes care of attributes, text content and even if multiple nodes with the same node-name are siblings.



                          Dislaimer:
                          I'm not a PHP native, so please bear with simple mistakes.



                          function xml2js($xmlnode) {
                          $root = (func_num_args() > 1 ? false : true);
                          $jsnode = array();

                          if (!$root) {
                          if (count($xmlnode->attributes()) > 0){
                          $jsnode["$"] = array();
                          foreach($xmlnode->attributes() as $key => $value)
                          $jsnode["$"][$key] = (string)$value;
                          }

                          $textcontent = trim((string)$xmlnode);
                          if (count($textcontent) > 0)
                          $jsnode["_"] = $textcontent;

                          foreach ($xmlnode->children() as $childxmlnode) {
                          $childname = $childxmlnode->getName();
                          if (!array_key_exists($childname, $jsnode))
                          $jsnode[$childname] = array();
                          array_push($jsnode[$childname], xml2js($childxmlnode, true));
                          }
                          return $jsnode;
                          } else {
                          $nodename = $xmlnode->getName();
                          $jsnode[$nodename] = array();
                          array_push($jsnode[$nodename], xml2js($xmlnode, true));
                          return json_encode($jsnode);
                          }
                          }


                          Usage example:



                          $xml = simplexml_load_file("myfile.xml");
                          echo xml2js($xml);


                          Example Input (myfile.xml):



                          <family name="Johnson">
                          <child name="John" age="5">
                          <toy status="old">Trooper</toy>
                          <toy status="old">Ultrablock</toy>
                          <toy status="new">Bike</toy>
                          </child>
                          </family>


                          Example output:



                          {"family":[{"$":{"name":"Johnson"},"child":[{"$":{"name":"John","age":"5"},"toy":[{"$":{"status":"old"},"_":"Trooper"},{"$":{"status":"old"},"_":"Ultrablock"},{"$":{"status":"new"},"_":"Bike"}]}]}]}


                          Pretty printed:



                          {
                          "family" : [{
                          "$" : {
                          "name" : "Johnson"
                          },
                          "child" : [{
                          "$" : {
                          "name" : "John",
                          "age" : "5"
                          },
                          "toy" : [{
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Trooper"
                          }, {
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Ultrablock"
                          }, {
                          "$" : {
                          "status" : "new"
                          },
                          "_" : "Bike"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }


                          Quirks to keep in mind:
                          Several tags with the same tagname can be siblings. Other solutions will most likely drop all but the last sibling. To avoid this each and every single node, even if it only has one child, is an array which hold an object for each instance of the tagname. (See multiple "" elements in example)



                          Even the root element, of which only one should exist in a valid XML document is stored as array with an object of the instance, just to have a consistent data structure.



                          To be able to distinguish between XML node content and XML attributes each objects attributes are stored in the "$" and the content in the "_" child.



                          Edit:
                          I forgot to show the output for your example input data



                          {
                          "states" : [{
                          "state" : [{
                          "$" : {
                          "id" : "AL"
                          },
                          "name" : [{
                          "_" : "Alabama"
                          }
                          ]
                          }, {
                          "$" : {
                          "id" : "AK"
                          },
                          "name" : [{
                          "_" : "Alaska"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }





                          share|improve this answer













                          I guess I'm a bit late to the party but I have written a small function to accomplish this task. It also takes care of attributes, text content and even if multiple nodes with the same node-name are siblings.



                          Dislaimer:
                          I'm not a PHP native, so please bear with simple mistakes.



                          function xml2js($xmlnode) {
                          $root = (func_num_args() > 1 ? false : true);
                          $jsnode = array();

                          if (!$root) {
                          if (count($xmlnode->attributes()) > 0){
                          $jsnode["$"] = array();
                          foreach($xmlnode->attributes() as $key => $value)
                          $jsnode["$"][$key] = (string)$value;
                          }

                          $textcontent = trim((string)$xmlnode);
                          if (count($textcontent) > 0)
                          $jsnode["_"] = $textcontent;

                          foreach ($xmlnode->children() as $childxmlnode) {
                          $childname = $childxmlnode->getName();
                          if (!array_key_exists($childname, $jsnode))
                          $jsnode[$childname] = array();
                          array_push($jsnode[$childname], xml2js($childxmlnode, true));
                          }
                          return $jsnode;
                          } else {
                          $nodename = $xmlnode->getName();
                          $jsnode[$nodename] = array();
                          array_push($jsnode[$nodename], xml2js($xmlnode, true));
                          return json_encode($jsnode);
                          }
                          }


                          Usage example:



                          $xml = simplexml_load_file("myfile.xml");
                          echo xml2js($xml);


                          Example Input (myfile.xml):



                          <family name="Johnson">
                          <child name="John" age="5">
                          <toy status="old">Trooper</toy>
                          <toy status="old">Ultrablock</toy>
                          <toy status="new">Bike</toy>
                          </child>
                          </family>


                          Example output:



                          {"family":[{"$":{"name":"Johnson"},"child":[{"$":{"name":"John","age":"5"},"toy":[{"$":{"status":"old"},"_":"Trooper"},{"$":{"status":"old"},"_":"Ultrablock"},{"$":{"status":"new"},"_":"Bike"}]}]}]}


                          Pretty printed:



                          {
                          "family" : [{
                          "$" : {
                          "name" : "Johnson"
                          },
                          "child" : [{
                          "$" : {
                          "name" : "John",
                          "age" : "5"
                          },
                          "toy" : [{
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Trooper"
                          }, {
                          "$" : {
                          "status" : "old"
                          },
                          "_" : "Ultrablock"
                          }, {
                          "$" : {
                          "status" : "new"
                          },
                          "_" : "Bike"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }


                          Quirks to keep in mind:
                          Several tags with the same tagname can be siblings. Other solutions will most likely drop all but the last sibling. To avoid this each and every single node, even if it only has one child, is an array which hold an object for each instance of the tagname. (See multiple "" elements in example)



                          Even the root element, of which only one should exist in a valid XML document is stored as array with an object of the instance, just to have a consistent data structure.



                          To be able to distinguish between XML node content and XML attributes each objects attributes are stored in the "$" and the content in the "_" child.



                          Edit:
                          I forgot to show the output for your example input data



                          {
                          "states" : [{
                          "state" : [{
                          "$" : {
                          "id" : "AL"
                          },
                          "name" : [{
                          "_" : "Alabama"
                          }
                          ]
                          }, {
                          "$" : {
                          "id" : "AK"
                          },
                          "name" : [{
                          "_" : "Alaska"
                          }
                          ]
                          }
                          ]
                          }
                          ]
                          }






                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered Jun 9 '15 at 13:14









                          FTavFTav

                          252311




                          252311













                          • Can it parse large XML data?

                            – Volatil3
                            Mar 1 '16 at 18:09











                          • This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                            – Peter Krauss
                            Oct 6 '16 at 4:27













                          • Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                            – Peter Krauss
                            Oct 6 '16 at 4:57



















                          • Can it parse large XML data?

                            – Volatil3
                            Mar 1 '16 at 18:09











                          • This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                            – Peter Krauss
                            Oct 6 '16 at 4:27













                          • Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                            – Peter Krauss
                            Oct 6 '16 at 4:57

















                          Can it parse large XML data?

                          – Volatil3
                          Mar 1 '16 at 18:09





                          Can it parse large XML data?

                          – Volatil3
                          Mar 1 '16 at 18:09













                          This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                          – Peter Krauss
                          Oct 6 '16 at 4:27







                          This solution is better because not discards XML attributes. See also why this complex structure is better than simplified ones, at xml.com/lpt/a/1658 (see "Semi-Structured XML").... Ops, for CDATA, as @txyoji suggested to flatten CDATA elements $xml = simplexml_load_file("myfile.xml",'SimpleXMLElement',LIBXML_‌​NOCDATA); .

                          – Peter Krauss
                          Oct 6 '16 at 4:27















                          Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                          – Peter Krauss
                          Oct 6 '16 at 4:57





                          Oops BUG!!! losting order and grouping tags. Test with <states> <state>Alabama</state> <p>John</p> <state>Alaska</state> </states>.

                          – Peter Krauss
                          Oct 6 '16 at 4:57











                          8














                          A common pitfall is to forget that json_encode() does not respect elements with a textvalue and attribute(s). It will choose one of those, meaning dataloss.
                          The function below solves that problem. If one decides to go for the json_encode/decode way, the following function is advised.



                          function json_prepare_xml($domNode) {
                          foreach($domNode->childNodes as $node) {
                          if($node->hasChildNodes()) {
                          json_prepare_xml($node);
                          } else {
                          if($domNode->hasAttributes() && strlen($domNode->nodeValue)){
                          $domNode->setAttribute("nodeValue", $node->textContent);
                          $node->nodeValue = "";
                          }
                          }
                          }
                          }

                          $dom = new DOMDocument();
                          $dom->loadXML( file_get_contents($xmlfile) );
                          json_prepare_xml($dom);
                          $sxml = simplexml_load_string( $dom->saveXML() );
                          $json = json_decode( json_encode( $sxml ) );


                          by doing so, <foo bar="3">Lorem</foo> will not end up as {"foo":"Lorem"} in your JSON.






                          share|improve this answer


























                          • Does not compile and does not produce the described output if syntax-errors are corrected.

                            – Richard Kiefer
                            Jan 21 '15 at 10:36











                          • What is $dom? Where did that come from?

                            – Jake Wilson
                            Jan 26 '15 at 20:20











                          • $dom = new DOMDocument(); is where it comes from

                            – Scott
                            Nov 25 '15 at 21:28






                          • 1





                            Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                            – Charlie Smith
                            Feb 29 '16 at 2:46













                          • Definite +1 for this - very important point!

                            – Tom Folk
                            Apr 18 '16 at 10:09
















                          8














                          A common pitfall is to forget that json_encode() does not respect elements with a textvalue and attribute(s). It will choose one of those, meaning dataloss.
                          The function below solves that problem. If one decides to go for the json_encode/decode way, the following function is advised.



                          function json_prepare_xml($domNode) {
                          foreach($domNode->childNodes as $node) {
                          if($node->hasChildNodes()) {
                          json_prepare_xml($node);
                          } else {
                          if($domNode->hasAttributes() && strlen($domNode->nodeValue)){
                          $domNode->setAttribute("nodeValue", $node->textContent);
                          $node->nodeValue = "";
                          }
                          }
                          }
                          }

                          $dom = new DOMDocument();
                          $dom->loadXML( file_get_contents($xmlfile) );
                          json_prepare_xml($dom);
                          $sxml = simplexml_load_string( $dom->saveXML() );
                          $json = json_decode( json_encode( $sxml ) );


                          by doing so, <foo bar="3">Lorem</foo> will not end up as {"foo":"Lorem"} in your JSON.






                          share|improve this answer


























                          • Does not compile and does not produce the described output if syntax-errors are corrected.

                            – Richard Kiefer
                            Jan 21 '15 at 10:36











                          • What is $dom? Where did that come from?

                            – Jake Wilson
                            Jan 26 '15 at 20:20











                          • $dom = new DOMDocument(); is where it comes from

                            – Scott
                            Nov 25 '15 at 21:28






                          • 1





                            Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                            – Charlie Smith
                            Feb 29 '16 at 2:46













                          • Definite +1 for this - very important point!

                            – Tom Folk
                            Apr 18 '16 at 10:09














                          8












                          8








                          8







                          A common pitfall is to forget that json_encode() does not respect elements with a textvalue and attribute(s). It will choose one of those, meaning dataloss.
                          The function below solves that problem. If one decides to go for the json_encode/decode way, the following function is advised.



                          function json_prepare_xml($domNode) {
                          foreach($domNode->childNodes as $node) {
                          if($node->hasChildNodes()) {
                          json_prepare_xml($node);
                          } else {
                          if($domNode->hasAttributes() && strlen($domNode->nodeValue)){
                          $domNode->setAttribute("nodeValue", $node->textContent);
                          $node->nodeValue = "";
                          }
                          }
                          }
                          }

                          $dom = new DOMDocument();
                          $dom->loadXML( file_get_contents($xmlfile) );
                          json_prepare_xml($dom);
                          $sxml = simplexml_load_string( $dom->saveXML() );
                          $json = json_decode( json_encode( $sxml ) );


                          by doing so, <foo bar="3">Lorem</foo> will not end up as {"foo":"Lorem"} in your JSON.






                          share|improve this answer















                          A common pitfall is to forget that json_encode() does not respect elements with a textvalue and attribute(s). It will choose one of those, meaning dataloss.
                          The function below solves that problem. If one decides to go for the json_encode/decode way, the following function is advised.



                          function json_prepare_xml($domNode) {
                          foreach($domNode->childNodes as $node) {
                          if($node->hasChildNodes()) {
                          json_prepare_xml($node);
                          } else {
                          if($domNode->hasAttributes() && strlen($domNode->nodeValue)){
                          $domNode->setAttribute("nodeValue", $node->textContent);
                          $node->nodeValue = "";
                          }
                          }
                          }
                          }

                          $dom = new DOMDocument();
                          $dom->loadXML( file_get_contents($xmlfile) );
                          json_prepare_xml($dom);
                          $sxml = simplexml_load_string( $dom->saveXML() );
                          $json = json_decode( json_encode( $sxml ) );


                          by doing so, <foo bar="3">Lorem</foo> will not end up as {"foo":"Lorem"} in your JSON.







                          share|improve this answer














                          share|improve this answer



                          share|improve this answer








                          edited Jun 8 '17 at 4:43









                          mkaatman

                          4,38612445




                          4,38612445










                          answered Dec 10 '13 at 22:03









                          Coder Of SalvationCoder Of Salvation

                          8911




                          8911













                          • Does not compile and does not produce the described output if syntax-errors are corrected.

                            – Richard Kiefer
                            Jan 21 '15 at 10:36











                          • What is $dom? Where did that come from?

                            – Jake Wilson
                            Jan 26 '15 at 20:20











                          • $dom = new DOMDocument(); is where it comes from

                            – Scott
                            Nov 25 '15 at 21:28






                          • 1





                            Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                            – Charlie Smith
                            Feb 29 '16 at 2:46













                          • Definite +1 for this - very important point!

                            – Tom Folk
                            Apr 18 '16 at 10:09



















                          • Does not compile and does not produce the described output if syntax-errors are corrected.

                            – Richard Kiefer
                            Jan 21 '15 at 10:36











                          • What is $dom? Where did that come from?

                            – Jake Wilson
                            Jan 26 '15 at 20:20











                          • $dom = new DOMDocument(); is where it comes from

                            – Scott
                            Nov 25 '15 at 21:28






                          • 1





                            Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                            – Charlie Smith
                            Feb 29 '16 at 2:46













                          • Definite +1 for this - very important point!

                            – Tom Folk
                            Apr 18 '16 at 10:09

















                          Does not compile and does not produce the described output if syntax-errors are corrected.

                          – Richard Kiefer
                          Jan 21 '15 at 10:36





                          Does not compile and does not produce the described output if syntax-errors are corrected.

                          – Richard Kiefer
                          Jan 21 '15 at 10:36













                          What is $dom? Where did that come from?

                          – Jake Wilson
                          Jan 26 '15 at 20:20





                          What is $dom? Where did that come from?

                          – Jake Wilson
                          Jan 26 '15 at 20:20













                          $dom = new DOMDocument(); is where it comes from

                          – Scott
                          Nov 25 '15 at 21:28





                          $dom = new DOMDocument(); is where it comes from

                          – Scott
                          Nov 25 '15 at 21:28




                          1




                          1





                          Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                          – Charlie Smith
                          Feb 29 '16 at 2:46







                          Last line of code: $json = json_decode( json_encode( $sxml ) ) ); should be : $json = json_decode( json_encode( $sxml ) );

                          – Charlie Smith
                          Feb 29 '16 at 2:46















                          Definite +1 for this - very important point!

                          – Tom Folk
                          Apr 18 '16 at 10:09





                          Definite +1 for this - very important point!

                          – Tom Folk
                          Apr 18 '16 at 10:09











                          6














                          Try to use this



                          $xml = ... // Xml file data

                          // first approach
                          $Json = json_encode(simplexml_load_string($xml));

                          ---------------- OR -----------------------

                          // second approach
                          $Json = json_encode(simplexml_load_string($xml, "SimpleXMLElement", LIBXML_NOCDATA));

                          echo $Json;


                          Or



                          You can use this library : https://github.com/rentpost/xml2array






                          share|improve this answer






























                            6














                            Try to use this



                            $xml = ... // Xml file data

                            // first approach
                            $Json = json_encode(simplexml_load_string($xml));

                            ---------------- OR -----------------------

                            // second approach
                            $Json = json_encode(simplexml_load_string($xml, "SimpleXMLElement", LIBXML_NOCDATA));

                            echo $Json;


                            Or



                            You can use this library : https://github.com/rentpost/xml2array






                            share|improve this answer




























                              6












                              6








                              6







                              Try to use this



                              $xml = ... // Xml file data

                              // first approach
                              $Json = json_encode(simplexml_load_string($xml));

                              ---------------- OR -----------------------

                              // second approach
                              $Json = json_encode(simplexml_load_string($xml, "SimpleXMLElement", LIBXML_NOCDATA));

                              echo $Json;


                              Or



                              You can use this library : https://github.com/rentpost/xml2array






                              share|improve this answer















                              Try to use this



                              $xml = ... // Xml file data

                              // first approach
                              $Json = json_encode(simplexml_load_string($xml));

                              ---------------- OR -----------------------

                              // second approach
                              $Json = json_encode(simplexml_load_string($xml, "SimpleXMLElement", LIBXML_NOCDATA));

                              echo $Json;


                              Or



                              You can use this library : https://github.com/rentpost/xml2array







                              share|improve this answer














                              share|improve this answer



                              share|improve this answer








                              edited Sep 5 '17 at 20:11

























                              answered Jun 25 '16 at 12:15









                              Ajay KumarAjay Kumar

                              1,112620




                              1,112620























                                  3














                                  I've used Miles Johnson's TypeConverter for this purpose. It's installable using Composer.



                                  You could write something like this using it:



                                  <?php
                                  require 'vendor/autoload.php';
                                  use mjohnsonutilityTypeConverter;

                                  $xml = file_get_contents("file.xml");
                                  $arr = TypeConverter::xmlToArray($xml, TypeConverter::XML_GROUP);
                                  echo json_encode($arr);





                                  share|improve this answer




























                                    3














                                    I've used Miles Johnson's TypeConverter for this purpose. It's installable using Composer.



                                    You could write something like this using it:



                                    <?php
                                    require 'vendor/autoload.php';
                                    use mjohnsonutilityTypeConverter;

                                    $xml = file_get_contents("file.xml");
                                    $arr = TypeConverter::xmlToArray($xml, TypeConverter::XML_GROUP);
                                    echo json_encode($arr);





                                    share|improve this answer


























                                      3












                                      3








                                      3







                                      I've used Miles Johnson's TypeConverter for this purpose. It's installable using Composer.



                                      You could write something like this using it:



                                      <?php
                                      require 'vendor/autoload.php';
                                      use mjohnsonutilityTypeConverter;

                                      $xml = file_get_contents("file.xml");
                                      $arr = TypeConverter::xmlToArray($xml, TypeConverter::XML_GROUP);
                                      echo json_encode($arr);





                                      share|improve this answer













                                      I've used Miles Johnson's TypeConverter for this purpose. It's installable using Composer.



                                      You could write something like this using it:



                                      <?php
                                      require 'vendor/autoload.php';
                                      use mjohnsonutilityTypeConverter;

                                      $xml = file_get_contents("file.xml");
                                      $arr = TypeConverter::xmlToArray($xml, TypeConverter::XML_GROUP);
                                      echo json_encode($arr);






                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered May 29 '13 at 13:59









                                      HuskyHusky

                                      3,83523133




                                      3,83523133























                                          3














                                          Optimizing Antonio Max answer:



                                          $xmlfile = 'yourfile.xml';
                                          $xmlparser = xml_parser_create();

                                          // open a file and read data
                                          $fp = fopen($xmlfile, 'r');
                                          //9999999 is the length which fread stops to read.
                                          $xmldata = fread($fp, 9999999);

                                          // converting to XML
                                          $xml = simplexml_load_string($xmldata, "SimpleXMLElement", LIBXML_NOCDATA);

                                          // converting to JSON
                                          $json = json_encode($xml);
                                          $array = json_decode($json,TRUE);





                                          share|improve this answer



















                                          • 1





                                            I used this approach, but JSON is empty. XML is valid.

                                            – ryabenko-pro
                                            Jan 9 '18 at 19:07
















                                          3














                                          Optimizing Antonio Max answer:



                                          $xmlfile = 'yourfile.xml';
                                          $xmlparser = xml_parser_create();

                                          // open a file and read data
                                          $fp = fopen($xmlfile, 'r');
                                          //9999999 is the length which fread stops to read.
                                          $xmldata = fread($fp, 9999999);

                                          // converting to XML
                                          $xml = simplexml_load_string($xmldata, "SimpleXMLElement", LIBXML_NOCDATA);

                                          // converting to JSON
                                          $json = json_encode($xml);
                                          $array = json_decode($json,TRUE);





                                          share|improve this answer



















                                          • 1





                                            I used this approach, but JSON is empty. XML is valid.

                                            – ryabenko-pro
                                            Jan 9 '18 at 19:07














                                          3












                                          3








                                          3







                                          Optimizing Antonio Max answer:



                                          $xmlfile = 'yourfile.xml';
                                          $xmlparser = xml_parser_create();

                                          // open a file and read data
                                          $fp = fopen($xmlfile, 'r');
                                          //9999999 is the length which fread stops to read.
                                          $xmldata = fread($fp, 9999999);

                                          // converting to XML
                                          $xml = simplexml_load_string($xmldata, "SimpleXMLElement", LIBXML_NOCDATA);

                                          // converting to JSON
                                          $json = json_encode($xml);
                                          $array = json_decode($json,TRUE);





                                          share|improve this answer













                                          Optimizing Antonio Max answer:



                                          $xmlfile = 'yourfile.xml';
                                          $xmlparser = xml_parser_create();

                                          // open a file and read data
                                          $fp = fopen($xmlfile, 'r');
                                          //9999999 is the length which fread stops to read.
                                          $xmldata = fread($fp, 9999999);

                                          // converting to XML
                                          $xml = simplexml_load_string($xmldata, "SimpleXMLElement", LIBXML_NOCDATA);

                                          // converting to JSON
                                          $json = json_encode($xml);
                                          $array = json_decode($json,TRUE);






                                          share|improve this answer












                                          share|improve this answer



                                          share|improve this answer










                                          answered Oct 18 '17 at 8:16









                                          Marco LeutiMarco Leuti

                                          392




                                          392








                                          • 1





                                            I used this approach, but JSON is empty. XML is valid.

                                            – ryabenko-pro
                                            Jan 9 '18 at 19:07














                                          • 1





                                            I used this approach, but JSON is empty. XML is valid.

                                            – ryabenko-pro
                                            Jan 9 '18 at 19:07








                                          1




                                          1





                                          I used this approach, but JSON is empty. XML is valid.

                                          – ryabenko-pro
                                          Jan 9 '18 at 19:07





                                          I used this approach, but JSON is empty. XML is valid.

                                          – ryabenko-pro
                                          Jan 9 '18 at 19:07











                                          2














                                          This is an improvement of the most upvoted solution by Antonio Max, which also works with XML that has namespaces (by replacing the colon with an underscore). It also has some extra options (and does parse <person my-attribute='name'>John</person> correctly).



                                          function parse_xml_into_array($xml_string, $options = array()) {
                                          /*
                                          DESCRIPTION:
                                          - parse an XML string into an array
                                          INPUT:
                                          - $xml_string
                                          - $options : associative array with any of these keys:
                                          - 'flatten_cdata' : set to true to flatten CDATA elements
                                          - 'use_objects' : set to true to parse into objects instead of associative arrays
                                          - 'convert_booleans' : set to true to cast string values 'true' and 'false' into booleans
                                          OUTPUT:
                                          - associative array
                                          */

                                          // Remove namespaces by replacing ":" with "_"
                                          if (preg_match_all("|</([\w\-]+):([\w\-]+)>|", $xml_string, $matches, PREG_SET_ORDER)) {
                                          foreach ($matches as $match) {
                                          $xml_string = str_replace('<'. $match[1] .':'. $match[2], '<'. $match[1] .'_'. $match[2], $xml_string);
                                          $xml_string = str_replace('</'. $match[1] .':'. $match[2], '</'. $match[1] .'_'. $match[2], $xml_string);
                                          }
                                          }

                                          $output = json_decode(json_encode(@simplexml_load_string($xml_string, 'SimpleXMLElement', ($options['flatten_cdata'] ? LIBXML_NOCDATA : 0))), ($options['use_objects'] ? false : true));

                                          // Cast string values "true" and "false" to booleans
                                          if ($options['convert_booleans']) {
                                          $bool = function(&$item, $key) {
                                          if (in_array($item, array('true', 'TRUE', 'True'), true)) {
                                          $item = true;
                                          } elseif (in_array($item, array('false', 'FALSE', 'False'), true)) {
                                          $item = false;
                                          }
                                          };
                                          array_walk_recursive($output, $bool);
                                          }

                                          return $output;
                                          }





                                          share|improve this answer


























                                          • One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                            – AlexanderMP
                                            Feb 7 '17 at 16:19











                                          • I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                            – TheStoryCoder
                                            Feb 13 '17 at 21:39











                                          • The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                            – AlexanderMP
                                            May 9 '17 at 17:41











                                          • The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                            – AlexanderMP
                                            May 9 '17 at 17:48


















                                          2














                                          This is an improvement of the most upvoted solution by Antonio Max, which also works with XML that has namespaces (by replacing the colon with an underscore). It also has some extra options (and does parse <person my-attribute='name'>John</person> correctly).



                                          function parse_xml_into_array($xml_string, $options = array()) {
                                          /*
                                          DESCRIPTION:
                                          - parse an XML string into an array
                                          INPUT:
                                          - $xml_string
                                          - $options : associative array with any of these keys:
                                          - 'flatten_cdata' : set to true to flatten CDATA elements
                                          - 'use_objects' : set to true to parse into objects instead of associative arrays
                                          - 'convert_booleans' : set to true to cast string values 'true' and 'false' into booleans
                                          OUTPUT:
                                          - associative array
                                          */

                                          // Remove namespaces by replacing ":" with "_"
                                          if (preg_match_all("|</([\w\-]+):([\w\-]+)>|", $xml_string, $matches, PREG_SET_ORDER)) {
                                          foreach ($matches as $match) {
                                          $xml_string = str_replace('<'. $match[1] .':'. $match[2], '<'. $match[1] .'_'. $match[2], $xml_string);
                                          $xml_string = str_replace('</'. $match[1] .':'. $match[2], '</'. $match[1] .'_'. $match[2], $xml_string);
                                          }
                                          }

                                          $output = json_decode(json_encode(@simplexml_load_string($xml_string, 'SimpleXMLElement', ($options['flatten_cdata'] ? LIBXML_NOCDATA : 0))), ($options['use_objects'] ? false : true));

                                          // Cast string values "true" and "false" to booleans
                                          if ($options['convert_booleans']) {
                                          $bool = function(&$item, $key) {
                                          if (in_array($item, array('true', 'TRUE', 'True'), true)) {
                                          $item = true;
                                          } elseif (in_array($item, array('false', 'FALSE', 'False'), true)) {
                                          $item = false;
                                          }
                                          };
                                          array_walk_recursive($output, $bool);
                                          }

                                          return $output;
                                          }





                                          share|improve this answer


























                                          • One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                            – AlexanderMP
                                            Feb 7 '17 at 16:19











                                          • I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                            – TheStoryCoder
                                            Feb 13 '17 at 21:39











                                          • The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                            – AlexanderMP
                                            May 9 '17 at 17:41











                                          • The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                            – AlexanderMP
                                            May 9 '17 at 17:48
















                                          2












                                          2








                                          2







                                          This is an improvement of the most upvoted solution by Antonio Max, which also works with XML that has namespaces (by replacing the colon with an underscore). It also has some extra options (and does parse <person my-attribute='name'>John</person> correctly).



                                          function parse_xml_into_array($xml_string, $options = array()) {
                                          /*
                                          DESCRIPTION:
                                          - parse an XML string into an array
                                          INPUT:
                                          - $xml_string
                                          - $options : associative array with any of these keys:
                                          - 'flatten_cdata' : set to true to flatten CDATA elements
                                          - 'use_objects' : set to true to parse into objects instead of associative arrays
                                          - 'convert_booleans' : set to true to cast string values 'true' and 'false' into booleans
                                          OUTPUT:
                                          - associative array
                                          */

                                          // Remove namespaces by replacing ":" with "_"
                                          if (preg_match_all("|</([\w\-]+):([\w\-]+)>|", $xml_string, $matches, PREG_SET_ORDER)) {
                                          foreach ($matches as $match) {
                                          $xml_string = str_replace('<'. $match[1] .':'. $match[2], '<'. $match[1] .'_'. $match[2], $xml_string);
                                          $xml_string = str_replace('</'. $match[1] .':'. $match[2], '</'. $match[1] .'_'. $match[2], $xml_string);
                                          }
                                          }

                                          $output = json_decode(json_encode(@simplexml_load_string($xml_string, 'SimpleXMLElement', ($options['flatten_cdata'] ? LIBXML_NOCDATA : 0))), ($options['use_objects'] ? false : true));

                                          // Cast string values "true" and "false" to booleans
                                          if ($options['convert_booleans']) {
                                          $bool = function(&$item, $key) {
                                          if (in_array($item, array('true', 'TRUE', 'True'), true)) {
                                          $item = true;
                                          } elseif (in_array($item, array('false', 'FALSE', 'False'), true)) {
                                          $item = false;
                                          }
                                          };
                                          array_walk_recursive($output, $bool);
                                          }

                                          return $output;
                                          }





                                          share|improve this answer















                                          This is an improvement of the most upvoted solution by Antonio Max, which also works with XML that has namespaces (by replacing the colon with an underscore). It also has some extra options (and does parse <person my-attribute='name'>John</person> correctly).



                                          function parse_xml_into_array($xml_string, $options = array()) {
                                          /*
                                          DESCRIPTION:
                                          - parse an XML string into an array
                                          INPUT:
                                          - $xml_string
                                          - $options : associative array with any of these keys:
                                          - 'flatten_cdata' : set to true to flatten CDATA elements
                                          - 'use_objects' : set to true to parse into objects instead of associative arrays
                                          - 'convert_booleans' : set to true to cast string values 'true' and 'false' into booleans
                                          OUTPUT:
                                          - associative array
                                          */

                                          // Remove namespaces by replacing ":" with "_"
                                          if (preg_match_all("|</([\w\-]+):([\w\-]+)>|", $xml_string, $matches, PREG_SET_ORDER)) {
                                          foreach ($matches as $match) {
                                          $xml_string = str_replace('<'. $match[1] .':'. $match[2], '<'. $match[1] .'_'. $match[2], $xml_string);
                                          $xml_string = str_replace('</'. $match[1] .':'. $match[2], '</'. $match[1] .'_'. $match[2], $xml_string);
                                          }
                                          }

                                          $output = json_decode(json_encode(@simplexml_load_string($xml_string, 'SimpleXMLElement', ($options['flatten_cdata'] ? LIBXML_NOCDATA : 0))), ($options['use_objects'] ? false : true));

                                          // Cast string values "true" and "false" to booleans
                                          if ($options['convert_booleans']) {
                                          $bool = function(&$item, $key) {
                                          if (in_array($item, array('true', 'TRUE', 'True'), true)) {
                                          $item = true;
                                          } elseif (in_array($item, array('false', 'FALSE', 'False'), true)) {
                                          $item = false;
                                          }
                                          };
                                          array_walk_recursive($output, $bool);
                                          }

                                          return $output;
                                          }






                                          share|improve this answer














                                          share|improve this answer



                                          share|improve this answer








                                          edited Nov 30 '16 at 9:31









                                          user5997037

                                          52




                                          52










                                          answered Nov 29 '16 at 13:12









                                          TheStoryCoderTheStoryCoder

                                          1,11821242




                                          1,11821242













                                          • One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                            – AlexanderMP
                                            Feb 7 '17 at 16:19











                                          • I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                            – TheStoryCoder
                                            Feb 13 '17 at 21:39











                                          • The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                            – AlexanderMP
                                            May 9 '17 at 17:41











                                          • The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                            – AlexanderMP
                                            May 9 '17 at 17:48





















                                          • One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                            – AlexanderMP
                                            Feb 7 '17 at 16:19











                                          • I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                            – TheStoryCoder
                                            Feb 13 '17 at 21:39











                                          • The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                            – AlexanderMP
                                            May 9 '17 at 17:41











                                          • The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                            – AlexanderMP
                                            May 9 '17 at 17:48



















                                          One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                          – AlexanderMP
                                          Feb 7 '17 at 16:19





                                          One does not use Regex to parse XML, unless it's a simple XML with trivial structure and very predictable data. I can't stress enough how bad this solution is. This BREAKS DATA. Not to mention that it's incredibly slow (you parse with regex, and then you re-parse again?) and doesn't handle self-closing tags.

                                          – AlexanderMP
                                          Feb 7 '17 at 16:19













                                          I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                          – TheStoryCoder
                                          Feb 13 '17 at 21:39





                                          I don't think you really looked at the function. It doesn't use regex to do the actual parsing, only as a simple fix to deal with namespaces - which has been working for all my xml cases - and that it is working is the most important, rather than being "politically correct". You're welcome to improve it if you want, though!

                                          – TheStoryCoder
                                          Feb 13 '17 at 21:39













                                          The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                          – AlexanderMP
                                          May 9 '17 at 17:41





                                          The fact that it has worked for you doesn't mean it's right. It's code like this that generates bugs that are immensely hard to diagnose, and generates exploits. I mean even looking superficially at XML specs on sites like this w3schools.com/xml/xml_elements.asp show a lot of reasons why this solution wouldn't work. Like I said, it fails to detect self-closing tags like <element/>, fails to address elements that start with, or contain underscores, which is allowed in XML. Fails to detect CDATA. And as I've said, it's SLOW. It's an O(n^2) complexity because of inner parsing.

                                          – AlexanderMP
                                          May 9 '17 at 17:41













                                          The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                          – AlexanderMP
                                          May 9 '17 at 17:48







                                          The thing is that dealing with namespaces wasn't even asked here, and there are PROPER ways to deal with namespaces. Namespaces exist as a helpful construction, NOT to be parsed like that and turned into an abomination that won't be processed by any reasonable parser. And all you needed to do for that is not to create the contender for the prize of "slowest algorithm of 2016", but to do a bit of searching, to come up with a myriad of actual solutions, like this one stackoverflow.com/questions/16412047/… And to call this an improvement? Wow.

                                          – AlexanderMP
                                          May 9 '17 at 17:48













                                          1














                                          If you would like to only convert a specific part of the XML to JSON, you can use XPath to retrieve this and convert that to JSON.



                                          <?php
                                          $file = @file_get_contents($xml_File, FILE_TEXT);
                                          $xml = new SimpleXMLElement($file);
                                          $xml_Excerpt = @$xml->xpath('/states/state[@id="AL"]')[0]; // [0] gets the node
                                          echo json_encode($xml_Excerpt);
                                          ?>


                                          Please note that if you Xpath is incorrect, this will die with an error. So if you're debugging this through AJAX calls I recommend you log the response bodies as well.






                                          share|improve this answer




























                                            1














                                            If you would like to only convert a specific part of the XML to JSON, you can use XPath to retrieve this and convert that to JSON.



                                            <?php
                                            $file = @file_get_contents($xml_File, FILE_TEXT);
                                            $xml = new SimpleXMLElement($file);
                                            $xml_Excerpt = @$xml->xpath('/states/state[@id="AL"]')[0]; // [0] gets the node
                                            echo json_encode($xml_Excerpt);
                                            ?>


                                            Please note that if you Xpath is incorrect, this will die with an error. So if you're debugging this through AJAX calls I recommend you log the response bodies as well.






                                            share|improve this answer


























                                              1












                                              1








                                              1







                                              If you would like to only convert a specific part of the XML to JSON, you can use XPath to retrieve this and convert that to JSON.



                                              <?php
                                              $file = @file_get_contents($xml_File, FILE_TEXT);
                                              $xml = new SimpleXMLElement($file);
                                              $xml_Excerpt = @$xml->xpath('/states/state[@id="AL"]')[0]; // [0] gets the node
                                              echo json_encode($xml_Excerpt);
                                              ?>


                                              Please note that if you Xpath is incorrect, this will die with an error. So if you're debugging this through AJAX calls I recommend you log the response bodies as well.






                                              share|improve this answer













                                              If you would like to only convert a specific part of the XML to JSON, you can use XPath to retrieve this and convert that to JSON.



                                              <?php
                                              $file = @file_get_contents($xml_File, FILE_TEXT);
                                              $xml = new SimpleXMLElement($file);
                                              $xml_Excerpt = @$xml->xpath('/states/state[@id="AL"]')[0]; // [0] gets the node
                                              echo json_encode($xml_Excerpt);
                                              ?>


                                              Please note that if you Xpath is incorrect, this will die with an error. So if you're debugging this through AJAX calls I recommend you log the response bodies as well.







                                              share|improve this answer












                                              share|improve this answer



                                              share|improve this answer










                                              answered Aug 27 '13 at 13:15









                                              ChrisRChrisR

                                              631918




                                              631918























                                                  0














                                                  Looks like the $state->name variable is holding an array. You can use



                                                  var_dump($state)


                                                  inside the foreach to test that.



                                                  If that's the case, you can change the line inside the foreach to



                                                  $states= array('state' => array_shift($state->name)); 


                                                  to correct it.






                                                  share|improve this answer
























                                                  • looks like the attributes are arrays but not $state->name

                                                    – Bryan Hadlock
                                                    Jan 12 '12 at 6:11
















                                                  0














                                                  Looks like the $state->name variable is holding an array. You can use



                                                  var_dump($state)


                                                  inside the foreach to test that.



                                                  If that's the case, you can change the line inside the foreach to



                                                  $states= array('state' => array_shift($state->name)); 


                                                  to correct it.






                                                  share|improve this answer
























                                                  • looks like the attributes are arrays but not $state->name

                                                    – Bryan Hadlock
                                                    Jan 12 '12 at 6:11














                                                  0












                                                  0








                                                  0







                                                  Looks like the $state->name variable is holding an array. You can use



                                                  var_dump($state)


                                                  inside the foreach to test that.



                                                  If that's the case, you can change the line inside the foreach to



                                                  $states= array('state' => array_shift($state->name)); 


                                                  to correct it.






                                                  share|improve this answer













                                                  Looks like the $state->name variable is holding an array. You can use



                                                  var_dump($state)


                                                  inside the foreach to test that.



                                                  If that's the case, you can change the line inside the foreach to



                                                  $states= array('state' => array_shift($state->name)); 


                                                  to correct it.







                                                  share|improve this answer












                                                  share|improve this answer



                                                  share|improve this answer










                                                  answered Jan 12 '12 at 5:46









                                                  Michael FenwickMichael Fenwick

                                                  1,033718




                                                  1,033718













                                                  • looks like the attributes are arrays but not $state->name

                                                    – Bryan Hadlock
                                                    Jan 12 '12 at 6:11



















                                                  • looks like the attributes are arrays but not $state->name

                                                    – Bryan Hadlock
                                                    Jan 12 '12 at 6:11

















                                                  looks like the attributes are arrays but not $state->name

                                                  – Bryan Hadlock
                                                  Jan 12 '12 at 6:11





                                                  looks like the attributes are arrays but not $state->name

                                                  – Bryan Hadlock
                                                  Jan 12 '12 at 6:11











                                                  0














                                                  The question doesn't say it, but usually PHP is returning JSON to a web page.



                                                  I find it much easier to convert the XML to JSON in the browser/page via a JS lib, for example:



                                                  https://code.google.com/p/x2js/downloads/detail?name=x2js-v1.1.3.zip





                                                  share|improve this answer




























                                                    0














                                                    The question doesn't say it, but usually PHP is returning JSON to a web page.



                                                    I find it much easier to convert the XML to JSON in the browser/page via a JS lib, for example:



                                                    https://code.google.com/p/x2js/downloads/detail?name=x2js-v1.1.3.zip





                                                    share|improve this answer


























                                                      0












                                                      0








                                                      0







                                                      The question doesn't say it, but usually PHP is returning JSON to a web page.



                                                      I find it much easier to convert the XML to JSON in the browser/page via a JS lib, for example:



                                                      https://code.google.com/p/x2js/downloads/detail?name=x2js-v1.1.3.zip





                                                      share|improve this answer













                                                      The question doesn't say it, but usually PHP is returning JSON to a web page.



                                                      I find it much easier to convert the XML to JSON in the browser/page via a JS lib, for example:



                                                      https://code.google.com/p/x2js/downloads/detail?name=x2js-v1.1.3.zip






                                                      share|improve this answer












                                                      share|improve this answer



                                                      share|improve this answer










                                                      answered Dec 5 '13 at 15:27









                                                      Bret WeinraubBret Weinraub

                                                      821614




                                                      821614























                                                          0














                                                          All solutions here have problems!



                                                          ... When the representation need perfect XML interpretation (without problems with attributes) and to reproduce all text-tag-text-tag-text-... and order of tags. Also good remember here that JSON object "is an unordered set" (not repeat keys and the keys can't have predefined order)... Even ZF's xml2json is wrong (!) because not preserve exactly the XML structure.



                                                          All solutions here have problems with this simple XML,



                                                              <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>


                                                          ... @FTav solution seems better than 3-line solution, but also have little bug when tested with this XML.



                                                          Old solution is the best (for loss-less representation)



                                                          The solution, today well-known as jsonML, is used by Zorba project and others, and was first presented in ~2006 or ~2007, by (separately) Stephen McKamey and John Snelson.



                                                          // the core algorithm is the XSLT of the "jsonML conventions"
                                                          // see https://github.com/mckamey/jsonml
                                                          $xslt = 'https://raw.githubusercontent.com/mckamey/jsonml/master/jsonml.xslt';
                                                          $dom = new DOMDocument;
                                                          $dom->loadXML('
                                                          <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>
                                                          ');
                                                          if (!$dom) die("nERROR!");
                                                          $xslDoc = new DOMDocument();
                                                          $xslDoc->load($xslt);
                                                          $proc = new XSLTProcessor();
                                                          $proc->importStylesheet($xslDoc);
                                                          echo $proc->transformToXML($dom);


                                                          Produce



                                                          ["states",{"x-x":"1"},
                                                          "nt ",
                                                          ["state",{"y":"123"},"Alabama"],
                                                          "nttMy name is ",
                                                          ["b","John"],
                                                          " Doent ",
                                                          ["state","Alaska"],
                                                          "nt"
                                                          ]


                                                          See http://jsonML.org or github.com/mckamey/jsonml. The production rules of this JSON are based on the element JSON-analog,



                                                          enter image description here



                                                          This syntax is a element definition and recurrence, with
                                                          element-list ::= element ',' element-list | element.






                                                          share|improve this answer


























                                                          • Very unusual xml structure that I doubt would have real life use cases.

                                                            – TheStoryCoder
                                                            Feb 13 '17 at 21:49
















                                                          0














                                                          All solutions here have problems!



                                                          ... When the representation need perfect XML interpretation (without problems with attributes) and to reproduce all text-tag-text-tag-text-... and order of tags. Also good remember here that JSON object "is an unordered set" (not repeat keys and the keys can't have predefined order)... Even ZF's xml2json is wrong (!) because not preserve exactly the XML structure.



                                                          All solutions here have problems with this simple XML,



                                                              <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>


                                                          ... @FTav solution seems better than 3-line solution, but also have little bug when tested with this XML.



                                                          Old solution is the best (for loss-less representation)



                                                          The solution, today well-known as jsonML, is used by Zorba project and others, and was first presented in ~2006 or ~2007, by (separately) Stephen McKamey and John Snelson.



                                                          // the core algorithm is the XSLT of the "jsonML conventions"
                                                          // see https://github.com/mckamey/jsonml
                                                          $xslt = 'https://raw.githubusercontent.com/mckamey/jsonml/master/jsonml.xslt';
                                                          $dom = new DOMDocument;
                                                          $dom->loadXML('
                                                          <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>
                                                          ');
                                                          if (!$dom) die("nERROR!");
                                                          $xslDoc = new DOMDocument();
                                                          $xslDoc->load($xslt);
                                                          $proc = new XSLTProcessor();
                                                          $proc->importStylesheet($xslDoc);
                                                          echo $proc->transformToXML($dom);


                                                          Produce



                                                          ["states",{"x-x":"1"},
                                                          "nt ",
                                                          ["state",{"y":"123"},"Alabama"],
                                                          "nttMy name is ",
                                                          ["b","John"],
                                                          " Doent ",
                                                          ["state","Alaska"],
                                                          "nt"
                                                          ]


                                                          See http://jsonML.org or github.com/mckamey/jsonml. The production rules of this JSON are based on the element JSON-analog,



                                                          enter image description here



                                                          This syntax is a element definition and recurrence, with
                                                          element-list ::= element ',' element-list | element.






                                                          share|improve this answer


























                                                          • Very unusual xml structure that I doubt would have real life use cases.

                                                            – TheStoryCoder
                                                            Feb 13 '17 at 21:49














                                                          0












                                                          0








                                                          0







                                                          All solutions here have problems!



                                                          ... When the representation need perfect XML interpretation (without problems with attributes) and to reproduce all text-tag-text-tag-text-... and order of tags. Also good remember here that JSON object "is an unordered set" (not repeat keys and the keys can't have predefined order)... Even ZF's xml2json is wrong (!) because not preserve exactly the XML structure.



                                                          All solutions here have problems with this simple XML,



                                                              <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>


                                                          ... @FTav solution seems better than 3-line solution, but also have little bug when tested with this XML.



                                                          Old solution is the best (for loss-less representation)



                                                          The solution, today well-known as jsonML, is used by Zorba project and others, and was first presented in ~2006 or ~2007, by (separately) Stephen McKamey and John Snelson.



                                                          // the core algorithm is the XSLT of the "jsonML conventions"
                                                          // see https://github.com/mckamey/jsonml
                                                          $xslt = 'https://raw.githubusercontent.com/mckamey/jsonml/master/jsonml.xslt';
                                                          $dom = new DOMDocument;
                                                          $dom->loadXML('
                                                          <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>
                                                          ');
                                                          if (!$dom) die("nERROR!");
                                                          $xslDoc = new DOMDocument();
                                                          $xslDoc->load($xslt);
                                                          $proc = new XSLTProcessor();
                                                          $proc->importStylesheet($xslDoc);
                                                          echo $proc->transformToXML($dom);


                                                          Produce



                                                          ["states",{"x-x":"1"},
                                                          "nt ",
                                                          ["state",{"y":"123"},"Alabama"],
                                                          "nttMy name is ",
                                                          ["b","John"],
                                                          " Doent ",
                                                          ["state","Alaska"],
                                                          "nt"
                                                          ]


                                                          See http://jsonML.org or github.com/mckamey/jsonml. The production rules of this JSON are based on the element JSON-analog,



                                                          enter image description here



                                                          This syntax is a element definition and recurrence, with
                                                          element-list ::= element ',' element-list | element.






                                                          share|improve this answer















                                                          All solutions here have problems!



                                                          ... When the representation need perfect XML interpretation (without problems with attributes) and to reproduce all text-tag-text-tag-text-... and order of tags. Also good remember here that JSON object "is an unordered set" (not repeat keys and the keys can't have predefined order)... Even ZF's xml2json is wrong (!) because not preserve exactly the XML structure.



                                                          All solutions here have problems with this simple XML,



                                                              <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>


                                                          ... @FTav solution seems better than 3-line solution, but also have little bug when tested with this XML.



                                                          Old solution is the best (for loss-less representation)



                                                          The solution, today well-known as jsonML, is used by Zorba project and others, and was first presented in ~2006 or ~2007, by (separately) Stephen McKamey and John Snelson.



                                                          // the core algorithm is the XSLT of the "jsonML conventions"
                                                          // see https://github.com/mckamey/jsonml
                                                          $xslt = 'https://raw.githubusercontent.com/mckamey/jsonml/master/jsonml.xslt';
                                                          $dom = new DOMDocument;
                                                          $dom->loadXML('
                                                          <states x-x='1'>
                                                          <state y="123">Alabama</state>
                                                          My name is <b>John</b> Doe
                                                          <state>Alaska</state>
                                                          </states>
                                                          ');
                                                          if (!$dom) die("nERROR!");
                                                          $xslDoc = new DOMDocument();
                                                          $xslDoc->load($xslt);
                                                          $proc = new XSLTProcessor();
                                                          $proc->importStylesheet($xslDoc);
                                                          echo $proc->transformToXML($dom);


                                                          Produce



                                                          ["states",{"x-x":"1"},
                                                          "nt ",
                                                          ["state",{"y":"123"},"Alabama"],
                                                          "nttMy name is ",
                                                          ["b","John"],
                                                          " Doent ",
                                                          ["state","Alaska"],
                                                          "nt"
                                                          ]


                                                          See http://jsonML.org or github.com/mckamey/jsonml. The production rules of this JSON are based on the element JSON-analog,



                                                          enter image description here



                                                          This syntax is a element definition and recurrence, with
                                                          element-list ::= element ',' element-list | element.







                                                          share|improve this answer














                                                          share|improve this answer



                                                          share|improve this answer








                                                          edited Oct 6 '16 at 13:26

























                                                          answered Oct 6 '16 at 6:30









                                                          Peter KraussPeter Krauss

                                                          5,6591087180




                                                          5,6591087180













                                                          • Very unusual xml structure that I doubt would have real life use cases.

                                                            – TheStoryCoder
                                                            Feb 13 '17 at 21:49



















                                                          • Very unusual xml structure that I doubt would have real life use cases.

                                                            – TheStoryCoder
                                                            Feb 13 '17 at 21:49

















                                                          Very unusual xml structure that I doubt would have real life use cases.

                                                          – TheStoryCoder
                                                          Feb 13 '17 at 21:49





                                                          Very unusual xml structure that I doubt would have real life use cases.

                                                          – TheStoryCoder
                                                          Feb 13 '17 at 21:49











                                                          0














                                                          After researching a little bit all of the answers, I came up with a solution that worked just fine with my JavaScript functions across browsers (Including consoles / Dev Tools) :



                                                          <?php

                                                          // PHP Version 7.2.1 (Windows 10 x86)

                                                          function json2xml( $domNode ) {
                                                          foreach( $domNode -> childNodes as $node) {
                                                          if ( $node -> hasChildNodes() ) { json2xml( $node ); }
                                                          else {
                                                          if ( $domNode -> hasAttributes() && strlen( $domNode -> nodeValue ) ) {
                                                          $domNode -> setAttribute( "nodeValue", $node -> textContent );
                                                          $node -> nodeValue = "";
                                                          }
                                                          }
                                                          }
                                                          }

                                                          function jsonOut( $file ) {
                                                          $dom = new DOMDocument();
                                                          $dom -> loadXML( file_get_contents( $file ) );
                                                          json2xml( $dom );
                                                          header( 'Content-Type: application/json' );
                                                          return str_replace( "@", "", json_encode( simplexml_load_string( $dom -> saveXML() ), JSON_PRETTY_PRINT ) );
                                                          }

                                                          $output = jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' );

                                                          echo( $output );

                                                          /*
                                                          Or simply
                                                          echo( jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' ) );
                                                          */

                                                          ?>


                                                          It basically creates a new DOMDocument, loads and XML file into it and traverses through each one of the nodes and children getting the data / parameters and exporting it into JSON without the annoying "@" signs.



                                                          Link to the XML file.






                                                          share|improve this answer




























                                                            0














                                                            After researching a little bit all of the answers, I came up with a solution that worked just fine with my JavaScript functions across browsers (Including consoles / Dev Tools) :



                                                            <?php

                                                            // PHP Version 7.2.1 (Windows 10 x86)

                                                            function json2xml( $domNode ) {
                                                            foreach( $domNode -> childNodes as $node) {
                                                            if ( $node -> hasChildNodes() ) { json2xml( $node ); }
                                                            else {
                                                            if ( $domNode -> hasAttributes() && strlen( $domNode -> nodeValue ) ) {
                                                            $domNode -> setAttribute( "nodeValue", $node -> textContent );
                                                            $node -> nodeValue = "";
                                                            }
                                                            }
                                                            }
                                                            }

                                                            function jsonOut( $file ) {
                                                            $dom = new DOMDocument();
                                                            $dom -> loadXML( file_get_contents( $file ) );
                                                            json2xml( $dom );
                                                            header( 'Content-Type: application/json' );
                                                            return str_replace( "@", "", json_encode( simplexml_load_string( $dom -> saveXML() ), JSON_PRETTY_PRINT ) );
                                                            }

                                                            $output = jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' );

                                                            echo( $output );

                                                            /*
                                                            Or simply
                                                            echo( jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' ) );
                                                            */

                                                            ?>


                                                            It basically creates a new DOMDocument, loads and XML file into it and traverses through each one of the nodes and children getting the data / parameters and exporting it into JSON without the annoying "@" signs.



                                                            Link to the XML file.






                                                            share|improve this answer


























                                                              0












                                                              0








                                                              0







                                                              After researching a little bit all of the answers, I came up with a solution that worked just fine with my JavaScript functions across browsers (Including consoles / Dev Tools) :



                                                              <?php

                                                              // PHP Version 7.2.1 (Windows 10 x86)

                                                              function json2xml( $domNode ) {
                                                              foreach( $domNode -> childNodes as $node) {
                                                              if ( $node -> hasChildNodes() ) { json2xml( $node ); }
                                                              else {
                                                              if ( $domNode -> hasAttributes() && strlen( $domNode -> nodeValue ) ) {
                                                              $domNode -> setAttribute( "nodeValue", $node -> textContent );
                                                              $node -> nodeValue = "";
                                                              }
                                                              }
                                                              }
                                                              }

                                                              function jsonOut( $file ) {
                                                              $dom = new DOMDocument();
                                                              $dom -> loadXML( file_get_contents( $file ) );
                                                              json2xml( $dom );
                                                              header( 'Content-Type: application/json' );
                                                              return str_replace( "@", "", json_encode( simplexml_load_string( $dom -> saveXML() ), JSON_PRETTY_PRINT ) );
                                                              }

                                                              $output = jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' );

                                                              echo( $output );

                                                              /*
                                                              Or simply
                                                              echo( jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' ) );
                                                              */

                                                              ?>


                                                              It basically creates a new DOMDocument, loads and XML file into it and traverses through each one of the nodes and children getting the data / parameters and exporting it into JSON without the annoying "@" signs.



                                                              Link to the XML file.






                                                              share|improve this answer













                                                              After researching a little bit all of the answers, I came up with a solution that worked just fine with my JavaScript functions across browsers (Including consoles / Dev Tools) :



                                                              <?php

                                                              // PHP Version 7.2.1 (Windows 10 x86)

                                                              function json2xml( $domNode ) {
                                                              foreach( $domNode -> childNodes as $node) {
                                                              if ( $node -> hasChildNodes() ) { json2xml( $node ); }
                                                              else {
                                                              if ( $domNode -> hasAttributes() && strlen( $domNode -> nodeValue ) ) {
                                                              $domNode -> setAttribute( "nodeValue", $node -> textContent );
                                                              $node -> nodeValue = "";
                                                              }
                                                              }
                                                              }
                                                              }

                                                              function jsonOut( $file ) {
                                                              $dom = new DOMDocument();
                                                              $dom -> loadXML( file_get_contents( $file ) );
                                                              json2xml( $dom );
                                                              header( 'Content-Type: application/json' );
                                                              return str_replace( "@", "", json_encode( simplexml_load_string( $dom -> saveXML() ), JSON_PRETTY_PRINT ) );
                                                              }

                                                              $output = jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' );

                                                              echo( $output );

                                                              /*
                                                              Or simply
                                                              echo( jsonOut( 'https://boxelizer.com/assets/a1e10642e9294f39/b6f30987f0b66103.xml' ) );
                                                              */

                                                              ?>


                                                              It basically creates a new DOMDocument, loads and XML file into it and traverses through each one of the nodes and children getting the data / parameters and exporting it into JSON without the annoying "@" signs.



                                                              Link to the XML file.







                                                              share|improve this answer












                                                              share|improve this answer



                                                              share|improve this answer










                                                              answered Jul 6 '18 at 0:08









                                                              XedretXedret

                                                              920818




                                                              920818























                                                                  0














                                                                  This solution handles namespaces, attributes, and produces consistent result with repeating elements (always in array, even if there is only one occurrence).
                                                                  Inspired by ratfactor's sxiToArray().



                                                                  /**
                                                                  * <root><a>5</a><b>6</b><b>8</b></root> -> {"root":[{"a":["5"],"b":["6","8"]}]}
                                                                  * <root a="5"><b>6</b><b>8</b></root> -> {"root":[{"a":"5","b":["6","8"]}]}
                                                                  * <root xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy"><a>123</a><wsp:b>456</wsp:b></root>
                                                                  * -> {"root":[{"xmlns:wsp":"http://schemas.xmlsoap.org/ws/2004/09/policy","a":["123"],"wsp:b":["456"]}]}
                                                                  */
                                                                  function domNodesToArray(array $tags, DOMXPath $xpath)
                                                                  {
                                                                  $tagNameToArr = ;
                                                                  foreach ($tags as $tag) {
                                                                  $tagData = ;
                                                                  $attrs = $tag->attributes ? iterator_to_array($tag->attributes) : ;
                                                                  $subTags = $tag->childNodes ? iterator_to_array($tag->childNodes) : ;
                                                                  foreach ($xpath->query('namespace::*', $tag) as $nsNode) {
                                                                  // the only way to get xmlns:*, see https://stackoverflow.com/a/2470433/2750743
                                                                  if ($tag->hasAttribute($nsNode->nodeName)) {
                                                                  $attrs = $nsNode;
                                                                  }
                                                                  }

                                                                  foreach ($attrs as $attr) {
                                                                  $tagData[$attr->nodeName] = $attr->nodeValue;
                                                                  }
                                                                  if (count($subTags) === 1 && $subTags[0] instanceof DOMText) {
                                                                  $text = $subTags[0]->nodeValue;
                                                                  } elseif (count($subTags) === 0) {
                                                                  $text = '';
                                                                  } else {
                                                                  // ignore whitespace (and any other text if any) between nodes
                                                                  $isNotDomText = function($node){return !($node instanceof DOMText);};
                                                                  $realNodes = array_filter($subTags, $isNotDomText);
                                                                  $subTagNameToArr = domNodesToArray($realNodes, $xpath);
                                                                  $tagData = array_merge($tagData, $subTagNameToArr);
                                                                  $text = null;
                                                                  }
                                                                  if (!is_null($text)) {
                                                                  if ($attrs) {
                                                                  if ($text) {
                                                                  $tagData['_'] = $text;
                                                                  }
                                                                  } else {
                                                                  $tagData = $text;
                                                                  }
                                                                  }
                                                                  $keyName = $tag->nodeName;
                                                                  $tagNameToArr[$keyName] = $tagData;
                                                                  }
                                                                  return $tagNameToArr;
                                                                  }

                                                                  function xmlToArr(string $xml)
                                                                  {
                                                                  $doc = new DOMDocument();
                                                                  $doc->loadXML($xml);
                                                                  $xpath = new DOMXPath($doc);
                                                                  $tags = $doc->childNodes ? iterator_to_array($doc->childNodes) : ;
                                                                  return domNodesToArray($tags, $xpath);
                                                                  }


                                                                  Example:



                                                                  php > print(json_encode(xmlToArr('<root a="5"><b>6</b></root>')));
                                                                  {"root":[{"a":"5","b":["6"]}]}





                                                                  share|improve this answer




























                                                                    0














                                                                    This solution handles namespaces, attributes, and produces consistent result with repeating elements (always in array, even if there is only one occurrence).
                                                                    Inspired by ratfactor's sxiToArray().



                                                                    /**
                                                                    * <root><a>5</a><b>6</b><b>8</b></root> -> {"root":[{"a":["5"],"b":["6","8"]}]}
                                                                    * <root a="5"><b>6</b><b>8</b></root> -> {"root":[{"a":"5","b":["6","8"]}]}
                                                                    * <root xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy"><a>123</a><wsp:b>456</wsp:b></root>
                                                                    * -> {"root":[{"xmlns:wsp":"http://schemas.xmlsoap.org/ws/2004/09/policy","a":["123"],"wsp:b":["456"]}]}
                                                                    */
                                                                    function domNodesToArray(array $tags, DOMXPath $xpath)
                                                                    {
                                                                    $tagNameToArr = ;
                                                                    foreach ($tags as $tag) {
                                                                    $tagData = ;
                                                                    $attrs = $tag->attributes ? iterator_to_array($tag->attributes) : ;
                                                                    $subTags = $tag->childNodes ? iterator_to_array($tag->childNodes) : ;
                                                                    foreach ($xpath->query('namespace::*', $tag) as $nsNode) {
                                                                    // the only way to get xmlns:*, see https://stackoverflow.com/a/2470433/2750743
                                                                    if ($tag->hasAttribute($nsNode->nodeName)) {
                                                                    $attrs = $nsNode;
                                                                    }
                                                                    }

                                                                    foreach ($attrs as $attr) {
                                                                    $tagData[$attr->nodeName] = $attr->nodeValue;
                                                                    }
                                                                    if (count($subTags) === 1 && $subTags[0] instanceof DOMText) {
                                                                    $text = $subTags[0]->nodeValue;
                                                                    } elseif (count($subTags) === 0) {
                                                                    $text = '';
                                                                    } else {
                                                                    // ignore whitespace (and any other text if any) between nodes
                                                                    $isNotDomText = function($node){return !($node instanceof DOMText);};
                                                                    $realNodes = array_filter($subTags, $isNotDomText);
                                                                    $subTagNameToArr = domNodesToArray($realNodes, $xpath);
                                                                    $tagData = array_merge($tagData, $subTagNameToArr);
                                                                    $text = null;
                                                                    }
                                                                    if (!is_null($text)) {
                                                                    if ($attrs) {
                                                                    if ($text) {
                                                                    $tagData['_'] = $text;
                                                                    }
                                                                    } else {
                                                                    $tagData = $text;
                                                                    }
                                                                    }
                                                                    $keyName = $tag->nodeName;
                                                                    $tagNameToArr[$keyName] = $tagData;
                                                                    }
                                                                    return $tagNameToArr;
                                                                    }

                                                                    function xmlToArr(string $xml)
                                                                    {
                                                                    $doc = new DOMDocument();
                                                                    $doc->loadXML($xml);
                                                                    $xpath = new DOMXPath($doc);
                                                                    $tags = $doc->childNodes ? iterator_to_array($doc->childNodes) : ;
                                                                    return domNodesToArray($tags, $xpath);
                                                                    }


                                                                    Example:



                                                                    php > print(json_encode(xmlToArr('<root a="5"><b>6</b></root>')));
                                                                    {"root":[{"a":"5","b":["6"]}]}





                                                                    share|improve this answer


























                                                                      0












                                                                      0








                                                                      0







                                                                      This solution handles namespaces, attributes, and produces consistent result with repeating elements (always in array, even if there is only one occurrence).
                                                                      Inspired by ratfactor's sxiToArray().



                                                                      /**
                                                                      * <root><a>5</a><b>6</b><b>8</b></root> -> {"root":[{"a":["5"],"b":["6","8"]}]}
                                                                      * <root a="5"><b>6</b><b>8</b></root> -> {"root":[{"a":"5","b":["6","8"]}]}
                                                                      * <root xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy"><a>123</a><wsp:b>456</wsp:b></root>
                                                                      * -> {"root":[{"xmlns:wsp":"http://schemas.xmlsoap.org/ws/2004/09/policy","a":["123"],"wsp:b":["456"]}]}
                                                                      */
                                                                      function domNodesToArray(array $tags, DOMXPath $xpath)
                                                                      {
                                                                      $tagNameToArr = ;
                                                                      foreach ($tags as $tag) {
                                                                      $tagData = ;
                                                                      $attrs = $tag->attributes ? iterator_to_array($tag->attributes) : ;
                                                                      $subTags = $tag->childNodes ? iterator_to_array($tag->childNodes) : ;
                                                                      foreach ($xpath->query('namespace::*', $tag) as $nsNode) {
                                                                      // the only way to get xmlns:*, see https://stackoverflow.com/a/2470433/2750743
                                                                      if ($tag->hasAttribute($nsNode->nodeName)) {
                                                                      $attrs = $nsNode;
                                                                      }
                                                                      }

                                                                      foreach ($attrs as $attr) {
                                                                      $tagData[$attr->nodeName] = $attr->nodeValue;
                                                                      }
                                                                      if (count($subTags) === 1 && $subTags[0] instanceof DOMText) {
                                                                      $text = $subTags[0]->nodeValue;
                                                                      } elseif (count($subTags) === 0) {
                                                                      $text = '';
                                                                      } else {
                                                                      // ignore whitespace (and any other text if any) between nodes
                                                                      $isNotDomText = function($node){return !($node instanceof DOMText);};
                                                                      $realNodes = array_filter($subTags, $isNotDomText);
                                                                      $subTagNameToArr = domNodesToArray($realNodes, $xpath);
                                                                      $tagData = array_merge($tagData, $subTagNameToArr);
                                                                      $text = null;
                                                                      }
                                                                      if (!is_null($text)) {
                                                                      if ($attrs) {
                                                                      if ($text) {
                                                                      $tagData['_'] = $text;
                                                                      }
                                                                      } else {
                                                                      $tagData = $text;
                                                                      }
                                                                      }
                                                                      $keyName = $tag->nodeName;
                                                                      $tagNameToArr[$keyName] = $tagData;
                                                                      }
                                                                      return $tagNameToArr;
                                                                      }

                                                                      function xmlToArr(string $xml)
                                                                      {
                                                                      $doc = new DOMDocument();
                                                                      $doc->loadXML($xml);
                                                                      $xpath = new DOMXPath($doc);
                                                                      $tags = $doc->childNodes ? iterator_to_array($doc->childNodes) : ;
                                                                      return domNodesToArray($tags, $xpath);
                                                                      }


                                                                      Example:



                                                                      php > print(json_encode(xmlToArr('<root a="5"><b>6</b></root>')));
                                                                      {"root":[{"a":"5","b":["6"]}]}





                                                                      share|improve this answer













                                                                      This solution handles namespaces, attributes, and produces consistent result with repeating elements (always in array, even if there is only one occurrence).
                                                                      Inspired by ratfactor's sxiToArray().



                                                                      /**
                                                                      * <root><a>5</a><b>6</b><b>8</b></root> -> {"root":[{"a":["5"],"b":["6","8"]}]}
                                                                      * <root a="5"><b>6</b><b>8</b></root> -> {"root":[{"a":"5","b":["6","8"]}]}
                                                                      * <root xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy"><a>123</a><wsp:b>456</wsp:b></root>
                                                                      * -> {"root":[{"xmlns:wsp":"http://schemas.xmlsoap.org/ws/2004/09/policy","a":["123"],"wsp:b":["456"]}]}
                                                                      */
                                                                      function domNodesToArray(array $tags, DOMXPath $xpath)
                                                                      {
                                                                      $tagNameToArr = ;
                                                                      foreach ($tags as $tag) {
                                                                      $tagData = ;
                                                                      $attrs = $tag->attributes ? iterator_to_array($tag->attributes) : ;
                                                                      $subTags = $tag->childNodes ? iterator_to_array($tag->childNodes) : ;
                                                                      foreach ($xpath->query('namespace::*', $tag) as $nsNode) {
                                                                      // the only way to get xmlns:*, see https://stackoverflow.com/a/2470433/2750743
                                                                      if ($tag->hasAttribute($nsNode->nodeName)) {
                                                                      $attrs = $nsNode;
                                                                      }
                                                                      }

                                                                      foreach ($attrs as $attr) {
                                                                      $tagData[$attr->nodeName] = $attr->nodeValue;
                                                                      }
                                                                      if (count($subTags) === 1 && $subTags[0] instanceof DOMText) {
                                                                      $text = $subTags[0]->nodeValue;
                                                                      } elseif (count($subTags) === 0) {
                                                                      $text = '';
                                                                      } else {
                                                                      // ignore whitespace (and any other text if any) between nodes
                                                                      $isNotDomText = function($node){return !($node instanceof DOMText);};
                                                                      $realNodes = array_filter($subTags, $isNotDomText);
                                                                      $subTagNameToArr = domNodesToArray($realNodes, $xpath);
                                                                      $tagData = array_merge($tagData, $subTagNameToArr);
                                                                      $text = null;
                                                                      }
                                                                      if (!is_null($text)) {
                                                                      if ($attrs) {
                                                                      if ($text) {
                                                                      $tagData['_'] = $text;
                                                                      }
                                                                      } else {
                                                                      $tagData = $text;
                                                                      }
                                                                      }
                                                                      $keyName = $tag->nodeName;
                                                                      $tagNameToArr[$keyName] = $tagData;
                                                                      }
                                                                      return $tagNameToArr;
                                                                      }

                                                                      function xmlToArr(string $xml)
                                                                      {
                                                                      $doc = new DOMDocument();
                                                                      $doc->loadXML($xml);
                                                                      $xpath = new DOMXPath($doc);
                                                                      $tags = $doc->childNodes ? iterator_to_array($doc->childNodes) : ;
                                                                      return domNodesToArray($tags, $xpath);
                                                                      }


                                                                      Example:



                                                                      php > print(json_encode(xmlToArr('<root a="5"><b>6</b></root>')));
                                                                      {"root":[{"a":"5","b":["6"]}]}






                                                                      share|improve this answer












                                                                      share|improve this answer



                                                                      share|improve this answer










                                                                      answered Jan 7 at 22:34









                                                                      Artur KlesunArtur Klesun

                                                                      3,48521923




                                                                      3,48521923























                                                                          -1














                                                                          $templateData =  $_POST['data'];

                                                                          // initializing or creating array
                                                                          $template_info = $templateData;

                                                                          // creating object of SimpleXMLElement
                                                                          $xml_template_info = new SimpleXMLElement("<?xml version="1.0"?><template></template>");

                                                                          // function call to convert array to xml
                                                                          array_to_xml($template_info,$xml_template_info);

                                                                          //saving generated xml file
                                                                          $xml_template_info->asXML(dirname(__FILE__)."/manifest.xml") ;

                                                                          // function defination to convert array to xml
                                                                          function array_to_xml($template_info, &$xml_template_info) {
                                                                          foreach($template_info as $key => $value) {
                                                                          if(is_array($value)) {
                                                                          if(!is_numeric($key)){
                                                                          $subnode = $xml_template_info->addChild($key);
                                                                          if(is_array($value)){
                                                                          $cont = 0;
                                                                          foreach(array_keys($value) as $k){
                                                                          if(is_numeric($k)) $cont++;
                                                                          }
                                                                          }

                                                                          if($cont>0){
                                                                          for($i=0; $i < $cont; $i++){
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value[$i], $subnode);
                                                                          }
                                                                          }else{
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value, $subnode);
                                                                          }
                                                                          }
                                                                          else{
                                                                          array_to_xml($value, $xml_template_info);
                                                                          }
                                                                          }
                                                                          else {
                                                                          $xml_template_info->addChild($key,$value);
                                                                          }
                                                                          }
                                                                          }





                                                                          share|improve this answer
























                                                                          • It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                            – Octavio Perez Gallegos
                                                                            Jun 30 '16 at 22:45








                                                                          • 1





                                                                            In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                            – Dan Roche
                                                                            Jun 30 '16 at 22:54











                                                                          • Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                            – Octavio Perez Gallegos
                                                                            Jul 26 '16 at 17:45
















                                                                          -1














                                                                          $templateData =  $_POST['data'];

                                                                          // initializing or creating array
                                                                          $template_info = $templateData;

                                                                          // creating object of SimpleXMLElement
                                                                          $xml_template_info = new SimpleXMLElement("<?xml version="1.0"?><template></template>");

                                                                          // function call to convert array to xml
                                                                          array_to_xml($template_info,$xml_template_info);

                                                                          //saving generated xml file
                                                                          $xml_template_info->asXML(dirname(__FILE__)."/manifest.xml") ;

                                                                          // function defination to convert array to xml
                                                                          function array_to_xml($template_info, &$xml_template_info) {
                                                                          foreach($template_info as $key => $value) {
                                                                          if(is_array($value)) {
                                                                          if(!is_numeric($key)){
                                                                          $subnode = $xml_template_info->addChild($key);
                                                                          if(is_array($value)){
                                                                          $cont = 0;
                                                                          foreach(array_keys($value) as $k){
                                                                          if(is_numeric($k)) $cont++;
                                                                          }
                                                                          }

                                                                          if($cont>0){
                                                                          for($i=0; $i < $cont; $i++){
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value[$i], $subnode);
                                                                          }
                                                                          }else{
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value, $subnode);
                                                                          }
                                                                          }
                                                                          else{
                                                                          array_to_xml($value, $xml_template_info);
                                                                          }
                                                                          }
                                                                          else {
                                                                          $xml_template_info->addChild($key,$value);
                                                                          }
                                                                          }
                                                                          }





                                                                          share|improve this answer
























                                                                          • It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                            – Octavio Perez Gallegos
                                                                            Jun 30 '16 at 22:45








                                                                          • 1





                                                                            In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                            – Dan Roche
                                                                            Jun 30 '16 at 22:54











                                                                          • Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                            – Octavio Perez Gallegos
                                                                            Jul 26 '16 at 17:45














                                                                          -1












                                                                          -1








                                                                          -1







                                                                          $templateData =  $_POST['data'];

                                                                          // initializing or creating array
                                                                          $template_info = $templateData;

                                                                          // creating object of SimpleXMLElement
                                                                          $xml_template_info = new SimpleXMLElement("<?xml version="1.0"?><template></template>");

                                                                          // function call to convert array to xml
                                                                          array_to_xml($template_info,$xml_template_info);

                                                                          //saving generated xml file
                                                                          $xml_template_info->asXML(dirname(__FILE__)."/manifest.xml") ;

                                                                          // function defination to convert array to xml
                                                                          function array_to_xml($template_info, &$xml_template_info) {
                                                                          foreach($template_info as $key => $value) {
                                                                          if(is_array($value)) {
                                                                          if(!is_numeric($key)){
                                                                          $subnode = $xml_template_info->addChild($key);
                                                                          if(is_array($value)){
                                                                          $cont = 0;
                                                                          foreach(array_keys($value) as $k){
                                                                          if(is_numeric($k)) $cont++;
                                                                          }
                                                                          }

                                                                          if($cont>0){
                                                                          for($i=0; $i < $cont; $i++){
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value[$i], $subnode);
                                                                          }
                                                                          }else{
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value, $subnode);
                                                                          }
                                                                          }
                                                                          else{
                                                                          array_to_xml($value, $xml_template_info);
                                                                          }
                                                                          }
                                                                          else {
                                                                          $xml_template_info->addChild($key,$value);
                                                                          }
                                                                          }
                                                                          }





                                                                          share|improve this answer













                                                                          $templateData =  $_POST['data'];

                                                                          // initializing or creating array
                                                                          $template_info = $templateData;

                                                                          // creating object of SimpleXMLElement
                                                                          $xml_template_info = new SimpleXMLElement("<?xml version="1.0"?><template></template>");

                                                                          // function call to convert array to xml
                                                                          array_to_xml($template_info,$xml_template_info);

                                                                          //saving generated xml file
                                                                          $xml_template_info->asXML(dirname(__FILE__)."/manifest.xml") ;

                                                                          // function defination to convert array to xml
                                                                          function array_to_xml($template_info, &$xml_template_info) {
                                                                          foreach($template_info as $key => $value) {
                                                                          if(is_array($value)) {
                                                                          if(!is_numeric($key)){
                                                                          $subnode = $xml_template_info->addChild($key);
                                                                          if(is_array($value)){
                                                                          $cont = 0;
                                                                          foreach(array_keys($value) as $k){
                                                                          if(is_numeric($k)) $cont++;
                                                                          }
                                                                          }

                                                                          if($cont>0){
                                                                          for($i=0; $i < $cont; $i++){
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value[$i], $subnode);
                                                                          }
                                                                          }else{
                                                                          $subnode = $xml_body_info->addChild($key);
                                                                          array_to_xml($value, $subnode);
                                                                          }
                                                                          }
                                                                          else{
                                                                          array_to_xml($value, $xml_template_info);
                                                                          }
                                                                          }
                                                                          else {
                                                                          $xml_template_info->addChild($key,$value);
                                                                          }
                                                                          }
                                                                          }






                                                                          share|improve this answer












                                                                          share|improve this answer



                                                                          share|improve this answer










                                                                          answered Jun 30 '16 at 22:43









                                                                          Octavio Perez GallegosOctavio Perez Gallegos

                                                                          11




                                                                          11













                                                                          • It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                            – Octavio Perez Gallegos
                                                                            Jun 30 '16 at 22:45








                                                                          • 1





                                                                            In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                            – Dan Roche
                                                                            Jun 30 '16 at 22:54











                                                                          • Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                            – Octavio Perez Gallegos
                                                                            Jul 26 '16 at 17:45



















                                                                          • It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                            – Octavio Perez Gallegos
                                                                            Jun 30 '16 at 22:45








                                                                          • 1





                                                                            In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                            – Dan Roche
                                                                            Jun 30 '16 at 22:54











                                                                          • Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                            – Octavio Perez Gallegos
                                                                            Jul 26 '16 at 17:45

















                                                                          It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                          – Octavio Perez Gallegos
                                                                          Jun 30 '16 at 22:45







                                                                          It is a small and universal solution based on an array of data can be a JSON transformed json_decode ...lucky

                                                                          – Octavio Perez Gallegos
                                                                          Jun 30 '16 at 22:45






                                                                          1




                                                                          1





                                                                          In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                          – Dan Roche
                                                                          Jun 30 '16 at 22:54





                                                                          In what way does this answer the original question? Your answer seems more complicated than the original question, and also doesn't seem to even mention JSON anywhere.

                                                                          – Dan Roche
                                                                          Jun 30 '16 at 22:54













                                                                          Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                          – Octavio Perez Gallegos
                                                                          Jul 26 '16 at 17:45





                                                                          Sorry, I uploaded the implementation is to respond to the conversion of XML to any understandable to process a simple PHP json_encode arrangement. Sorry for the lack of clarity

                                                                          – Octavio Perez Gallegos
                                                                          Jul 26 '16 at 17:45











                                                                          -1














                                                                          $xml = simplexml_load_string($xml_string);
                                                                          $json = json_encode($xml);
                                                                          $array = json_decode($json,TRUE);


                                                                          just add those three lines you will get the correct output:-)






                                                                          share|improve this answer




























                                                                            -1














                                                                            $xml = simplexml_load_string($xml_string);
                                                                            $json = json_encode($xml);
                                                                            $array = json_decode($json,TRUE);


                                                                            just add those three lines you will get the correct output:-)






                                                                            share|improve this answer


























                                                                              -1












                                                                              -1








                                                                              -1







                                                                              $xml = simplexml_load_string($xml_string);
                                                                              $json = json_encode($xml);
                                                                              $array = json_decode($json,TRUE);


                                                                              just add those three lines you will get the correct output:-)






                                                                              share|improve this answer













                                                                              $xml = simplexml_load_string($xml_string);
                                                                              $json = json_encode($xml);
                                                                              $array = json_decode($json,TRUE);


                                                                              just add those three lines you will get the correct output:-)







                                                                              share|improve this answer












                                                                              share|improve this answer



                                                                              share|improve this answer










                                                                              answered Apr 26 '18 at 5:46









                                                                              karthikkarthik

                                                                              1308




                                                                              1308






























                                                                                  draft saved

                                                                                  draft discarded




















































                                                                                  Thanks for contributing an answer to Stack Overflow!


                                                                                  • Please be sure to answer the question. Provide details and share your research!

                                                                                  But avoid



                                                                                  • Asking for help, clarification, or responding to other answers.

                                                                                  • Making statements based on opinion; back them up with references or personal experience.


                                                                                  To learn more, see our tips on writing great answers.




                                                                                  draft saved


                                                                                  draft discarded














                                                                                  StackExchange.ready(
                                                                                  function () {
                                                                                  StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f8830599%2fphp-convert-xml-to-json%23new-answer', 'question_page');
                                                                                  }
                                                                                  );

                                                                                  Post as a guest















                                                                                  Required, but never shown





















































                                                                                  Required, but never shown














                                                                                  Required, but never shown












                                                                                  Required, but never shown







                                                                                  Required, but never shown

































                                                                                  Required, but never shown














                                                                                  Required, but never shown












                                                                                  Required, but never shown







                                                                                  Required, but never shown







                                                                                  Popular posts from this blog

                                                                                  mysqli_query(): Empty query in /home/lucindabrummitt/public_html/blog/wp-includes/wp-db.php on line 1924

                                                                                  How to change which sound is reproduced for terminal bell?

                                                                                  Can I use Tabulator js library in my java Spring + Thymeleaf project?