0

0

3.PHP自定义错误处理器

php中文网

php中文网

发布时间:2016-06-23 13:31:06

|

967人浏览过

|

来源于php中文网

原创

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()等终止函数

    成新网络商城购物系统
    成新网络商城购物系统

    使用模板与程序分离的方式构建,依靠专门设计的数据库操作类实现数据库存取,具有专有错误处理模块,通过 Email 实时报告数据库错误,除具有满足购物需要的全部功能外,成新商城购物系统还对购物系统体系做了丰富的扩展,全新设计的搜索功能,自定义成新商城购物系统代码功能代码已经全面优化,杜绝SQL注入漏洞前台测试用户名:admin密码:admin888后台管理员名:admin密码:admin888

    下载

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

    立即学习PHP免费学习笔记(深入)”;

    相关文章

    PHP速学教程(入门到精通)
    PHP速学教程(入门到精通)

    PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    Golang 测试体系与代码质量保障:工程级可靠性建设
    Golang 测试体系与代码质量保障:工程级可靠性建设

    Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

    6

    2026.02.28

    Golang 工程化架构设计:可维护与可演进系统构建
    Golang 工程化架构设计:可维护与可演进系统构建

    Go语言工程化架构设计专注于构建高可维护性、可演进的企业级系统。本专题深入探讨Go项目的目录结构设计、模块划分、依赖管理等核心架构原则,涵盖微服务架构、领域驱动设计(DDD)在Go中的实践应用。通过实战案例解析接口抽象、错误处理、配置管理、日志监控等关键工程化技术,帮助开发者掌握构建稳定、可扩展Go应用的最佳实践方法。

    6

    2026.02.28

    Golang 性能分析与运行时机制:构建高性能程序
    Golang 性能分析与运行时机制:构建高性能程序

    Go语言以其高效的并发模型和优异的性能表现广泛应用于高并发、高性能场景。其运行时机制包括 Goroutine 调度、内存管理、垃圾回收等方面,深入理解这些机制有助于编写更高效稳定的程序。本专题将系统讲解 Golang 的性能分析工具使用、常见性能瓶颈定位及优化策略,并结合实际案例剖析 Go 程序的运行时行为,帮助开发者掌握构建高性能应用的关键技能。

    8

    2026.02.28

    Golang 并发编程模型与工程实践:从语言特性到系统性能
    Golang 并发编程模型与工程实践:从语言特性到系统性能

    本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

    14

    2026.02.27

    Golang 高级特性与最佳实践:提升代码艺术
    Golang 高级特性与最佳实践:提升代码艺术

    本专题深入剖析 Golang 的高级特性与工程级最佳实践,涵盖并发模型、内存管理、接口设计与错误处理策略。通过真实场景与代码对比,引导从“可运行”走向“高质量”,帮助构建高性能、可扩展、易维护的优雅 Go 代码体系。

    17

    2026.02.27

    Golang 测试与调试专题:确保代码可靠性
    Golang 测试与调试专题:确保代码可靠性

    本专题聚焦 Golang 的测试与调试体系,系统讲解单元测试、表驱动测试、基准测试与覆盖率分析方法,并深入剖析调试工具与常见问题定位思路。通过实践示例,引导建立可验证、可回归的工程习惯,从而持续提升代码可靠性与可维护性。

    2

    2026.02.27

    漫蛙app官网链接入口
    漫蛙app官网链接入口

    漫蛙App官网提供多条稳定入口,包括 https://manwa.me、https

    130

    2026.02.27

    deepseek在线提问
    deepseek在线提问

    本合集汇总了DeepSeek在线提问技巧与免登录使用入口,助你快速上手AI对话、写作、分析等功能。阅读专题下面的文章了解更多详细内容。

    8

    2026.02.27

    AO3官网直接进入
    AO3官网直接进入

    AO3官网最新入口合集,汇总2026年可用官方及镜像链接,助你快速稳定访问Archive of Our Own平台。阅读专题下面的文章了解更多详细内容。

    208

    2026.02.27

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    第三期培训_PHP开发
    第三期培训_PHP开发

    共116课时 | 27.2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号