Skip to content

Commit

Permalink
[DomCrawler] Dont use LIBXML_PARSEHUGE by default
Browse files Browse the repository at this point in the history
  • Loading branch information
nicolas-grekas committed Mar 2, 2016
1 parent 2e9e83e commit fda32f8
Showing 1 changed file with 5 additions and 2 deletions.
7 changes: 5 additions & 2 deletions src/Symfony/Component/DomCrawler/Crawler.php
Expand Up @@ -219,8 +219,11 @@ function ($m) {
*
* @param string $content The XML content
* @param string $charset The charset
* @param int $options Bitwise OR of the libxml option constants
* LIBXML_PARSEHUGE is dangerous, see
* http://symfony.com/blog/security-release-symfony-2-0-17-released
*/
public function addXmlContent($content, $charset = 'UTF-8')
public function addXmlContent($content, $charset = 'UTF-8', $options = LIBXML_NONET)
{
$internalErrors = libxml_use_internal_errors(true);
$disableEntities = libxml_disable_entity_loader(true);
Expand All @@ -230,7 +233,7 @@ public function addXmlContent($content, $charset = 'UTF-8')

if ('' !== trim($content)) {
// remove the default namespace to make XPath expressions simpler
@$dom->loadXML(str_replace('xmlns', 'ns', $content), LIBXML_NONET | (defined('LIBXML_PARSEHUGE') ? LIBXML_PARSEHUGE : 0));
@$dom->loadXML(str_replace('xmlns', 'ns', $content), $options);
}

libxml_use_internal_errors($internalErrors);
Expand Down

0 comments on commit fda32f8

Please sign in to comment.