1

我对 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, 'name@domain.com', $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 通过电子邮件发送错误消息,请告诉我。

4

3 回答 3

8

我不认为扩展 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,他首先提出了这个想法。

于 2012-08-02T13:23:53.640 回答
2

我找到了解决方案。

set_error_handler(array(&$this, 'my_error_handler'));

由于您必须告诉错误处理程序它是您要调用的类方法(的预期含义set_error_handler(array(&$this, ‘method’))),而不仅仅是一个函数(的预期含义set_error_handler(‘function’)

于 2012-06-13T07:14:50.350 回答
0

如果您扩展核心异常类,您将能够在其中添加所需的功能。

关于扩展该类的 Codeigniter 论坛帖子

希望这可以帮助

于 2012-06-12T12:43:11.860 回答