<完全なPHPのXMLリファレンス
定義と使用法
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 | 必須。 外部エンティティの公開識別子を指定します。 |
ヒントと注意事項
Note:ハンドラ・パラメータは、オブジェクト参照とメソッド名を含む配列であることができます。
例
<?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);
?>
<完全なPHPのXMLリファレンス