Php/docs/function.libxml-set-external-entity-loader

提供:Dev Guides
< Php
移動先:案内検索

libxml_set_external_entity_loader

(PHP 5 >= 5.4.0, PHP 7)

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


説明

libxml_set_external_entity_loader ( callable|null $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%22><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)

参考