Edit report at http://bugs.php.net/bug.php?id=54632&edit=1
ID: 54632
Comment by: enrico at zimuel dot it
Reported by: enrico at zimuel dot it
Summary: json_encode() doesn't convert SimpleXML data
properly
Status: Open
Type: Bug
Package: JSON related
Operating System: Ubuntu Linux 10.04
PHP Version: 5.3.6
Block user comment: N
Private report: N
New Comment:
I agree that the var_dump output of the SimpleXMLElement doesn't
contains the text value of the <a> element. But, as you said, you can
get it from $bar = (string) $simpleXML, that means the data is inside
the SimpleXMLElement even if the values is not explicit.
The problem here is related to the fact that there is not a standard way
to convert an XML into JSON. IBM proposed the JSONx format. To continue
to follow the syntax used by SimpleXMLElement we can add a special
element (like '@attributes') to manage the text value.
For instance the xml document: <a><b id="foo"/>bar</a> can be translated
in {"a":{"b":{"@attributes":{"id":"foo"}},"@text":"bar"}}.
So, the problem is in SimpleXMLElement? I don't know, for sure the
result of json_encode() is not correct.
Previous Comments:
------------------------------------------------------------------------
[2011-04-29 16:20:29] felipecg00 at gmail dot com
Looks like the problem is not the json_encode.
var_dump( $simpleXML );
object(SimpleXMLElement)#1 (1) {
["b"]=>
object(SimpleXMLElement)#2 (1) {
["@attributes"]=>
array(1) {
["id"]=>
string(3) "foo"
}
}
}
Where is bar? This is the behavior of SimpleXML. You can try using
DOMDocument:
$dd = new DOMDocument();
$dd->loadXML('<?xml version="1.0" encoding="UTF-8" ?><a><b
id="foo"/>bar</a>');
echo $dd->documentElement->textContent; // outputs bar
Still, you can force the SimpleXMLElement to be a string, so it will
contain the text inside the node:
$bar = (string) $simpleXML;
echo $bar; // outputs 'bar'
And yet, there is dom_import_simplexml(), which converts a SimpleXML
node into a DOMDocument node. But that i've never used before.
I think the right thing to do is to keep the text inside text-only
nodes.
------------------------------------------------------------------------
[2011-04-29 13:42:27] enrico at zimuel dot it
Description:
------------
I tried to encode the following XML document in JSON using json_encode()
and the result doesn't reflect the XML structure.
XML document:
<?xml version="1.0" encoding="UTF-8" ?>
<a><b id="foo"/>bar</a>
Result of json_encode():
{"b":{"@attributes":{"id":"foo"}}}
The JSON results lost the "bar" value of the XML document.
This is the source code that is used:
<?php
$xml='<?xml version="1.0" encoding="UTF-8" ?><a><b id="foo"/>bar</a>';
$simpleXML= simplexml_load_string($xml);
echo json_encode($simpleXML);
Test script:
---------------
$xml='<?xml version="1.0" encoding="UTF-8" ?><a><b id="foo"/>bar</a>';
$simpleXML= simplexml_load_string($xml);
echo json_encode($simpleXML);
Expected result:
----------------
It's not obviuos the correct JSON rappresentation of the above XML
document.
In my opinion it can be as follow:
{"a":[{"b":{"@attributes":{"id":"foo"}}},"bar"]}
Where the value "bar" is included in a JSON array using the syntax [...]
Actual result:
--------------
{"b":{"@attributes":{"id":"foo"}}}
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/bug.php?id=54632&edit=1