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

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

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

Указанные значения в виде чисел или констант можно комбинировать, формируя битовую маску ошибок, о которых необходимо сообщать в ходе исполнения сценария. Для комбинирования используются битовые операторы, но в конфигурационном файле 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_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);

?>

Введение

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

Указанные значения в виде чисел или констант можно комбинировать, формируя битовую маску ошибок, о которых необходимо сообщать в ходе исполнения сценария. Для комбинирования используются битовые операторы, но в конфигурационном файле 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_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);

?>