If you have trouble parsing xml documents with text tags bigger than 10MB, this might help you:
<?php
$xmlreader = new XMLReader();
$xmlreader->open($uri, null, 1<<19);
?>
Since in libxml there is a constant
XML_PARSE_HUGE = 1<<19
which enables parsing xml documents with huge texts.
Please note that this option is not accessible using the setParserProperty method and that there is currently no constant to do the work, which will hopefully change soon:
http://bugs.php.net/bug.php?id=49660
XMLReader::read
(PHP 5 >= 5.1.2)
XMLReader::read — Move to next node in document
Description
bool XMLReader::read
( void
)
Moves cursor to the next node in the document.
Return Values
Returns TRUE on success or FALSE on failure.
See Also
- XMLReader::moveToElement - Position cursor on the parent Element of current Attribute
- XMLReader::moveToAttribute - Move cursor to a named attribute
- XMLReader::next - Move cursor to next node skipping all subtrees
XMLReader::read
Yannik
10-Nov-2009 09:38
10-Nov-2009 09:38
jirka at kosek dot cz
08-Feb-2006 07:01
08-Feb-2006 07:01
libxml2 contains much more useful method readString() that will read and return whole text content of element. You can call it after receiving start tag (XMLReader::ELEMENT). You can use this PHP code to emulate this method until PHP will directly call underlying libxml2 implementation.
<?php
class XMLReader2 extends XMLReader
{
function readString()
{
$depth = 1;
$text = "";
while ($this->read() && $depth != 0)
{
if (in_array($this->nodeType, array(XMLReader::TEXT, XMLReader::CDATA, XMLReader::WHITESPACE, XMLReader::SIGNIFICANT_WHITESPACE)))
$text .= $this->value;
if ($this->nodeType == XMLReader::ELEMENT) $depth++;
if ($this->nodeType == XMLReader::END_ELEMENT) $depth--;
}
return $text;
}
}
?>
Just use XMLReader2 instead of XMLReader.
