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…
});