【发布时间】:2011-09-07 06:16:17
【问题描述】:
我对如何正确使用 set_error_handler() 感到困惑,php documentation 并没有真正帮助澄清。
我希望它通过电子邮件向我发送尽可能多的错误,通知除外。
我有以下代码
<?php
if (TRAP_ERRORS) {
// True on production, false in development, where errors are just echoed out.
set_exception_handler('globalExceptionHandler');
set_error_handler('globalErrorHandler', E_USER_WARNING);
}
function globalExceptionHandler($e) {
//log and email stuff here
}
function globalErrorHandler($errno, $errstr, $errfile, $errline) {
switch ($errno) {
case E_NOTICE:
case E_USER_NOTICE:
$errors = "Notice";
break;
case E_WARNING:
case E_USER_WARNING:
$errors = "Warning";
break;
case E_ERROR:
case E_USER_ERROR:
$errors = "Fatal Error";
break;
default:
$errors = "Unknown Error";
break;
}
error_log(sprintf("PHP %s: %s in %s on line %d", $errors, $errstr, $errfile, $errline));
$msg = "ERROR: [$errno] $errstr\r\n".
"$errors on line $errline in file $errfile\r\n";
sendErrorEmail($msg);
showErrorPage();
exit(1);
}
function sendErrorEmail($p_errorMsg) {
// Parse and sent out the error email...
}
function showErrorPage() {
// Redirect to an error page.
}
?>
以上是我当前的设置set_error_handler('globalErrorHandler', E_USER_WARNING);,这似乎是错误的,因为它没有涵盖 trigger_error() 错误。我认为这是因为该参数应该是一个位掩码,而不仅仅是一个错误级别,但我不确定如何将其设置为最大数量的错误/信息(通知除外)。我见过使用E_ALL 的示例,但这实际上直接导致任何包含全局错误处理程序内容的代码对我来说出错。
无论如何,我如何使用 set_error_handler 以便我的自定义错误处理程序可以处理最大数量的信息(这样我可以在发生此类问题时直接收到自动电子邮件,而不必稍后查看日志)。
【问题讨论】:
标签: php error-handling