PHP XML解析器函数

PHP xml_set_notation_decl_handler() 函数为给定的 XML 解析器设置符号声明处理函数。

符号声明是文档 DTD 的一部分,具有以下格式:

<!NOTATION <parameter>name</parameter>
{ <parameter>systemId</parameter> | <parameter>publicId</parameter>?> 

语法

xml_set_notation_decl_handler(parser, handler) 

参数

parser必需。 指定对 XML 解析器的引用以设置符号声明处理函数。
handler必需。 指定一个字符串,其中包含要用作事件处理程序的函数名称。该函数必须接受五个参数:
handler(parser, notation_name, base, system_id, public_id) 
  • parser:第一个参数 parser 是对调用处理程序的 XML 解析器的引用。
  • notation_name:包含符号名称的变量。
  • base:用于解析符号声明的系统标识符(system_id)的基数。目前此参数将始终设置为空字符串。
  • system_id:外部表示法声明的系统标识符。
  • public_id:外部符号声明的公共标识符。
如果处理程序函数设置为空字符串或 false,则相关处理程序将被禁用。注意:除了函数名之外,还可以使用包含对象引用和方法名的数组。

返回值

成功时返回 true,失败时返回 false。

示例:xml_set_notation_decl_handler() 示例

假设我们有一个名为 test.xml 的文件。在下面的示例中,使用 xml_parser_create() 函数创建 XML 解析器。然后打开 XML 文件,使用字符处理函数 char_print 解析其数据。然后,not_decl_handler 函数被设置为给定 XML 解析器的符号声明处理函数。解析文档后,使用xml_parser_free()函数释放解析器。

<?php
//创建XML解析器
$parser=xml_parser_create();

//XML解析器的字符处理函数
function char_print($parser, $data) {
  echo $data;
}

//XML解析器的符号声明处理函数
function not_decl_handler($parser, $not, $base, $sysID, $pubID) {
  echo "$not $sysID $pubID \n";
}

//设置XML解析器的字符处理函数
xml_set_character_data_handler($parser,"char_print");

//为XML解析器设置符号声明处理函数
xml_set_notation_decl_handler($parser,"not_decl_handler");

//打开xml文件
$fp = fopen("test.xml", "r");

while($data = fread($fp,4096)) {
  //解析XML数据
  xml_parse($parser,$data,feof($fp)) or

    //解析错误时显示错误
    die (sprintf("XML Error: %s at line %d",

    //错误字符串
    xml_error_string(xml_get_error_code($parser)),

    //当前行
    xml_get_current_line_number($parser)));
}

//免费的XML解析器
xml_parser_free($parser);

fclose($fp);
?>