Выводим сообщения об ошибках PHP в оповещениях администратора

PHP используется во многих веб приложениях, например, в WordPress. Не смотря на мощные средства языка, PHP имеет некоторые недостатки. Один из самых существенных - вывод сообщений об ошибках прямо на веб странице. Панель инструментов WordPress 3.3 закрывает первые несколько строк на странице, что мешает разработчику в процессе отладки.

 

Новая панель инструментов в WordPress 3.3 имеет фиксированное абсолютное положение, которое покрывает первые несколько строк сообщений об ошибках PHP. Поэтому надо использовать другие опции для отладки тем и плагинов. Существует несколько различных вариантов.

 

Плагины

Так как новая панель инструментов мешает разработчику, то нужно использовать плагин, который ее отключит. Вот несколько плагинов для работы с панелью инструментов:

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

 

Запись сообщений об ошибках в журнал

Решение для работы с ошибками PHP, которое предлагает команда разработчиков WordPress, заключается в записи сообщений в журнал. Если вы уже разрабатывали что-нибудь для WordPress, то наверняка уже знаете про константу WP_DEBUG, которая определяется в файле wp-config.php. Также можно определить константу WP_DEBUG_LOG. Вот пример из WordPress Codex для разрешения записи отладочной информации в журнал:

define('WP_DEBUG', true); 
if (WP_DEBUG) {
  define('WP_DEBUG_LOG', true);
  define('WP_DEBUG_DISPLAY', false);
  @ini_set('display_errors',0);
}

После выполнения данного кода сообщения об ошибках PHP будут выводиться в файл debug.log в папке wp-content. Запись сообщений об ошибках в журнал имеет свои плюсы и минусы. При работе над коммерческим плагином, когда над продуктом трудится команда, ведение журнала просто необходимо. Но когда масштаб разработок невелик, журнал превращается в обузу. Постоянное необходимость повторного открытия файла журнала при каждом небольшом изменении быстро утомит даже терпеливого педанта.

 

Вывод сообщений об ошибках в виде администраторского оповещения.

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

Для использования такой возможности нужно задействовать очень простой код, который нужно разместить в файле functions.php или в вашем плагине:

function admin_alert_errors($errno, $errstr, $errfile, $errline){

	$errorType = array (
		 E_ERROR 							=> 'ERROR',
		 E_CORE_ERROR     		=> 'CORE ERROR',
		 E_COMPILE_ERROR  		=> 'COMPILE ERROR',
		 E_USER_ERROR     		=> 'USER ERROR',
		 E_RECOVERABLE_ERROR  => 'RECOVERABLE ERROR',
		 E_WARNING        		=> 'WARNING',
		 E_CORE_WARNING   		=> 'CORE WARNING',
		 E_COMPILE_WARNING 		=> 'COMPILE WARNING',
		 E_USER_WARNING   		=> 'USER WARNING',
		 E_NOTICE         		=> 'NOTICE',
		 E_USER_NOTICE    		=> 'USER NOTICE',
		 E_DEPRECATED					=> 'DEPRECATED',
		 E_USER_DEPRECATED		=> 'USER_DEPRECATED',
		 E_PARSE          		=> 'PARSING ERROR'
	);

	if (array_key_exists($errno, $errorType)) {
		$errname = $errorType[$errno];
	} else {
		$errname = 'UNKNOWN ERROR';
	}
ob_start();?>
<div class="error">
  <p>
  	<strong><?php echo $errname; ?> Error: [<?php echo $errno; ?>] </strong><?php echo $errstr; ?><strong> <?php echo $errfile; ?></strong> on line <strong><?php echo $errline; ?></strong>
  <p/>
</div>
<?php
echo ob_get_clean();
}

set_error_handler("admin_alert_errors", E_ERROR ^ E_CORE_ERROR ^ E_COMPILE_ERROR ^ E_USER_ERROR ^ E_RECOVERABLE_ERROR ^  E_WARNING ^  E_CORE_WARNING ^ E_COMPILE_WARNING ^ E_USER_WARNING ^ E_NOTICE ^  E_USER_NOTICE ^ E_DEPRECATED	^  E_USER_DEPRECATED	^  E_PARSE );

Есть четыре аргумента, которые передаются в функцию admin_alert_errors():

  • $errno : номер типа ошибки;
  • $errstr : сообщение об ошибке;
  • $errfile : имя фала, в котором произошла ошибка;
  • $errline : номер строки, содержащей ошибку.

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

Выражение IF проверяет соответствие типа ошибки в значениям из массива $errorType. Если соответствий нет, то будет выводиться “UNKNOWN ERROR” (данное название тоже можно поменять).

Последняя часть функции формирует вывод. Класс error встроен в WordPress и используется для определения стиля для сообщений об ошибках.

Для запуска функции  admin_alert_errors() нужно использовать функцию set_error_handler(). Первый параметр определяет функцию для вывода ошибки. Второй параметр определяет набор констант ошибок PHP? которые будут выводиться.

Если у вас есть опыт работы с ошибками, то вы обратите внимание, что E_STRICT не включена в набор. Причина заключается в том, что некоторые ошибки генерируются ядром WordPress. Является ли данный факт недоработкой команды WordPress или хитрой особенностью дизайна неизвестно, но необходимости в них нет. Если использовать константу E_ALL вместо списка, то выводиться как администраторское оповещение будут не все ошибки.

Примечание: Данный способ не влияет на отображение ошибок на сайте и действует только в панели администратора.

Примечание 2: При использовании данных может появляться ошибка DEPRECATED(не рекомендуется, устаревший вариант) для некоторых фалов.

Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/xDnVoY69qd4/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

Выводим сообщения об ошибках PHP в оповещениях администратора | | 2012-06-19 12:00:17 | | Статьи Web-мастеру | | PHP используется во многих веб приложениях, например, в WordPress. Не смотря на мощные средства языка, PHP имеет некоторые недостатки. Один из самых существенных - вывод сообщений об ошибках прямо на | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: