我对 PHP 和自定义错误处理程序的设置相当陌生,但我有一些代码可以在 CI 之外正常工作,但我不知道如何将其集成到 CI 控制器中。我收到错误“消息:未定义的属性:错误::$my_error_handler”
我的控制器是:
<?php
class Errors extends CI_Controller {
public function __construct()
{
parent::__construct();
}
function my_error_handler($number, $message, $file, $line, $vars)
{
$email = "
<p>An error ($number) occurred on line
<strong>$line</strong> and in the <strong>file: $file.</strong>
<p> $message </p>";
$email .= "<pre>" . print_r($vars, 1) . "</pre>";
$headers = 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
// Email the error to someone...
error_log($email, 1, '[email protected]', $headers);
// Make sure that you decide how to respond to errors (on the user's side)
// Either echo an error message, or kill the entire project. Up to you...
// The code below ensures that we only "die" if the error was more than
// just a NOTICE.
if ( ($number !== E_NOTICE) && ($number < 2048) ) {
die("There was an error. Please try again later.");
}
}
function test()
{
// We should use our custom function to handle errors.
set_error_handler($this->my_error_handler);
// Trigger an error... (var doesn't exist)
echo $somevarthatdoesnotexist;
}
}
?>
如果有更好的方法使用 CI 通过电子邮件发送错误消息,请告诉我。
我不认为扩展 CI_Controller 是解决这个问题的正确方法。相反,您应该扩展 CI_Logs 以在记录错误时发送电子邮件:
class MY_Log extends CI_Log {
function MY_Log(){
parent::__construct();
}
function write_log($level = 'error', $msg, $php_error = FALSE){
$result = parent::write_log($level, $msg, $php_error);
if ($result == TRUE && strtoupper($level) == 'ERROR') {
$message = "An error occurred: \n\n";
$message .= $level.' - '.date($this->_date_fmt). ' --> '.$msg."\n";
$this->CI =& get_instance();
$to = $this->CI->config->item('email_admin_address');
$from_name = $this->CI->config->item('email_general_name');
$from_address = $this->CI->config->item('email_general_address');
$subject = 'An error has occured';
$headers = "From: $from_name <$from_address>" . "\r\n";
$headers .= 'Content-type: text/plain; charset=utf-8\r\n';
mail($to, $subject, $message, $headers);
}
return $result;
}
}
将此类保存到 application\libraries\MY_Logs.php 并且不要忘记在 config.php 中启用错误日志记录:
$config['log_threshold'] = 1;
感谢WPStorm,他首先提出了这个想法。
我找到了解决方案。
set_error_handler(array(&$this, 'my_error_handler'));
因为您必须告诉错误处理程序它是您要调用的类方法(
set_error_handler(array(&$this, ‘method’))
的预期含义)而不仅仅是一个函数(set_error_handler(‘function’)
的预期含义)