1.使用compser引入package
composer require barryvdh/laravel-debugbar
2.config/app.php的providers中添加注冊服務(laravel 5.5在用了auto-discovery后不用添加)
Barryvdh\Debugbar\ServiceProvider::class
3.門面(可選)
#config/app.php中添加如下門面別名到 aliases數組:
'Debugbar' => Barryvdh\Debugbar\Facade::class,
#然后運行如下 Artisan 命令將該擴展包的配置文件拷貝到 config目錄下:
php artisan vendor:publish
如果配置文件中 debug設置為 true的話,Debugbar 分析器默認是啟的,如果你想要關閉該分析器,在配置文件 config/debugbar.php中設置 enab為 false即可。
使用 Debugbar 門面添加 PSR-3 級別消息:
Debugbar::info($object);Debugbar::error('Error!'); Debugbar::warning('Watch out…'); Debugbar::addMessage('Another message', 'mylabel');
設置開始/中止時間:
Debugbar::startMeasure('render','Time for rendering');
Debugbar::stopMeasure('render');
Debugbar::addMeasure('now', LARAVEL_START, microtime(true));
Debugbar::measure('My long operation', function() { // Do something…});
記錄異常:
try { throw new Exception('foobar'); } catch (Exception $e) { Debugbar::addException($e); }
使用輔助函數實現上述調用:
// All arguments will be dumped as a debug message 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… });
如果想要添加自己的數據收集器(DataCollector),可以通過容器或門面實現:
Debugbar::addCollector(new DebugBar\DataCollector\MessagesCollector('my_messages'));
或者通過 App 容器:
$debugbar = App::make('debugbar'); $debugbar->addCollector(new DebugBar\DataCollector\MessagesCollector('my_messages'));
默認情況下,Debugbar 被注入到 </body>之前。如果你想要自己注入 Debugbar,在其配置文件中設置 inject為 false然后使用渲染器自己渲染:
$renderer = Debugbar::getJavascriptRenderer();
注意:使用自動注入的話將會禁止顯示 Request 信息,因為在響應之后才會添加該信息。你可以通過在配置文件中添加 default_request數據收集器作為替換方案。
如果你想要在運行時開啟/關閉 Debugbar,可以通過如下方式:
\Debugbar::enable();\Debugbar::disable();
