目錄
2. set_error_handler的使用
3.自定义错误处理类
4.register_shutdown_function函数的使用
1.作用
2.使用场景
3.注意点
首頁 後端開發 php教程 3.PHP自定义错误处理器

3.PHP自定义错误处理器

Jun 23, 2016 pm 01:31 PM

1. 使用set_error_handler 自定义错误处理函数说明

  • 1.创建错误处理函数
  • 2.设置不同级别调用函数
  • 3.set_error_handler函数指定接管错误处理
  • set_error_handler 说明

    mixed set_error_handler ( callable $error_handler [, int $error_types = E_ALL | E_STRICT ] )设置一个用户的函数(error_handler)来处理脚本中出现的错误。本函数可以用你自己定义的方式来处理运行中的错误, 例如,在应用程序中严重错误发生时,或者在特定条件下触发了一个错误(使用 trigger_error()),你需要对数据/文件做清理回收。重要的是要记住 error_types 里指定的错误类型都会绕过 PHP 标准错误处理程序, 除非回调函数返回了 FALSE。 error_reporting() 设置将不会起到作用而你的错误处理函数继续会被调用 ?? 不过你仍然可以获取 error_reporting 的当前值,并做适当处理。 需要特别注意的是带 @ error-control operator 前缀的语句发生错误时,这个值会是 0。同时注意,在需要时你有责任使用 die()。 如果错误处理程序返回了,脚本将会继续执行发生错误的后一行。以下级别的错误不能由用户定义的函数来处理: E_ERROR、 E_PARSE、 E_CORE_ERROR、 E_CORE_WARNING、 E_COMPILE_ERROR、 E_COMPILE_WARNING,和在 调用 set_error_handler() 函数所在文件中产生的大多数 E_STRICT。如果错误发生在脚本执行之前(比如文件上传时),将不会 调用自定义的错误处理程序因为它尚未在那时注册。参数error_handler用户的函数需要接受两个参数:错误码和描述错误的 string。 另外有可能提供三个可选参数:发生错误的文件名、发生错误的行号 以及发生错误的上下文(一个指向错误发生时活动符号表的 array)。 该函数可以表示为:handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )errno第一个参数 errno,包含了错误的级别,是一个 integer。errstr第二个参数 errstr,包含了错误的信息,是一个 string。errfile第三个参数是可选的,errfile, 包含了发生错误的文件名,是一个 string。errline第四个参数是一个可选项, errline, 包含了错误发生的行号,是一个 integer。errcontext第五个可选参数, errcontext, 是一个指向错误发生时活动符号表的 array。 也就是说,errcontext 会包含错误触发处作用域内所有变量的数组。 用户的错误处理程序不应该修改错误上下文(context)。如果函数返回 FALSE,标准错误处理处理程序将会继续调用。error_types就像error_reporting 的 ini 设置能够控制错误的显示一样, 此参数能够用于屏蔽 error_handler 的触发。 如果没有该掩码, 无论 error_reporting 是如何设置的, error_handler 都会在每个错误发生时被调用。
    登入後複製

    2. set_error_handler的使用

    header('content-type:text/html; charset=utf-8');//开启所有的错误报告error_reporting(-1);function customError($errno, $errmsg, $errfile, $errline){    if (!(error_reporting() & $errno)) {        // This error code is not included in error_reporting        return;    }    switch ($errno) {    case E_USER_ERROR:        echo "<b>My ERROR</b> [$errno] $errmsg<br />".PHP_EOL;        echo " Fatal error on line $errline in file $errfile";        echo ", PHP " . PHP_VERSION . " (" . PHP_OS . ")<br />".PHP_EOL;        echo "Aborting...<br />\n";        // exit(1);        break;    case E_USER_WARNING:        echo "<b>My WARNING</b> [$errno] $errmsg<br />".PHP_EOL;        break;    case E_USER_NOTICE:        echo "<b>My NOTICE</b> [$errno] $errmsg<br />".PHP_EOL;        break;    default:        echo "Unknown error type: [$errno] $errmsg<br />".PHP_EOL;        break;    }    /* Don't execute PHP internal error handler */    return true;}set_error_handler('customError');echo $test;settype($var, 'king');// test();trigger_error('出错了!', E_USER_ERROR);echo '<hr>';//回收错误接管restore_error_handler();echo $king;echo '<hr>';set_error_handler('customError', E_ALL&~E_NOTICE);echo '<hr>';settype($var, 'king');echo 'continue...............';
    登入後複製

    3.自定义错误处理类

    /** * 自定义错误处理类 */class MyErrorHandler {    public $msg='';    public $filename='';    public $line=0;    public $vars=array();    protected $_noticeLog = '/tmp/php_error.log';    function __construct($msg, $filename, $line, $vars) {        $this->msg=$msg;        $this->filename=$filename;        $this->line=$line;        $this->vars=$vars;    }    /** * [deal 自定义错误处理请求] * @param [int] $errno [错误号] * @param [string] $errmsg [错误描述] * @param [string] $errfile [出错的文件] * @param [int] $errline [出错的行号] * @param [array] $vars [错误触发处作用域内所有变量的数组] * @return [bool] */    public static function deal($errno, $errmsg, $errfile, $errline, $vars){        $self = new self($errmsg, $errfile, $errline, $vars);        switch ($errno) {            //致命级别的错误发邮件给管理员            case E_USER_ERROR:                return $self->dealError();                break;            case E_USER_WARNING:            case E_WARNING:                return $self->dealWarning();                break;            case E_USER_NOTICE:            case E_NOTICE:                return $self->dealNotice();                break;            default:                //交给php本身的错误机制处理                return false;                break;        }    }    public function get_debug_print_backtrace($traces_to_ignore = 1){        $traces = debug_backtrace();        $ret = array();        foreach($traces as $i => $call){            if ($i < $traces_to_ignore ) {                continue;            }            $object = '';            if (isset($call['class'])) {                $object = $call['class'].$call['type'];                if (is_array($call['args'])) {                    foreach ($call['args'] as &$arg) {                        $this->get_arg($arg);                    }                }            }                    $ret[] = '#'.str_pad($i - $traces_to_ignore, 3, ' ')            .$object.$call['function'].'('.implode(', ', $call['args'])            .') called at ['.$call['file'].':'.$call['line'].']';        }        return implode("\n",$ret);    }    public function get_arg(&$arg) {        if (is_object($arg)) {            $arr = (array)$arg;            $args = array();            foreach($arr as $key => $value) {                if (strpos($key, chr(0)) !== false) {                    $key = '';    // Private variable found                }                $args[] =  '['.$key.'] => '.get_arg($value);            }            $arg = get_class($arg) . ' Object ('.implode(',', $args).')';        }    }    /** * [dealError 处理错误级别的错误] * @return [type] [description] */    public function dealError(){        $backtrace=$this->get_debug_print_backtrace();        echo $backtrace; exit;        $errorMsg=<<<EOF 出现了致命错误,如下 产生错误的文件:{$this->filename} 产生错误的信息:{$this->msg} 产生错误的行号:{$this->line} 追踪信息:{$backtrace} \n EOF;        error_log($errorMsg, 1, '732578448@qq.com');        exit(1);    }    /** * [dealWarning 处理警告级别的错误] * @return [bool] */    public function dealWarning(){        $errorMsg=<<<EOF 出现了警告错误,如下 产生警告的文件:{$this->filename} 产生警告的信息:{$this->msg} 产生警告的行号:{$this->line} \n EOF;        error_log($errorMsg, 1, '732578448@qq.com');    }    /** * [dealNotice 处理通知级别的错误] * @return bool */    public function dealNotice(){        $datetime = date('Y-m-d H:i:s', time());        $errorMsg=<<<EOF 出现了通知错误,如下 产生通知的文件:{$this->filename} 产生通知的信息:{$this->msg} 产生通知的行号:{$this->line} 产生通知的时间:{$datetime} \n EOF;        return error_log($errorMsg, 3, $this->_noticeLog);    }}error_reporting(-1);set_error_handler(array('MyErrorHandler', 'deal'));ini_set('display_errors', 0);echo $var;trigger_error('zhiming', E_USER_ERROR);trigger_error('zhiming', E_USER_WARNING);
    登入後複製

    4.register_shutdown_function函数的使用

    1.作用

    1.通过register_shutdown_function函数,可以让我们设置一个当执行关闭时可以被调用的另一个函数。
    2.当我们的脚本执行完成或意外死掉导致PHP执行即将关闭时,我们的这个函数将会被调用

    2.使用场景

    1.页面强制被停止
    2.程序代码意外终止或超时

    3.注意点

    1.在register_shutdown_function之前不能有die() exit()等终止函数

    版权声明:本文为博主原创文章,未经博主允许不得转载。

    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1653
    14
    CakePHP 教程
    1413
    52
    Laravel 教程
    1305
    25
    PHP教程
    1251
    29
    C# 教程
    1224
    24
    在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

    JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

    PHP 8.1中的枚舉(枚舉)是什麼? PHP 8.1中的枚舉(枚舉)是什麼? Apr 03, 2025 am 12:05 AM

    PHP8.1中的枚舉功能通過定義命名常量增強了代碼的清晰度和類型安全性。 1)枚舉可以是整數、字符串或對象,提高了代碼可讀性和類型安全性。 2)枚舉基於類,支持面向對象特性,如遍歷和反射。 3)枚舉可用於比較和賦值,確保類型安全。 4)枚舉支持添加方法,實現複雜邏輯。 5)嚴格類型檢查和錯誤處理可避免常見錯誤。 6)枚舉減少魔法值,提升可維護性,但需注意性能優化。

    描述紮實的原則及其如何應用於PHP的開發。 描述紮實的原則及其如何應用於PHP的開發。 Apr 03, 2025 am 12:04 AM

    SOLID原則在PHP開發中的應用包括:1.單一職責原則(SRP):每個類只負責一個功能。 2.開閉原則(OCP):通過擴展而非修改實現變化。 3.里氏替換原則(LSP):子類可替換基類而不影響程序正確性。 4.接口隔離原則(ISP):使用細粒度接口避免依賴不使用的方法。 5.依賴倒置原則(DIP):高低層次模塊都依賴於抽象,通過依賴注入實現。

    會話如何劫持工作,如何在PHP中減輕它? 會話如何劫持工作,如何在PHP中減輕它? Apr 06, 2025 am 12:02 AM

    會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

    解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

    靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

    什麼是REST API設計原理? 什麼是REST API設計原理? Apr 04, 2025 am 12:01 AM

    RESTAPI設計原則包括資源定義、URI設計、HTTP方法使用、狀態碼使用、版本控制和HATEOAS。 1.資源應使用名詞表示並保持層次結構。 2.HTTP方法應符合其語義,如GET用於獲取資源。 3.狀態碼應正確使用,如404表示資源不存在。 4.版本控制可通過URI或頭部實現。 5.HATEOAS通過響應中的鏈接引導客戶端操作。

    您如何在PHP中有效處理異常(嘗試,捕捉,最後,投擲)? 您如何在PHP中有效處理異常(嘗試,捕捉,最後,投擲)? Apr 05, 2025 am 12:03 AM

    在PHP中,異常處理通過try,catch,finally,和throw關鍵字實現。 1)try塊包圍可能拋出異常的代碼;2)catch塊處理異常;3)finally塊確保代碼始終執行;4)throw用於手動拋出異常。這些機制幫助提升代碼的健壯性和可維護性。

    PHP中的匿名類是什麼?您何時可以使用它們? PHP中的匿名類是什麼?您何時可以使用它們? Apr 04, 2025 am 12:02 AM

    匿名類在PHP中的主要作用是創建一次性使用的對象。 1.匿名類允許在代碼中直接定義沒有名字的類,適用於臨時需求。 2.它們可以繼承類或實現接口,增加靈活性。 3.使用時需注意性能和代碼可讀性,避免重複定義相同的匿名類。

    See all articles