PHP set_exception_handler 设置异常处理函数

简介: If you're handling sensitive data and you don't want exceptions logging details such as variable contents when you throw them, you may find yourself f...

If you're handling sensitive data and you don't want exceptions logging details such as variable contents when you throw them, you may find yourself frustratedly looking for the bits and pieces that make up a normal stack trace output, so you can retain its legibility but just alter a few things. In that case, this may help you:

<?php

function exceptionHandler($exception) {

    // these are our templates
    $traceline "#%s %s(%s): %s(%s)";
    $msg "PHP Fatal error:  Uncaught exception '%s' with message '%s' in %s:%s Stack trace: %s   thrown in %s on line %s";

    // alter your trace as you please, here
    $trace $exception->getTrace();
    foreach ($trace as $key => $stackPoint) {
        // I'm converting arguments to their type
        // (prevents passwords from ever getting logged as anything other than 'string')
        $trace[$key]['args'] = array_map('gettype'$trace[$key]['args']);
    }

    // build your tracelines
    $result = array();
    foreach ($trace as $key => $stackPoint) {
        $result[] = sprintf(
            $traceline,
            $key,
            $stackPoint['file'],
            $stackPoint['line'],
            $stackPoint['function'],
            implode(', '$stackPoint['args'])
        );
    }
    // trace always ends with {main}
    $result[] = '#' . ++$key ' {main}';

    // write tracelines into main template
    $msg sprintf(
        $msg,
        get_class($exception),
        $exception->getMessage(),
        $exception->getFile(),
        $exception->getLine(),
        implode(" "$result),
        $exception->getFile(),
        $exception->getLine()
    );

    // log or echo as you please
    error_log($msg);
}

?>

If you're not a fan of sprintf() or the duplicate $exception->getFile() and $exception->getLine() calls you can of course replace that as you like - consider this a mere compilation of the parts.

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
1月前
|
PHP 开发者 UED
深入理解PHP中的异常处理
在PHP编程中,异常处理是保证代码健壮性的关键机制之一。通过掌握正确的异常处理策略,开发者可以有效预防和应对程序运行过程中的意外情况,从而提升应用程序的稳定性和用户体验。本文将深入浅出地介绍PHP异常处理的基本概念、实践方法以及如何通过自定义异常来增强代码的可维护性和扩展性。
|
2月前
|
PHP 开发者 UED
PHP中的异常处理:理解与应用
在编程的世界中,错误和异常就像是不请自来的客人——总是在你最不希望它们出现的时候敲门。对于PHP开发者来说,学会优雅地处理这些“不速之客”是提升代码质量和用户体验的关键。本文将带你深入理解PHP中的异常处理机制,通过实际的代码示例,展示如何捕获、处理以及自定义异常,让你的应用程序更加健壮和灵活。准备好迎接挑战,让我们共同探索PHP异常处理的奥秘吧!
105 66
|
1月前
|
PHP 开发者 UED
PHP中的异常处理:理解与实践
在编程世界中,错误和意外是不可避免的。PHP提供了一套异常处理机制,帮助开发者优雅地管理这些问题。本文将引导你理解PHP中异常处理的基本概念,并通过实际代码示例展示如何捕获和处理异常。我们将从基础开始,逐步深入,确保你能掌握这一技能。
50 21
|
1月前
|
程序员 PHP
PHP中的异常处理:从基础到进阶
在编程的世界里,异常处理如同生活中的急救箱,它不是日常所需,却能在关键时刻挽救程序的“生命”。本文将带你深入PHP的异常处理机制,从抛出、捕获到自定义异常,一步步构建你的代码“安全网”。准备好,让我们一起探索如何在PHP代码中优雅地处理那些不请自来的错误和异常。
|
1月前
|
PHP 开发者 UED
PHP中的异常处理机制解析####
本文深入探讨了PHP中的异常处理机制,通过实例解析try-catch语句的用法,并对比传统错误处理方式,揭示其在提升代码健壮性与可维护性方面的优势。文章还简要介绍了自定义异常类的创建及其应用场景,为开发者提供实用的技术参考。 ####
|
1月前
|
数据库连接 PHP 开发者
PHP中的异常处理机制####
本文深入探讨了PHP中的异常处理机制,包括异常的定义、抛出、捕获以及自定义异常类的创建。通过实例代码展示了如何在实际应用中有效地使用try-catch语句来提高代码的健壮性和可维护性。此外,还介绍了finally块的作用及其在资源管理中的应用。 ####
19 5
|
1月前
|
PHP
PHP中的异常处理:如何优雅地处理错误
在编程的世界里,错误和异常是不可避免的。它们就像是道路上的坑洼,让我们的代码旅程充满颠簸。但是,如果我们能够学会优雅地处理这些异常,我们的代码之旅就能变得更加顺畅。本文将带你了解PHP中的异常处理机制,教你如何捕获、处理和抛出异常,让你的代码更加健壮和可靠。让我们一起踏上这段旅程,探索PHP中异常处理的世界吧!
|
2月前
|
PHP 开发者 UED
探索PHP中的异常处理:提升代码的健壮性
在PHP开发中,优雅地处理错误和异常是确保应用稳定性和用户体验的关键。本文将通过深入浅出的方式,介绍如何在PHP中实现有效的异常处理机制,包括异常的基本概念、如何抛出和捕获异常,以及最佳实践。准备好让你的代码变得更加健壮和可靠吧!
23 2
|
2月前
|
监控 PHP 开发者
PHP中的异常处理:深入理解与最佳实践####
本文旨在通过探讨PHP中的异常处理机制,揭示其在现代Web开发中的重要性。我们将从基本概念入手,逐步深入到高级应用,包括自定义异常类、异常的最佳实践以及如何有效地捕获和处理多个异常,为开发者提供一套完整的解决方案来增强应用程序的健壮性和用户体验。 ####
|
2月前
|
PHP 数据库 开发者
深入理解PHP中的异常处理
在编程世界中,错误和异常是不可避免的。它们像是道路上的坑洼,让我们的代码之旅颠簸不平。但正如古人云:“困难是人的教科书。”通过理解和掌握PHP中的异常处理,我们不仅能够填平这些坑洼,还能在旅途中搭建起桥梁,让我们的代码更加健壮和可靠。本文将带你深入了解PHP的异常处理机制,探索如何使用try-catch语句来捕捉和处理异常,以及finally块的使用。我们将一起学习如何编写更优雅的错误处理代码,确保我们的应用程序能够在遇到问题时优雅地恢复或报告错误,而不是崩溃。准备好,让我们一起踏上这段旅程,探索如何在PHP中处理那些不请自来的“惊喜”。