【问题标题】:Treating Warnings as Errors将警告视为错误
【发布时间】:2011-01-05 11:23:50
【问题描述】:

我有一个我刚刚重构的 php 应用程序。不幸的是,它会发出如下警告:

警告:preg_match() 期望参数 2 是字符串,对象在 /home/yacoby/dev/netbeans/php/Zend/Db/Select.php 第 776 行中给出

解决这个问题是不可能的(或非常困难的工作),因为我没有调用堆栈,所以无法判断我的代码的哪些部分导致了警告并且有很多代码。

我需要一种方法来处理像错误一样的警告(因为应用程序死掉并打印堆栈跟踪),或者我需要在打印错误时显示堆栈跟踪。有没有办法做到这一点?

【问题讨论】:

  • XDebug 在这里xdebug.org/docs/stack_trace 谈到了这样的功能
  • XDebug 答案被接受,因为它产生了最好的堆栈跟踪(而且它在我的 IDE 中有可点击的链接;))。所有其他人也都得到了 +1 的好答案,一切都很好。

标签: php warnings callstack


【解决方案1】:

您可以使用 set_error_handler() 定义自己的错误处理程序

在处理函数中,您可以根据需要处理每一类错误。这是我使用的一个基本模板,在我的例子中我只想处理致命错误,所以我忽略了通知和警告。

在您的情况下,您可以对警告进行回溯,或根据需要记录它们

function error_handler($errno,$message,$file,$line,$context) {

switch($errno) {
    // ignore warnings and notices
    case E_WARNING:
    case E_NOTICE:
    case E_USER_NOTICE:
    case E_USER_WARNING:
        break;
    // log PHP and user errors
    case E_ERROR:
    case E_USER_ERROR:
              // Do some processing on fatal errors
    }
}

【讨论】:

  • 以下错误类型无法使用用户定义的函数进行处理:E_ERROR、E_PARSE、E_CORE_ERROR、E_CORE_WARNING、E_COMPILE_ERROR、E_COMPILE_WARNING 以及在 set_error_handler 所在的文件中引发的大部分 E_STRICT () 叫做。 - 但我还是投了赞成票。
  • 啊,谢谢你的信息。我通常使用它来处理 USER_ERROR,但不知道它无法捕获 E_ERROR,尽管仔细想想它确实是有道理的。
【解决方案2】:

参见示例 #1,http://www.php.net/manual/en/class.errorexception.php

<?php
function exception_error_handler($errno, $errstr, $errfile, $errline ) {
    throw new ErrorException($errstr, $errno, 0, $errfile, $errline);
}
set_error_handler("exception_error_handler");

/* Trigger exception */
strpos();
?>

【讨论】:

  • 我认为这就是 PHPUnit 将常规错误、通知和警告转换为 PHPUnit 框架错误/通知/警告异常的方式。
  • 不知道它是否“酷”,但它绝对是最简单的。 :P
  • 显示更多错误,但对我来说没有在警告上显示堆栈跟踪。
【解决方案3】:

查看 set_error_handler() 并将其包含在脚本的开头或引导程序中,以便在 E_WARNING 发生时打印堆栈跟踪。

function stacktrace_error_handler($errno,$message,$file,$line,$context)
{
    if($errno === E_WARNING) {
        debug_print_backtrace();
    }
    return false; // to execute the regular error handler
}
set_error_handler("stacktrace_error_handler");

要更好地控制各种类型,请查看答案中其他地方发布的更明确的版本。

【讨论】:

  • 有效,但输出使用换行符而不是
    ,因此在HTML中难以阅读。
  • 这里是 HTML 输出代码: function GetStack() { return (new Exception())->getTraceAsString(); } // GetStack 函数 stacktrace_error_handler($errno,$message,$file,$line,$context) { if($errno === E_WARNING) { echo nl2br(GetStack()); } 返回假; // 执行常规错误处理程序 } set_error_handler("stacktrace_error_handler");
  • 这里是 HTML 输出代码:function GetStack() { return (new Exception())-&gt;getTraceAsString(); } // GetStack function stacktrace_error_handler($errno,$message,$file,$line,$context) { if($errno === E_WARNING) { echo nl2br(GetStack()); } return false; // to execute the regular error handler } set_error_handler("stacktrace_error_handler");
  • 或者只用&lt;pre&gt;标签和htmlspecialchars()包装它。 @DavidSpector。
猜你喜欢
  • 2012-01-13
  • 2022-08-03
  • 2010-11-05
  • 2013-07-06
  • 1970-01-01
  • 1970-01-01
  • 2013-03-11
  • 2011-03-15
  • 2018-09-28
相关资源
最近更新 更多