PHP Conference Japan 2024

libxml_set_external_entity_loader

(PHP 5 >= 5.4.0, PHP 7, PHP 8)

libxml_set_external_entity_loader更改默认的外部实体加载器

描述

libxml_set_external_entity_loader(?callable $resolver_function): bool

更改默认的外部实体加载器。这可以用来阻止任意外部实体的扩展,从而避免 XXE 攻击,即使为相应操作设置了LIBXML_NOENT,通常也比调用libxml_disable_entity_loader()更好。

参数

resolver_function

一个具有以下签名的callable

resolver(?string $public_id, string $system_id, array $context): resource|string|null
public_id
公共 ID。
system_id
系统 ID。
context
一个包含四个元素的数组:"directory""intSubName""extSubURI""extSubSystem"
此回调函数应返回一个资源,一个可以从中打开资源的字符串。如果返回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)

参见

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top