Справочник по PHP : Управляющие функции : Отслеживание и обработка ошибок : Введение

Материал из Справочник Web-языков.

Перейти к: навигация, поиск
Главная  ::. PHP  ::. Управляющие функции  ::. Отслеживание и обработка ошибок  ::. Введение

PHP имеет следующие типы ошибок и предупреждений:

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

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

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

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

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

Если разрешен параметр конфигурации track_errors, то сообщение об ошибке сохраняется в глобальной переменной $php_errormsg.

<?php
// определенный пользователем обработчик ошибок
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_ERRORE_USER_WARNINGE_USER_NOTICE);
  if(
in_array($errno$user_errors))
  
// выдать сообщение для ошибок пользователя
  
echo $err;

  
// сохранить событие ошибки в системном журнале
  
error_log($err3"/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);

?>
Личные инструменты
1.44677710533