Files

47 lines
1.2 KiB
PHP
Raw Permalink Normal View History

<?php
// +----------------------------------------------------------------------
// | Author: ScottPan Team
// +----------------------------------------------------------------------
namespace crmeb\topthink;
use think\event\LogWrite;
class TraceDebug extends \think\trace\TraceDebug
{
/**
* @param \think\Request $request
* @param \Closure $next
* @return mixed|void
* @author 等风来
* @email 136327134@qq.com
* @date 2023/10/9
*/
public function handle($request, \Closure $next)
{
$debug = $this->app->config->get('trace.enable');
// 注册日志监听
if ($debug) {
$this->log = [];
$this->app->event->listen(LogWrite::class, function ($event) {
if (empty($this->config['channel']) || $this->config['channel'] == $event->channel) {
$this->log = array_merge_recursive($this->log, $event->log);
}
});
}
$response = $next($request);
// Trace调试注入
if ($debug) {
$data = $response->getContent();
$this->traceDebug($response, $data);
$response->content($data);
}
return $response;
}
}