libxml_set_external_entity_loader

(PHP 5 >= 5.4.0, PHP 7)

libxml_set_external_entity_loaderデフォルトの外部エンティティローダーを変更する

説明

libxml_set_external_entity_loader ( callable $resolver_function ) : bool

デフォルトの外部エンティティローダーを変更します。

パラメータ

resolver_function

三つの引数をとる callable。はじめの二つは文字列でそれぞれ パブリック ID とシステム ID で、残りの一つはコンテキスト (四つのキーを持つ配列) です。 このコールバックの返す値は、リソースまたはリソースをオープンできる文字列あるいは NULL でなければなりません。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。

例1 libxml_set_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());
?>

上の例の出力は以下となります。

string(10) "-//FOO/BAR"
string(25) "http://example.com/foobar"
array(4) {
    ["directory"]    => NULL
    ["intSubName"]   => NULL
    ["extSubURI"]    => NULL
    ["extSubSystem"] => NULL
}
bool(true)

参考