我想通过扩展现有的CI_Log类来将系统错误日志存储到数据库。到目前为止,这是我做了什么如何存储错误在CodeIgniter中登录数据库
class MY_Logger extends CI_Log{
public function __construct(){
parent::__construct();
}
function write_log($level='error', $msg, $php_error = FALSE){
$result = parent::write_log($level, $msg, $php_error);
$ci =& get_instance();
$ci->load->library('user_agent');
if ($result == TRUE && strtoupper($level) == 'ERROR') {
$gmtoffset = 60*60*5;
$post = array(
'log_type' => $level,
'log_message' => $msg,
'log_php_message' => $php_error,
'log_ip_origin' => $this->input->ip_address(),
'log_user_agent' => $this->agent->agent_string(),
'log_date' => date("Y-m-d H:i:s",time() + $gmtoffset)
);
$ci->db->insert('system_log', $post);
}
return $result;
}
}
和我有以下的autoload.php和config.php文件
$autoload['libraries'] = array('database', 'session', 'xmlrpc', 'user_agent');
$config['log_threshold'] = 1;
配置然而,当我测试了一下,不存储错误数据库(虽然它显示并正确写入日志)
任何人都可以指出我在这里错过了什么吗?
PS:
已经改变了代码,以便它延伸CI_Exceptions不起作用以及:
class MY_Exceptions extends CI_Exceptions{
function __construct(){
parent::__construct();
}
function log_exception($severity, $message, $filepath, $line){
//$result = parent::write_log($level, $msg, $php_error);
$ci =& get_instance();
//if ($result == TRUE && strtoupper($level) == 'ERROR') {
$gmtoffset = 60*60*5;
$post = array(
'log_type' => $severity,
'log_message' => $message,
'log_php_message' => $line,
'log_ip_origin' => $ci->input->ip_address(),
'log_user_agent' => $ci->agent->agent_string(),
'log_date' => date("Y-m-d H:i:s",time() + $gmtoffset)
);
$ci->db->insert('system_log', $post);
//}
parent::log_exception($severity, $message, $filepath, $line);
//return $result;
}
}
它抛出?\ – 2013-05-07 07:45:13
是您在库文件夹中记录任何错误?尝试将其重命名为MY_Log(或者你在配置中设置的任何前缀而不是MY_) – package 2013-05-07 07:49:38
@LolCoder我通过创建将数据插入到不存在的表的故意错误来测试它。 – Jeremy 2013-05-07 07:56:35