首页 > Web开发 > 详细

[php] 错误接管类

时间:2017-07-11 22:30:04      阅读:367      评论:0      收藏:0      [点我收藏+]

自己弄的一个错误接管类:

<?php

//----------------------------------
// Leephp 错误接管类
// 2017-07-06
// PengchongLee
//----------------------------------

 // error_reporting — 设置应该报告何种 PHP 错误
 error_reporting(0);
 
class Erro
{
    public function __construct()
    {
        $this->iserr();
    }
    public function iserr()
    {    
        // set_exception_handler — 设置用户自定义的异常处理函数 
        set_exception_handler([$this,‘ex‘]);

        // set_error_handler — 设置用户自定义的错误处理函数
        set_error_handler([$this,‘err‘]);

        // register_shutdown_function — 注册一个会在php中止时执行的函数
        register_shutdown_function( [ $this,‘last_error‘ ]);
    }

    // 异常接管
    public function ex($ex)
    {
        // 获取错误异常信息
        $message = $ex->getMessage();
        // 获取错误异常代码
        $code    = $ex->getCode();
        // 获取错误异常文件
        $file    = $ex->getFile();
        // 获取错误异常文件行数
        $line    = $ex->getLine();
    }

    // 错误接管
    public function err( $code, $message,$file ,$line )
    {
        // 记录日志
        $this->errlog( $code, $message,$file ,$line );
    }

    // 脚本结束前获取最后错误
    public function last_error()
    {
        // error_get_last — 获取最后发生的错误
        $last = error_get_last();
        $this->errlog( $last[‘type‘],$last[‘message‘],$last[‘file‘],$last[‘line‘] );
    }

    // 错误信息收集并记录 (参数传输的顺序不一样,参数还不一样)
    public function errlog( $code, $message,$file ,$line )
    {
        // 拼接错误信息
        $errstr  =  date(‘Y-m-d h:i:s‘)."\r\n";
        $errstr .= ‘  错误级别:‘.$code."\r\n";
        $errstr .= ‘  错误信息:‘.$message."\r\n";
        $errstr .= ‘  错误文件:‘.$file."\r\n";
        $errstr .= ‘  错误行数:‘.$line."\r\n";
        $errstr .= "\r\n";

        // error_log — 发送错误信息到某个地方
        error_log($errstr,3,__DIR__.‘/error.log‘);
    }

}

 

[php] 错误接管类

原文:http://www.cnblogs.com/lipcblog/p/7152710.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!