Рассмотрение предупреждений как ошибок

У меня есть приложение php, которое я только что переустановил. К сожалению, это извергает предупреждения вроде:

Предупреждение: preg_match() ожидает, что параметр 2 будет строкой, объект указан в /home/yacoby/dev/netbeans/php/Zend/Db/Select.php в строке 776

Это невозможно (или очень тяжелая работа), чтобы решить проблему, поскольку у меня нет вызова, поэтому не могу определить, какие части моего кода вызывают предупреждение, и есть много кода.

Мне нужен метод для обработки предупреждений, таких как ошибки (в том, что приложение умирает и печатает stacktrace), или мне нужно, чтобы стек отображался при печати ошибок. Есть ли способ сделать это?

Ответ 1

См. пример # 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();
?>

Ответ 2

Посмотрите set_error_handler() и включите это в начале ваших сценариев или в ваш загрузочный лоток, чтобы просто распечатать stacktrace, когда E_WARNINGs происходят.

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");

Чтобы получить больше контроля над различными типами, просмотрите более явную версию, опубликованную в другом месте в ответах.

Ответ 3

Вы можете определить свой собственный обработчик ошибок, используя 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
    }
}