この記事は主に PHP のエラー処理メカニズムに関する情報を紹介するもので、必要な方は参考にしてください。これを比較的適切に処理しないと、プログラムは非常に専門的でないように見え、他の人がシステムを攻撃するための有効な情報になる可能性が高く、いくつかのエラー例外によってスクリプトの実行が終了します。この時点でエラー メッセージが表示されない場合は、では、プロジェクト内に数百行または数千行のコードがあることがどれほど恐ろしいことであるかを理解する必要があります。では、プロジェクト開発プロセス中に異常を迅速かつ正確に特定するにはどうすればよいでしょうか。この記事は、エラーと
例外処理についての私自身の理解に基づいており、皆さんと共有し、お互いの学びとコミュニケーションを目的としてメモとして提供します。
システムエラープロセッサ:PHP 通常の状況では、エラーは正常に出力されますが、一部のフレームワークでは、フレームワーク自体が独自の処理機構を持っているか、エラー出力に影響を与える可能性があります。コード内の操作が処理されます。通常は次の関数設定:
1.
error_reporting(); PHP のエラー報告レベルを設定し、現在のレベルを返します error_reporting(report_level)
パラメーター レベルが指定されていない場合は、現在のエラー報告レベルが返されます。次の項目は、レベルの可能な値です:
定数 | 説明 | |
E_ERROR | 致命的なランタイム エラー。このエラーは再利用できません。スクリプトの実行が中断されました。 | |
2 |
E_WARNING |
致命的ではないランタイム警告。スクリプトの実行は中断されません。 |
4 |
E_PARSE |
コンパイル時間分析エラー。解析では、実行時にアナライザーによって生成されたエラー |
8 |
E_NOTICE |
についてのみ通知する必要があります。見つかったスクリプトはバグである可能性がありますが、通常はスクリプトの実行時に発生する可能性があります |
16 |
E_CORE_ERROR |
PHP起動時の致命的なエラー。これは、PHPの時間警告E_ERROR |
32 |
E_CORE_WARNING |
のようなものです。これは、PHPのコアのE_WARNING | 64
E_COMPILE_ERROR のようなものです |
致命的なコンパイル時エラー。これは、Zendスクリプト エンジンによって生成されるE_ERROR |
|
128 |
E_COMPILE_WARNING |
非致命的コンパイル時警告を渡すのと同じです。これは、プログラマが PHP を使用する方法と同様に、Zend スクリプト エンジンに E_WARNING |
256 |
E_USER_ERROR |
を生成させるようなものです。 関数 trigger_error() set E_エラー |
512 |
E_USER_WARNING |
プログラマーがPHPの関数を使用して設定するものと同様の、致命的ではないユーザー生成の警告trigger_errorE_WARNING |
E_USER_NOTICE | ユーザー生成の通知。これは、プログラマが PHP | 関数を使用して設定するものと似ています実行時通知。 PHPこのコードの相互運用性と互換性を高めるために、コードへの変更をお勧めします |
4096 |
E_RECOVERABLE_ERROR |
E_ERRORのようなキャッチ可能な致命的なエラー、ただしユーザーによって捕捉される可能性があります-定義されたハンドラー (set_error_handler()を参照) |
8191 |
E_ALL |
レベルE_STRを除くすべてのエラーと警告ICT (PHP6.0では、E_STRICT はE_ALL)の一部になります |
ここで、$level が 0 の場合、エラー出力がオフになる、つまりエラーが出力されないことに注意してください。
2.set_error_handler()
定義と使用法
set_error_handler() 関数は、ユーザー定義のエラー処理関数を設定します。
この関数は、実行時にユーザー独自のエラー処理メソッドを作成するために使用されます。
この関数は古いエラー ハンドラーを返すか、失敗した場合は null を返します。
構文
set_error_handler(error_function,error_types)
パラメータ |
説明 |
error_function |
必須。エラーが発生したときに実行する関数を指定します。 |
error_types |
オプション。ユーザー定義エラーがどのエラー報告レベルで表示されるかを指定します。デフォルトは「E_ALL」です。 |
ヒント: この関数を使用すると、標準の PHP エラー処理関数は完全にバイパスされます。必要に応じて、ユーザー定義のエラー ハンドラーはスクリプトを終了 (die()) する必要があります。
注: スクリプトの前にエラーが発生した場合。この時点ではカスタムプログラムが登録されていないため、カスタムエラーハンドラは使用されません。
テストコードは次のとおりです:
/** * * @param type $error_level 错误级别 * @param type $error_message 错误信息 * @param type $error_file 可选 错误文件 * @param type $error_line 可选 错误行 * @param type $error_context 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。 */ function my_error($error_level, $error_message, $error_file, $error_line, $error_context) { echo date('Y-m-d H:i:s') . $error_level . $error_message . $error_file . $error_line; var_dump($error_context); } set_error_handler('my_error', E_ALL); print_r($a);
//上記の例から、my_error メソッドを登録すると、システムは元のエラー処理 error_fuction() メソッドを自動的に上書きすることがわかります。
上記のプログラムの実行結果:
エラートリガーの定義
定義と使用法
trigger_error() 関数は、ユーザー定義のエラーメッセージを作成します。
trigger_error() は、ユーザーが指定した条件下でエラー メッセージをトリガーするために使用されます。これは、組み込みのエラー ハンドラーで使用されますが、set_error_handler() 関数で作成されたユーザー定義関数でも使用できます。 不正なエラータイプが指定された場合、この関数は false を返し、それ以外の場合は true を返します。
構文
trigger_error(error_message,error_types)
説明 | |
必須d.エラーメッセージを指定します。長さ制限は | 1024 文字です。 |
可选。规定错误消息的错误类型。 可能的值:
|
测试代码如下:
/** * * @param type $level * @param type $msg */ function my_error($level, $msg) { switch ($level) { case E_USER_ERROR: echo "ERROR:<br/>"; break; case E_USER_WARNING: echo "WARNING:<br/>"; break; case E_USER_NOTICE: echo "NOTICE:<br/>"; break; default: break; } echo "错误编号:" . $level . " <br/>"; echo "错误信息:" . $msg; } //注册错误处理器 set_error_handler('my_error'); if (89 > 8) { //调用错误触发器 trigger_error('这是错误啊', E_USER_WARNING); }
运行结果如下:
WARNING:
错误编号:512
错误信息:这是错误啊
以上がPHPエラー処理メカニズムの例の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。