Laravel 调试利器 laravel-debugbar

2019-11-08  本文已影响0人  夏天Dee枫

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…
});
上一篇下一篇

猜你喜欢

热点阅读