私は、phpエラー処理と例外処理についていくつかの調査を行ってきました。
たとえば、ユーザーエラーを処理するにはset_error_handler()
、ユーザーエラーに使用するのが最適です。コード例:
// Destinations
define("ADMIN_EMAIL", "nobody@stanford.edu");
define("LOG_FILE", "/my/home/errors.log");
// Destination types
define("DEST_EMAIL", "1");
define("DEST_LOGFILE", "3");
/**
* my_error_handler($errno, $errstr, $errfile, $errline)
*
* Author(s): thanosb, ddonahue
* Date: May 11, 2008
*
* custom error handler
*
* Parameters:
* $errno: Error level
* $errstr: Error message
* $errfile: File in which the error was raised
* $errline: Line at which the error occurred
*/
function my_error_handler($errno, $errstr, $errfile, $errline)
{
switch ($errno) {
case E_USER_ERROR:
// Send an e-mail to the administrator
error_log("Error: $errstr \n Fatal error on line $errline in file $errfile \n", DEST_EMAIL, ADMIN_EMAIL);
// Write the error to our log file
error_log("Error: $errstr \n Fatal error on line $errline in file $errfile \n", DEST_LOGFILE, LOG_FILE);
break;
case E_USER_WARNING:
// Write the error to our log file
error_log("Warning: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
case E_USER_NOTICE:
// Write the error to our log file
error_log("Notice: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
default:
// Write the error to our log file
error_log("Unknown error [#$errno]: $errstr \n in $errfile on line $errline \n", DEST_LOGFILE, LOG_FILE);
break;
}
// Don't execute PHP's internal error handler
return TRUE;
}
// Use set_error_handler() to tell PHP to use our method
$old_error_handler = set_error_handler("my_error_handler");
次に、致命的なエラーの場合:
register_shutdown_function('handleShutdown');
function handleShutdown() {
$error = error_get_last();
if($error !== NULL){
$info = "[SHUTDOWN] file:".$error['file']." | ln:".$error['line']." | msg:".$error['message'] .PHP_EOL;
yourPrintOrMailFunction($info);
}
else{
yourPrintOrMailFunction("SHUTDOWN");
}
}
私の知る限り、これはスクリプト内で発生する可能性のある基本的にすべてのエラーをカバーしているようです(非常に一般的なステートメントとして-すべてのエラーを予測することは困難です)。クラスを開発するときは、例外を使用して内部で処理することをお勧めします。
私の質問は、これらの例が本番環境でのエラーを処理するのに一般的に適切であると考えられるかどうか、または何かが明らかに間違っているか欠けているかどうかです。
いずれにせよ、これらの関数はすべてのファイルに添付されていますか、それともクラス内に設定されていますか?
どんな助けでも大歓迎です。
編集:私はまた、特定のエラーが発生した場合にスクリプトを停止するにはどうすればよいかを追加するつもりでした。明らかに、exit()
またはdie()
トリックを行いますが、そうするためにもっと適切なものはありますか?