Форумы портала PHP.SU » Разное » Обсуждение статей » Отлавливаем ошибки, не пойманные исключения.

Страниц (1): [1]
 

1. sKaa - 03 Февраля, 2012 - 21:04:31 - перейти к сообщению
Итак, я хочу сразу сказать, что эта "статья" навеяна мне некоторыми статьями с хабра :
http://habrahabr[dot]ru/blogs/php/134557/ - Битовые операции
http://ru[dot]wikipedia[dot]org/wiki/%D0[dot][dot][dot]1%86%D0%B8%D0%B8 - Немного теории лично от Вики
http://www.php.net/manual/ru/lan...tors.bitwise.php - А так-же офф мануалы.
Я сразу скажу, что материал ориентирован на людей которые прекрасно понимают, что такое ООП и с чем его едят.
Поехали :
1) Пишем класс по отлову ошибок, не пойманных исключений. Код почему-то у меня получился достаточно "тяжелый" хотя и его очень мало, но Adobe DreamWeaver CS 5.5 местами помечает строки красным - хотя всё работает. Думаю у кого NetBeans 7.1 или аналогичные редакторы проблем не будет, а если будут не стоит на них существенно зацикливаться, нам всё выдадут наши новые ошибки.

Спойлер (Отобразить)

Едем дальше :
index.php :

PHP:
скопировать код в буфер обмена
  1.  
  2. // Запускаем статический метод класса с аргументом в виде безымянной функции
  3. Errors :: Init(function(){
  4.                 // Собираем аргументы функции в переменные
  5.                 list($errno, $errstr, $errfile, $errline, $codes) = func_get_args();
  6.                 // Переводим код ошибки в читабельный вид (массив с кодами и именами ошибок в классе)
  7.                 $err = (isset($codes[$errno])) ? $codes[$errno] : 'Unknown';
  8.                 // Тут конструкция которая используется для работы с битовыми операторми, её суть в данном примере это узнать по номеру ошибки какой "тяжести" она является, и если она критическая, после которой работа скрипта остановится мы её обрамляем в тэг <b> чтобы показать какая именно из ошибок привела к таким чудовищным последствиям. Ессно echo ... у меня в коде заменены на логирование ошибок т.к пользователю их видеть не совсем обязательно но для наглядности тут echo.
  9.                 if($errno & (E_ERROR | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR))
  10.                         echo "<br><b>$err : $errstr в файле $errfile на строке $errline</b> (работа скрипта остановлена)";
  11.                 else
  12.                         echo "<br>$err : $errstr в файле $errfile на строке $errline"; 
  13.         }
  14. );
  15.  
  16.  

ну и для наглядности вызовем парочку :
PHP:
скопировать код в буфер обмена
  1. trigger_error('Bla bla', E_USER_NOTICE);
  2. trigger_error('Critical Bla bla', E_USER_ERROR);


итак про битовые маски, помните массив из класса?
if( $errno & (E_ERROR | E_CORE) ) // - Если ошибка $errno одна из этих
if( $errno & ( E_ALL ^ E_NOTICE ) ) // - Если любая ошибка кроме NOTICE итд. Подробней ссылки на материалы я указал выше.

 

Powered by ExBB FM 1.0 RC1