xml_set_external_entity_ref_handler() 関数は、パーサがXML文書内の外部エンティティを検出したときに呼び出す関数を指定します。
この関数は、成功した場合はTRUEを、失敗した場合はFALSEを返します。
xml_set_external_entity_ref_handler(parser,handler)
パラメータ | 説明 |
---|---|
parser | 必須。使用するXMLパーサを指定する |
handler | 必須。パーサが外部エンティティを検出したときに呼び出す関数を指定する |
"handler" パラメータで指定した関数には、5 つのパラメータが必要です:
パラメータ | 説明 |
---|---|
parser | 必須。ハンドラを呼び出すXMLパーサを含む変数を指定する |
name | 必須。外部エンティティの名前を含む変数を指定する |
base | 必須。外部エンティティのシステム識別子(system_id)を解決するためのベースを指定する。現在、これは常にNULLになる |
system_id | 必須。外部エンティティのシステム識別子を指定する |
public_id | 必須。外部エンティティの公開識別子を指定する |
注: handler パラメータは、オブジェクトへのリファレンスとメソッド名を含む配列を指定することもできます。
<?php
$parser=xml_parser_create();
function char($parser,$data)
{
echo $data;
}
function ext_ent_handler($parser,$ent,$base,$sysID,$pubID)
{
echo "$ent<br />";
echo "$sysID<br />";
echo "$pubID<BR />";
}
xml_set_character_data_handler($parser,"char");
xml_set_external_entity_ref_handler($parser, "ext_ent_handler");
$fp=fopen("test.xml","r");
while ($data=fread($fp,4096))
{
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_parser_free($parser);
?>