xml_set_unparsed_entity_decl_handler

(PHP 4, PHP 5, PHP 7, PHP 8)

xml_set_unparsed_entity_decl_handler 建立未解析实体定义声明处理程序

说明

xml_set_unparsed_entity_decl_handler(XMLParser $parser, callable $handler): bool

parser XML 解析器设置未解析实体声明处理函数。

当 XML 解析器遇到如下含有 NDATA 声明的外部实体定义声明时,该 handler 处理程序将被调用:

<!ENTITY <parameter>name</parameter> {<parameter>publicId</parameter> | <parameter>systemId</parameter>}
        NDATA <parameter>notationName</parameter>

请参阅 » XML 1.0 参考的第 4.2.2 节以获取有关已声明外部实体注释定义的信息。

参数

parser

XML 解析器的引用,用于建立未解析实体定义声明处理函数。

handler

参数handler 为表示函数名称的字符串,这个函数必须在为 parser 指定的解析器调用 xml_parse() 函数时已存在。

handler 参数命名的函数名必须接受六个参数:

handler(
    XMLParser $parser,
    string $entity_name,
    string $base,
    string $system_id,
    string $public_id,
    string $notation_name
)
parser
第一个参数 parser 为指向要调用处理程序的 XML 解析器的指针。
entity_name
将被定义的实体名。
base
这个参数是解析外部实体的系统标识符(system_id)的基础。当前该参数通常都被设置为空字符串。
system_id
外部实体的系统标识符。
public_id
外部实体的公共标识符。
notation_name
该实体的注释名(请参阅 xml_set_notation_decl_handler())。

如果处理函数名被设置为空字符串或者 false,则该有问题的处理程序将被屏蔽。

注意: 除了函数名,含有对象引用的数组和方法名也可以作为参数。

返回值

成功时返回 true, 或者在失败时返回 false

更新日志

版本 说明
8.0.0 parser 现在接受 XMLParser 实例;之前接受有效的 xml resource
add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top