ホームページ >バックエンド開発 >PHPチュートリアル >PHPエラー処理方法例
システムエラーハンドラー:
PHPでは通常の状況ではエラーが出力されますが、一部のフレームワークでは、フレームワーク自体が独自の処理機構を持っているか、フレームワークで処理されている可能性があります。通常、これらの関数設定は次のとおりです:
1.error_reporting(); PHP のエラー報告レベルを設定し、現在のレベルを返します
error_reporting(report_level)
パラメーター レベルが指定されていない場合は、現在のエラー報告レベル返されます。次の項目は、レベルの可能な値です:
値 |
定数 |
説明 |
||
1 |
E_ERROR |
致命的なランタイム エラー。このエラーは再利用できません。スクリプトの実行が中断されました。 |
||
2 |
E_WARNING |
致命的ではないランタイム警告。スクリプトの実行は中断されません。 |
||
4 |
E_PARSE |
コンパイル時間分析エラー。解析では、実行時にアナライザーによって生成されたエラー |
||
8 |
E_NOTICE |
についてのみ通知する必要があります。見つかったスクリプトはバグである可能性がありますが、通常、スクリプトを実行すると、PHP の起動中に |
||
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 |
致命的ではないコンパイル時警告。これは、zendスクリプトエンジンが生成したzendスクリプトエンジンによって生成されたエラーのようなものですe_warning256 |
||
は、php function trigger_error()設定を使用してプログラマーによって設定されたe_error | に似ています | 512 |
||
PHP関数trigger_errorを使用してプログラマーによって設定されるE_WARNINGに似た、致命的ではないユーザー生成の警告 |
1024 |
|||
ユーザーが生成した通知。PHP 関数trigger_errorを使用してプログラマーによって設定されたE_NOTICEに似ています | 2048 |
E_STRICT |
実行時通知。 PHP では、コードの相互運用性と互換性を高めるためにコードを変更することをお勧めします |
|
4096 |
E_RECOVERABLE_ERROR |
E_ERROR と同様にキャッチ可能な致命的なエラーですが、ユーザー定義のプログラム キャプチャで処理できます (set_error_handler を参照) ()) |
||
8191 |
E_ALL |
レベルE_STRICTを除くすべてのエラーと警告(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)
参数 |
描述 |
error_message |
必需。规定错误消息。长度限制为 1024 个字符。 |
error_types |
可选。规定错误消息的错误类型。 可能的值:
|
测试代码如下:
/** * * @param type $level * @param type $msg */ function my_error($level, $msg) { switch ($level) { case E_USER_ERROR: echo "ERROR:<br data-filtered="filtered">"; break; case E_USER_WARNING: echo "WARNING:<br data-filtered="filtered">"; break; case E_USER_NOTICE: echo "NOTICE:<br data-filtered="filtered">"; break; default: break; } echo "错误编号:" . $level . " <br data-filtered="filtered">"; echo "错误信息:" . $msg; } //注册错误处理器 set_error_handler('my_error'); if (89 > 8) { //调用错误触发器 trigger_error('这是错误啊', E_USER_WARNING); } |
运行结果如下:
WARNING:
错误编号:512
错误信息:这是错误啊
相关推荐:
以上がPHPエラー処理方法例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。