Отладка Приложений

PHP предлагает инструменты для отладки приложений с уведомлениями, предупреждениями, ошибками и исключениями. Класс Exception предоставляет такие сведения, как файл, строка, сообщение, числовой код, трассировка и т. д. о том, где произошла ошибка. Платформы ООП, такие как Phalcon, в основном используют этот класс для инкапсуляции этой функциональности и предоставления информации разработчику или пользователю.

Несмотря на то, что Phalcon написан на C, он выполняет методы в пользовательской среде PHP, обеспечивая отладочные возможности, которые есть у любого другого приложения или фреймворка, написанного на PHP.

Перехват Исключений

Во всех учебниках и примерах документации Phalcon есть общий элемент, перехватывающий исключения. Это блок try / catch:

<?php

try {

    // ... Некоторый Phalcon/PHP код

} catch (\Exception $e) {

}

 

Любое исключение, выданное внутри блока, записывается в переменную $e.   Phalcon\Exception расширяет класс PHP Exception и используется, чтобы понять, пришло ли исключение из Phalcon или самого PHP.

Все исключения, генерируемые PHP, основаны на классе Exception, и имеют по крайней мере следующие элементы:

<?php

class Exception
{

    /* Properties */
    protected string $message;
    protected int $code;
    protected string $file;
    protected int $line;

    /* Methods */
    public __construct ([ string $message = '' [, int $code = 0 [, Exception $previous = NULL ]]])
    final public string getMessage ( void )
    final public Exception getPrevious ( void )
    final public mixed getCode ( void )
    final public string getFile ( void )
    final public int getLine ( void )
    final public array getTrace ( void )
    final public string getTraceAsString ( void )
    public string __toString ( void )
    final private void __clone ( void )
}

Получение информации из Phalcon\Exception аналогично классу PHP Exception:

<?php

try {

    // ... Код приложения ...

} catch (\Exception $e) {
    echo get_class($e), ': ', $e->getMessage(), '\n';
    echo ' File=', $e->getFile(), '\n';
    echo ' Line=', $e->getLine(), '\n';
    echo $e->getTraceAsString();
}

Поэтому легко найти, какой файл и строка кода приложения сгенерировали исключение, а также компоненты, участвующие в создании исключения:

PDOException: SQLSTATE[28000] [1045] Access denied for user 'root'@'localhost'
    (using password: NO)
 File=/Applications/MAMP/htdocs/invo/public/index.php
 Line=74
#0 [internal function]: PDO->__construct('mysql:host=loca...', 'root', '', Array)
#1 [internal function]: Phalcon\Db\Adapter\Pdo->connect(Array)
#2 /Applications/MAMP/htdocs/invo/public/index.php(74):
    Phalcon\Db\Adapter\Pdo->__construct(Array)
#3 [internal function]: {closure}()
#4 [internal function]: call_user_func_array(Object(Closure), Array)
#5 [internal function]: Phalcon\Di->_factory(Object(Closure), Array)
#6 [internal function]: Phalcon\Di->get('db', Array)
#7 [internal function]: Phalcon\Di->getShared('db')
#8 [internal function]: Phalcon\Mvc\Model->getConnection()
#9 [internal function]: Phalcon\Mvc\Model::_getOrCreateResultset('Users', Array, true)
#10 /Applications/MAMP/htdocs/invo/app/controllers/SessionController.php(83):
    Phalcon\Mvc\Model::findFirst('email='demo@pha...')
#11 [internal function]: SessionController->startAction()
#12 [internal function]: call_user_func_array(Array, Array)
#13 [internal function]: Phalcon\Mvc\Dispatcher->dispatch()
#14 /Applications/MAMP/htdocs/invo/public/index.php(114): Phalcon\Mvc\Application->handle()
#15 {main}

Как вы можете видеть из приведенного выше вывода классы и методы Phalcon отображаются так же, как и любой другой компонент, и даже показывает параметры, которые были вызваны в каждом вызове. Exception::getTrace предоставляет дополнительные сведения при необходимости.

Отладочный компонент

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

Следующий скринкаст объясняет, как это работает:

Чтобы включить его, добавьте в bootstrap следующее:

<?php

$debug = new \Phalcon\Debug();
$debug->listen();

Любые блоки Try/Catch должны быть удалены или отключены, чтобы заставить этот компонент работать должным образом.

Отражение и самоанализ

Любой экземпляр класса Phalcon предлагает точно такое же поведение, что и обычный PHP. Можно использовать Reflection API или просто распечатать любой объект, чтобы показать, как его внутреннее состояние:

<?php

$router = new Phalcon\Mvc\Router();
print_r($router);

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

Phalcon\Mvc\Router Object
(
    [_dependencyInjector:protected] =>
    [_module:protected] =>
    [_controller:protected] =>
    [_action:protected] =>
    [_params:protected] => Array
        (
        )
    [_routes:protected] => Array
        (
            [0] => Phalcon\Mvc\Router\Route Object
                (
                    [_pattern:protected] => #^/([a-zA-Z0-9\_]+)[/]{0,1}$#
                    [_compiledPattern:protected] => #^/([a-zA-Z0-9\_]+)[/]{0,1}$#
                    [_paths:protected] => Array
                        (
                            [controller] => 1
                        )

                    [_methods:protected] =>
                    [_id:protected] => 0
                    [_name:protected] =>
                )

            [1] => Phalcon\Mvc\Router\Route Object
                (
                    [_pattern:protected] => #^/([a-zA-Z0-9\_]+)/([a-zA-Z0-9\_]+)(/.*)*$#
                    [_compiledPattern:protected] => #^/([a-zA-Z0-9\_]+)/([a-zA-Z0-9\_]+)(/.*)*$#
                    [_paths:protected] => Array
                        (
                            [controller] => 1
                            [action] => 2
                            [params] => 3
                        )
                    [_methods:protected] =>
                    [_id:protected] => 1
                    [_name:protected] =>
                )
        )
    [_matchedRoute:protected] =>
    [_matches:protected] =>
    [_wasMatched:protected] =>
    [_defaultModule:protected] =>
    [_defaultController:protected] =>
    [_defaultAction:protected] =>
    [_defaultParams:protected] => Array
        (
        )
)

С Помощью Xdebug

XDebug это удивительный инструмент, который дополняет отладку PHP-приложений. Это также расширение C для PHP, и вы можете использовать его вместе с Phalcon без дополнительных настроек или побочных эффектов.

В следующем скринкасте показан сеанс Xdebug с Phalcon:

После установки xdebug можно использовать его API для получения более подробной информации об исключениях и сообщениях.

Следующий пример реализует xdebug_print_function_stack, чтобы остановить казнь и создать протокол сбоя:

<?php

use Phalcon\Mvc\Controller;

class SignupController extends Controller
{
    public function indexAction()
    {

    }

    public function registerAction()
    {
        // Request variables from HTML form
        $name  = $this->request->getPost('name', 'string');
        $email = $this->request->getPost('email', 'email');

        // Stop execution and show a backtrace
        return xdebug_print_function_stack('stop here!');

        $user        = new Users();
        $user->name  = $name;
        $user->email = $email;

        // Store and check for errors
        $user->save();
    }
}

В этом случае Xdebug также покажет нам переменные в локальной области и обратную трассировку:

Xdebug: stop here! in /Applications/MAMP/htdocs/tutorial/app/controllers/SignupController.php
    on line 19

Call Stack:
    0.0383     654600   1. {main}() /Applications/MAMP/htdocs/tutorial/public/index.php:0
    0.0392     663864   2. Phalcon\Mvc\Application->handle()
        /Applications/MAMP/htdocs/tutorial/public/index.php:37
    0.0418     738848   3. SignupController->registerAction()
        /Applications/MAMP/htdocs/tutorial/public/index.php:0
    0.0419     740144   4. xdebug_print_function_stack()
        /Applications/MAMP/htdocs/tutorial/app/controllers/SignupController.php:19

Xdebug предоставляет несколько способов получения отладочной и трассировочной информации о выполнении вашего приложения с помощью Phalcon. Дополнительные сведения можно найти в документации XDebug.