Приглашаем посетить
Бунин (bunin-lit.ru)

Учебник по PHP : Отслеживание и обработка ошибок : Введение

Отслеживание и обработка ошибок : Введение

PHP имеет следующие типы ошибок и предупреждений:
ЗначениеКонстантаОписание
1E_ERRORФатальная ошибка времени исполнения.
2E_WARNINGПредупреждение времени исполнения.
4E_PARSEСообщение интерпретации времени исполнения.
8E_NOTICEПростое сообщение времени исполнения.
16E_CORE_ERRORФатальная ошибка при инициализации PHP.
32E_CORE_WARNINGПредупреждение инициализации.
64E_COMPILE_ERRORФатальная ошибка компиляции.
128E_COMPILE_WARNINGПредупреждение компиляции.
256E_USER_ERRORОшибки, определяемые пользователем.
512E_USER_WARNINGПредупреждения, определяемые пользователем.
1024E_USER_NOTICEСообщения, определяемые пользователем.
2047E_ALLВсе перечисленные сообщения.


Указанные значения в виде чисел или констант можно комбинировать, формируя битовую маску ошибок, о которых необходимо сообщать в ходе исполнения сценария. Для комбинирования используются битовые операторы, но в конфигурационном файле php.ini распознаются только "|", "~", "!" и "&".

В PHP 4 по умолчанию разрешены сообщения вида E_ALL & ~E_NOTICE, то есть сообщаться должно все, кроме обычных сообщений. Можно переопределить эту установку параметром файла конфигурации error_reporting() (ее также можно указывать в файлах конфигурации сервера Apache).

Если при вызове функции перед ее именем указать символ "@", то в случае возникновения ошибки в этой функции сообщение о нем выдаваться не будет.

В настоящее время оператор игнорирования ошибок блокирует даже выдачу сообщений о критических ошибках, при возникновении которых сценарий досрочно завершается.

Если разрешен параметр конфигурации track_errors, то сообщение об ошибке сохраняется в глобальной переменной $php_errormsg.
<?
// определенный пользователем обработчик ошибок
function userErrorHandler($errno,$errmsg,$filename,$linenum,$vars) {
  // время возникновения ошибки
  $dt=date("Y-m-d H:i:s (T)");
  $errortype = array(
    1    => "Error",
    2    => "Warning",
    4    => "Parsing Error",
    8    => "Notice",
    16   => "Core Error",
    32   => "Core Warning",
    64   => "Compile Error",
    128  => "Compile Warning",
    256  => "User Error",
    512  => "User Warning",
    1024 => "User Notice"
    );

  $err.="время ($dt), номер ошибки ($errno), ";
  $err.="тип ошибки (".$errortype[$errno]."): ";
  $err.="\"$errmsg\".файл \"$filename\", строка (";
  $err.=$linenum.")\n";

  $user_errors=array(E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE);
  if(in_array($errno, $user_errors))
  // выдать сообщение для ошибок пользователя
  echo $err;

  // сохранить событие ошибки в системном журнале
  error_log($err, 3, "/usr/local/php4/error.log");
}

// установить уровень контроля ошибок и обработчик
error_reporting(0); // не выводить сообщения PHP
$old_error_handler=set_error_handler("userErrorHAndler");

// неопределенная константа вызывает предупреждение
$t=_NOT_DEFINED_CONSTANT;

trigger_error("Моя ошибка", E_USER_ERROR);
trigger_error("Мое предупреждение", E_USER_WARNING);

?>

Назад Содержание Вперед