zoukankan      html  css  js  c++  java
  • 调试应用程序(Debugging Applications)

     

    调试应用程序(Debugging Applications)

    ../_images/xdebug-1.jpg

    Phalcon中提供了提供了几种调试级别即通知,错误和异常。 异常类 Exception class 提供了错误发生时的一些常用的调试信息如文件,行,消息,错误代码,跟踪信息等。 Phalcon主要使用这个异常类来包装这些功能,以方便开发者或用户使用。

    尽管Phalcon是使用C语言书写的,但其依然如其它的PHP框架般提供了一些必须的调试工具,PHP本身提供的调试工具亦然可以正常使用。

    捕获异常(Catching Exceptions)

    纵观Phalcon的文档及其提供的例子程序, 有一个最直接的捕获异常的方法即是使用try/catch块:

    <?php
    
    try {
    
        // ... Some Phalcon/PHP code
    
    } catch (Exception $e) {
    
    }
    

    try/catch块内发生的异常会被捕获然后放入 $e 变量。 开发者可以使用 PhalconException (扩展自 Exception class )来确定异常信息是来自Phalcon还是PHP本身。 PHP产生的所有异常都是基于 Exception class , 且至少含有如下元素:

    <?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 )
    }
    

    如从 Exception class 中取得异常信息一样, 我也可以从 PhalconException 中取异常信息。

    <?php
    
    try {
    
        // ... App code ...
    
    } catch (Exception $e) {
        echo get_class($e), ": ", $e->getMessage(), "
    ";
        echo " File=", $e->getFile(), "
    ";
        echo " Line=", $e->getLine(), "
    ";
        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]: PhalconDbAdapterPdo->connect(Array)
    #2 /Applications/MAMP/htdocs/invo/public/index.php(74):
        PhalconDbAdapterPdo->__construct(Array)
    #3 [internal function]: {closure}()
    #4 [internal function]: call_user_func_array(Object(Closure), Array)
    #5 [internal function]: PhalconDi->_factory(Object(Closure), Array)
    #6 [internal function]: PhalconDi->get('db', Array)
    #7 [internal function]: PhalconDi->getShared('db')
    #8 [internal function]: PhalconMvcModel->getConnection()
    #9 [internal function]: PhalconMvcModel::_getOrCreateResultset('Users', Array, true)
    #10 /Applications/MAMP/htdocs/invo/app/controllers/SessionController.php(83):
        PhalconMvcModel::findFirst('email='demo@pha...')
    #11 [internal function]: SessionController->startAction()
    #12 [internal function]: call_user_func_array(Array, Array)
    #13 [internal function]: PhalconMvcDispatcher->dispatch()
    #14 /Applications/MAMP/htdocs/invo/public/index.php(114): PhalconMvcApplication->handle()
    #15 {main}
    

    从上面我们可以看到异常信息中有Phalcon的类及方法,甚至调用时的参数也显示了出来。 如果需要可以使用 Exception::getTrace 获取更多的信息。

    调试组件(Debug component)

    Phalcon提供的调试组件可以使开发者更容易的定位代码中的错误。

    下面的视频中展示了如何工作的:

    要打开调试功能只需要如下做:

    <?php
    
    $debug = new PhalconDebug();
    $debug->listen();
    

    注意一定要去掉Try/Catch块才可以, 否则异常信息不会正确的输出(事实上很多时候Phalco显示异常信息是非常耗时的)。

    反射与内省(Reflection and Introspection)

    Phalcon的类的实例通常比一般的类实例更复杂。 这里我们可以使用 ‘Reflection API’_ (反射机制) 或 直接打印其内部状态来观其究竟:

    <?php
    
    $router = new PhalconMvcRouter();
    print_r($router);
    

    开发者可以非常容易的观察到对象内部的状态。 上面的代码输出如下:

    PhalconMvcRouter Object
    (
        [_dependencyInjector:protected] =>
        [_module:protected] =>
        [_controller:protected] =>
        [_action:protected] =>
        [_params:protected] => Array
            (
            )
        [_routes:protected] => Array
            (
                [0] => PhalconMvcRouterRoute 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] => PhalconMvcRouterRoute 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(Using XDebug)

    XDebug 是一个非常好(神奇)的调试工具,其和PHP内部调试工具一起为我们提调试工具(可以和PHP内置的调试工具互补)。 XDebug 也是一个PHP扩展, 所以二者可以一起使用,而且不需要额外的配置。

    下面的视频中展示了Phalcon中使用XDebug的情况:

    一旦安装了xdebug, 开发者便可以使用其API来取得更多的异常信息和其它信息:

    我们强烈推荐至少使用XDebug 2.2.3 以提供与Phalcon最佳的兼容性。

    下面的例子中调用了 xdebug_print_function_stack 方法, 并返回了该方法产生的代码跟踪结果:

    <?php
    
    use PhalconMvcController;
    
    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. PhalconMvcApplication->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 documentation ( XDebug 文档)。

  • 相关阅读:
    Window7下手动编译最新版的PCL库
    C和C++中的异常处理
    队列之卡片游戏
    C/C++笔记
    最真的梦——文/林清玄
    库函数与系统调用的区别
    hdu2653之BFS
    使用ffmpeg+crtmpserver搭建文件的伪直播
    ZOJ3705:Applications
    c_c++基础问题(平时读书时笔记)
  • 原文地址:https://www.cnblogs.com/php-rearch/p/6603961.html
Copyright © 2011-2022 走看看