libxml_disable_entity_loader.phpt 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. --TEST--
  2. libxml_disable_entity_loader()
  3. --SKIPIF--
  4. <?php if (!extension_loaded('libxml') || !extension_loaded('dom') || defined('PHP_WINDOWS_VERSION_MAJOR')) die('skip'); ?>
  5. --FILE--
  6. <?php
  7. $xml = <<<EOT
  8. <?xml version="1.0" encoding="UTF-8"?>
  9. <!DOCTYPE test [<!ENTITY xxe SYSTEM "XXE_URI">]>
  10. <foo>&xxe;</foo>
  11. EOT;
  12. $xml = str_replace('XXE_URI', __DIR__ . '/libxml_disable_entity_loader_payload.txt', $xml);
  13. function parseXML($xml) {
  14. $doc = new DOMDocument();
  15. $doc->resolveExternals = true;
  16. $doc->substituteEntities = true;
  17. $doc->validateOnParse = false;
  18. $doc->loadXML($xml, 0);
  19. return $doc->saveXML();
  20. }
  21. var_dump(strpos(parseXML($xml), 'SECRET_DATA') !== false);
  22. var_dump(libxml_disable_entity_loader(true));
  23. var_dump(strpos(parseXML($xml), 'SECRET_DATA') === false);
  24. echo "Done\n";
  25. ?>
  26. --EXPECTF--
  27. bool(true)
  28. bool(false)
  29. Warning: DOMDocument::loadXML(): I/O warning : failed to load external entity "%s" in %s on line %d
  30. Warning: DOMDocument::loadXML(): Failure to process entity xxe in Entity, line: %d in %s on line %d
  31. Warning: DOMDocument::loadXML(): Entity 'xxe' not defined in Entity, line: %d in %s on line %d
  32. bool(true)
  33. Done