我正在使用set_error_handler()
使用自定义错误处理程序。所有的工作都很完美,直到我进入“Do buggy script”部分。这个错误的脚本是http://osticket.com/的一些集成。请注意,我在没有集成的情况下启用了ostickets的基本安装上的所有错误,并且我得到了相同的错误,因此我知道这不是我集成中的缺陷。
当我运行下面显示的脚本时,我会将大约200个错误写入我的日志并通过电子邮件发送给我。
我希望在此脚本之前暂时禁用set_error_handler
,然后在完成后立即重新启用它。
这是如何完成的?
<?php
ini_set('display_errors', 1);
error_reporting(E_ALL);
set_error_handler("my_error_handler");
//Do normal script
//I wish to disable set_error_handler here
//Do buggy script
//I wish to re-enable set_error_handler here
//Do normal script
//Complete
function my_error_handler($e_number, $e_message, $e_file, $e_line, $e_vars) {
$message = "An error occurred in script '$e_file' on line $e_line: $e_message (error no: $e_number)";
syslog(LOG_INFO,'my_error_handler: '.$message);
$e_vars='<pre>'.print_r($e_vars, 1).'</pre>';
ob_start();
debug_print_backtrace();
$backtrace = ob_get_clean();
if (in_array(substr($_SERVER['HTTP_HOST'], 0, 5), array('local', '127.0', '192.1'))) {
echo "<div class='error'>{$message}</div><p>e_vars:</p><pre>{$e_vars}</pre><p>debug_print_backtrace:</p><pre>{$backtrace}</pre>";
} else {
error_log ($message.' e_vars=> '.$e_vars, 1, 'errors@testsite.com');
if ( ($e_number != E_NOTICE) && ($e_number < 2048)) {
echo '<div class="error">A system error occurred. We apologize for the inconvenience.</div>';
}
}
}
?>
在OSTicket代码中,bootstrap.init()设置错误报告。我不希望修改原始的OSTicket代码,因为这样做会使升级到新版本变得更加困难。
#Error reporting...Good idea to ENABLE error reporting to a file. i.e display_errors should be set to false
$error_reporting = E_ALL & ~E_NOTICE;
if (defined('E_STRICT')) # 5.4.0
$error_reporting &= ~E_STRICT;
if (defined('E_DEPRECATED')) # 5.3.0
$error_reporting &= ~(E_DEPRECATED | E_USER_DEPRECATED);
error_reporting($error_reporting); //Respect whatever is set in php.ini (sysadmin knows better??)
#Don't display errors
ini_set('display_errors', 0);
ini_set('display_startup_errors', 0);
答案 0 :(得分:4)
只需设置另一个无效功能:
$my_error_handler = set_error_handler(function() { return true; });
// call OSTicket here
set_error_handler($my_error_handler);
将return true
更改为return false
以执行PHP内部错误处理程序。