美文网首页
Laravel 调试利器 laravel-debugbar

Laravel 调试利器 laravel-debugbar

作者: 夏天Dee枫 | 来源:发表于2019-11-08 17:12 被阅读0次

    1. 简介

    这是一个将PHP Debug Bar与Laravel 5 集成的软件包。它包括一个ServiceProvider,用于注册调试栏并将其附加到输出。您可以发布资产并通过Laravel对其进行配置。它引导一些收集器与Laravel一起使用,并实现了几个特定于Laravel的自定义DataCollectors。它被配置成显示的重定向和(jQuery的)Ajax的请求。

    debugbar.png

    注意:仅在开发中使用DebugBar。这可能会使应用程序变慢(因为它必须收集数据)。因此,在遇到速度缓慢时,请尝试禁用某些收集器。

    2. 安装

    composer require barryvdh/laravel-debugbar:~3.2.8 --dev
    

    安装完成后,在 config/app.php 中注册服务提供者到 providers 数组(laravel5.5及以上版本会自动注册)。

    //注册如下服务提供者:
    Barryvdh\Debugbar\ServiceProvider::class,
    //添加如下门面别名到 aliases 数组:
    'Debugbar' => Barryvdh\Debugbar\Facade::class,
    

    然后运行如下 Artisan 命令将该扩展包的配置文件拷贝到 config 目录下:

    php artisan vendor:publish --provider="Barryvdh\Debugbar\ServiceProvider"
    

    在.env中开启APP_DEBUG

    APP_DEBUG=true
    

    最后chrome浏览器安装Laravel debugbar扩展

    3. 使用

    使用时注意Debugbar门面的添加是否正确,不然会出现方法未定义的错误。

    //错误
    Symfony \ Component \ Debug \ Exception \ FatalThrowableError (E_ERROR)
    Call to undefined method DebugBar\DebugBar::addMeasure()
    
    //修正
    use Barryvdh\Debugbar\Facade as Debugbar;
    

    使用 Debugbar 门面添加 PSR-3 级别消息:

    Debugbar::info($object);
    Debugbar::error('Error!');
    Debugbar::warning('Watch out…');
    Debugbar::addMessage('Another message', 'mylabel');//自定义标签,输出对应信息
    

    设置开始/中止时间:

    //以`Time for rendering`为标签,记录执行时间
    Debugbar::startMeasure('render','Time for rendering');
        //...do something
    Debugbar::stopMeasure('render');
    
    //记录从LARAVEL_START到now的执行时间
    Debugbar::addMeasure('now', LARAVEL_START, microtime(true));
    
    //记录闭包函数执行的时间
    Debugbar::measure('label-name', function() use ($request){
        // Do something…
    });
    

    记录异常:

    try {
        throw new Exception('foobar');
    } catch (Exception $e) {
        Debugbar::addException($e);
    }
    

    也可以辅助函数实现以上功能:

    debug($var1, $someString, $intValue, $object);
    start_measure('render','Time for rendering');
    stop_measure('render');
    add_measure('now', LARAVEL_START, microtime(true));
    measure('My long operation', function() {
        // Do something…
    });
    

    相关文章

      网友评论

          本文标题:Laravel 调试利器 laravel-debugbar

          本文链接:https://www.haomeiwen.com/subject/bylwbctx.html