将警告视为错误
Posted
技术标签:
【中文标题】将警告视为错误【英文标题】: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 的好答案,一切都很好。 【参考方案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())->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");
或者只用<pre>
标签和htmlspecialchars()
包装它。 @DavidSpector。以上是关于将警告视为错误的主要内容,如果未能解决你的问题,请参考以下文章