将警告视为错误

Yac*_*oby 13 php callstack warnings

我有一个我刚刚重新考虑的php应用程序.不幸的是,它喷出了警告:

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

由于我没有callstack,所以不可能(或非常努力)解决问题,因此无法分辨我的代码的哪些部分导致警告并且有很多代码.

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

Tor*_*amo 22

请参阅http://www.php.net/manual/en/class.errorexception.php上的示例#1

<?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();
?>
Run Code Online (Sandbox Code Playgroud)


Gor*_*don 9

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");
Run Code Online (Sandbox Code Playgroud)

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


Nei*_*ken 4

您可以使用 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
    }
}
Run Code Online (Sandbox Code Playgroud)