new files
This commit is contained in:
54
pro_v3.5.1/crmeb/topthink/TraceDebug.php
Normal file
54
pro_v3.5.1/crmeb/topthink/TraceDebug.php
Normal file
@@ -0,0 +1,54 @@
|
||||
<?php
|
||||
/**
|
||||
* +----------------------------------------------------------------------
|
||||
* | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||||
* +----------------------------------------------------------------------
|
||||
* | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
|
||||
* +----------------------------------------------------------------------
|
||||
* | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||||
* +----------------------------------------------------------------------
|
||||
* | Author: CRMEB Team <admin@crmeb.com>
|
||||
* +----------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
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;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user