PHP libxml_set_external_entity_loader() Function

❮ PHP libxml Reference

Example

Change the default external entity loader:

<?php
$xml = <<<XML
<!DOCTYPE foo PUBLIC "-//FOO/BAR" "http://example.com/foobar">
<foo>bar</foo>
XML;

$dtd = <<<DTD
<!ELEMENT foo (#PCDATA)>
DTD;

libxml_set_external_entity_loader(
  function ($public, $system, $context) use($dtd) {
    var_dump($public);
    var_dump($system);
    var_dump($context);
    $f = fopen("php://temp", "r+");
    fwrite($f, $dtd);
    rewind($f);
    return $f;
  }
);

$dd = new DOMDocument;
$r = $dd->loadXML($xml);

var_dump($dd->validate());
?>

Definition and Usage

The libxml_set_external_entity_loader() function changes the default external entity loader.

Syntax

libxml_set_external_entity_loader(function)

Parameter Values

Parameter Description
function Required. A function that takes three arguments. Two strings, a public id and system id, and a context (an array with four keys) as the third argument. This callback should return a resource, a string from which a resource can be opened, or NULL.


Technical Details

Return Value: Returns TRUE on success, FALSE on failure
PHP Version: 5.4+

❮ PHP libxml Reference
Copyright 1999-2023 by Refsnes Data. All Rights Reserved.