XMLデータをPHPで解析する場合、 XML_PARSE関数は一般的なツールです。 XML_PARSER_CREATEによって作成されたXMLパーサーに関連付けられたデータのブロックを解析するために使用されます。ただし、多くの開発者は、 XML_PARSE関数を使用するときに戻り値のチェックを無視します。これにより、ペルシングが失敗したときにプログラムが異常に実行されることが多く、隠されたバグを見つけるのが難しくなります。
XML_PARSEの関数署名は次のとおりです。
bool xml_parse(XMLParser $parser, string $data, bool $is_final = false)
解析が成功したかどうかを示すブール値を返します。
trueを返す(つまり1 ):データの解析が成功していることを示します。
false (すなわち0 )を返す:解析が失敗したことを示します。
したがって、このリターン値を無視すると、潜在的なエラーが発生したときに目をつぶると同等です。
簡単な例を見てみましょう:
$xml = '<note><to>Tove</to><from>Jani</from><heading>Reminder</heading><body>Don\'t forget me this weekend!</body></note>';
$parser = xml_parser_create();
xml_parse($parser, $xml, true);
xml_parser_free($parser);
上記のコードは問題ないようですが、 $ XML変数のデータ形式が間違っている場合、閉じたタグの欠落など、 XML_PARSEはFALSEを返します。ただし、コードは引き続き実行され、予期しない動作が発生し、後続のロジックのデータ処理に影響する場合があります。
以下に示すように、解析が失敗した場合、 XML_PARSEの返品値と関連するエラーメッセージの出力を常にキャプチャする必要があります。
$xml = '<note><to>Tove</to><from>Jani<from><heading>Reminder</heading><body>Don\'t forget me!</body></note>'; // ない </from>
$parser = xml_parser_create();
if (!xml_parse($parser, $xml, true)) {
$error_code = xml_get_error_code($parser);
$error_msg = xml_error_string($error_code);
$line = xml_get_current_line_number($parser);
echo "XML 解析エラー:$error_msg (エラーコード:$error_code) で $line わかりました。ソースデータを確認してください。" . PHP_EOL;
echo "関連するドキュメントへの参照:https://m66.net/php-manual/xml" . PHP_EOL;
}
xml_parser_free($parser);
これの利点は、XMLデータ形式のエラーが発生すると、プログラムが開発者に何がうまくいかなかったかをすぐに通知できることです。
XML_PARSE関数を使用するときに返品値をチェックしないことは、運転中に道路標識を見ないようなものです。正しい軌道から逸脱したかどうかはわかりません。プログラムの堅牢性と保守性を向上させるには、 XML_PARSEを使用した後、必ずその返品値を確認し、可能なエラーを処理してください。単純な判断声明は、トラブルシューティングの問題に多くの時間を節約する可能性があります。