通过日志记录功能,你可以将信息直接发送到其他日志服务器,或者发送到指定的电子邮箱(或者通过邮件网关发送),或者发送到操作系统日志等,从而可以有选择的记录和监视你的应用程序和网站的最重要的部分。
错误报告功能允许你自定义错误反馈的级别和类型,可以是简单的提示信息或者使用自定义的函数进行处理并返回信息.
为什么要使用错误处理?
1.是网站出错时对用户友好
2.更好的避免错误、调试、修复错误
3.避免一些安全风险
4.更好保证程序的健壮性
5.……
一、最简单的错误处理――die()
当我们预计有错误发生时,停止脚步的运行。比如连接数据库时:
1.定义错误处理函数的参数:
参数 | 描述 |
---|---|
error_level | 必需。为用户定义的错误规定错误报告级别。必须是一个值数。
参见下面的表格:错误报告级别。 |
error_message | 必需。为用户定义的错误规定错误消息。 |
error_file | 可选。规定错误在其中发生的文件名。 |
error_line | 可选。规定错误发生的行号。 |
error_context | 可选。规定一个数组,包含了当错误发生时在用的每个变量以及它们的值。 |
価値 | 定数 | 手順 | 備考 |
---|---|---|---|
1 | E_ERROR (整数) | 致命的なランタイムエラー。このタイプのエラーは、メモリ割り当てによって引き起こされる問題など、通常は回復不可能な状況です。その結果、スクリプトが終了し、実行が続行されなくなります。 | |
2 | E_WARNING (整数) | 実行時警告 (致命的ではないエラー)。プロンプト メッセージのみが表示されますが、スクリプトは終了しません。 | |
4 | E_PARSE (整数) | コンパイル時の構文解析エラー。解析エラーはパーサーによってのみ生成されます。 | |
8 | E_NOTICE (整数) | 実行時通知。スクリプトでエラーとして表示される可能性のある状況が発生したことを示しますが、正常に実行できるスクリプトにも同様の通知が表示される可能性があります。 | |
16 | E_CORE_ERROR (整数) | PHPの初期化起動中に致命的なエラーが発生しました。このエラーは E_ERROR に似ていますが、PHP エンジン コアによって生成されます。 | PHP 4以降 |
32 | E_CORE_WARNING(整数) | PHP の初期化起動中に警告 (致命的ではないエラー) が発生しました。 E_WARNING に似ていますが、PHP エンジン コアによって生成されます。 | PHP 4以降 |
64 | E_COMPILE_ERROR(整数) | 致命的なコンパイル時エラー。 E_ERROR に似ていますが、Zend スクリプト エンジンによって生成されます。 | PHP 4以降 |
128 | E_COMPILE_WARNING(整数) | コンパイル時間の警告 (致命的ではないエラー)。 E_WARNING に似ていますが、Zend スクリプト エンジンによって生成されます。 | PHP 4以降 |
256 | E_USER_ERROR (整数) | ユーザーが生成したエラーメッセージ。 E_ERROR に似ていますが、コード内で PHP 関数trigger_error() を使用するユーザーによって生成されます。 | PHP 4以降 |
512 | E_USER_WARNING(整数) | ユーザーが生成した警告メッセージ。 E_WARNINGと似ていますが、コード内でPHP関数trigger_error()を使用するユーザーによって生成されます。 | PHP 4以降 |
1024 | E_USER_NOTICE(整数) | ユーザーによって生成された通知メッセージ。 E_NOTICEと似ていますが、コード内でPHP関数trigger_error()を使用してユーザーによって生成されます。 | PHP 4以降 |
2048 | E_STRICT (整数) | コードの最高の相互運用性と上位互換性を確保するために、PHP のコード変更の提案を有効にします。 | since PHP 5 |
4096 | E_RECOVERABLE_ERROR(integer) | 可被捕捉的致命错误。 它表示发生了一个可能非常危险的错误,但是还没有导致PHP引擎处于不稳定的状态。 如果该错误没有被用户自定义句柄捕获 (参见 set_error_handler()),将成为一个 E_ERROR 从而脚本会终止运行。 | since PHP 5.2.0 |
8192 | E_DEPRECATED (integer) | 运行时通知。启用后将会对在未来版本中可能无法正常工作的代码给出警告。 | since PHP 5.3.0 |
16384 | E_USER_DEPRECATED(integer) | 用户产少的警告信息。 类似E_DEPRECATED, 但是是由用户自己在代码中使用PHP函数 trigger_error()来产生的。 | since PHP 5.3.0 |
30719 | E_ALL (integer) | E_STRICT出外的所有错误和警告信息。 | 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously |
(レベル E_ERROR および E_USER_ERROR はカスタム エラー処理関数では捕捉できません) 致命的なランタイム エラーが発生するとスクリプトはただちに実行を停止するため、致命的なエラー メッセージはカスタム エラー関数では捕捉できません。
3. エラーのトリガー
ユーザーがデータを入力するスクリプトで、ユーザーの入力が無効な場合にエラーをトリガーすると便利です。 PHP では、このタスクはtrigger_error() によって実行されます。
スクリプト内のどこでもエラーをトリガーできます。2 番目のパラメーターを追加すると、トリガーされるエラー レベルを指定できます。
4. 考えられるエラーの種類:
1).E_USER_ERROR - ユーザーが生成した致命的な実行時エラー。エラーは回復できません。スクリプトの実行が中断されました。
2) .E_USER_WARNING - 致命的ではないユーザー生成の実行時警告。スクリプトの実行は中断されません。
3).E_USER_NOTICE - デフォルト。ユーザーが生成した実行時通知。スクリプトは、スクリプトが正常に実行されているときに発生した可能性のあるエラーを検出しました。
例:
3. エラー報告
デフォルトでは、php.ini の error_log 設定に従って、PHP はエラー記録をサーバーのエラー記録システムまたはファイルに送信します。
error_log() 関数を使用すると、指定したファイルまたはリモートの宛先にエラー レコードを送信できます。たとえば、エラー メッセージを電子メールに送信することは良い方法です。
エラー処理に関するドキュメントの詳細については、http://www.php.net/manual/zh/book.errorfunc.php を参照してください。
4. 例外処理 例外がスローされると、後続のコードは実行を続行せず、PHP は一致する「キャッチ」コード ブロックを見つけようとします。
例外がキャッチされず、対応する処理に set_Exception_handler() を使用する必要がない場合は、重大なエラー (致命的なエラー) が発生し、「Uncaught Exception」(キャッチされない例外) のエラー メッセージが出力されます。
1. 処理手順には次のものが含まれます。
1.) try - 例外を使用する関数は、「try」ブロック内に置く必要があります。例外がトリガーされない場合、コードは通常どおり実行を続行します。ただし、例外がトリガーされると、例外がスローされます。
3.) catch - 「キャッチ」コード ブロックは例外をキャッチし、例外情報を含むオブジェクトを作成します
2。例外を再スローします
2。
例外がスローされたときに、標準の方法とは異なる方法で例外を処理したい場合があります。例外は「catch」ブロックで再度スローできます。
3. 異常なルール
1). 例外処理を必要とするコードは、潜在的な例外をキャッチするために try コード ブロック内に配置する必要があります。
2). 各 try または throw コード ブロックには、対応する catch コード ブロックが少なくとも 1 つ必要です。3). 複数の catch コード ブロックを使用して、さまざまな種類の例外をキャッチします。
4).try コード ブロック内の catch コード ブロックで例外を再スローできます。
つまり、例外がスローされた場合は、それをキャッチする必要があります。
http://www.bkjia.com/PHPjc/736790.html