feat: 添加记录操作日志功能

This commit is contained in:
2025-03-10 16:21:49 +08:00
parent 2e7c0887ea
commit 58892cf612
5 changed files with 95 additions and 3 deletions

View File

@@ -51,6 +51,7 @@ class ExceptionHandle extends Handle
public function render($request, Throwable $e): Response public function render($request, Throwable $e): Response
{ {
// 添加自定义异常处理机制 // 添加自定义异常处理机制
$request->exception_info = $e;
// 其他错误交给系统处理 // 其他错误交给系统处理
return parent::render($request, $e); return parent::render($request, $e);

View File

@@ -4,4 +4,5 @@ return [
// 登录验证 // 登录验证
app\admin\middleware\v1\Auth::class, app\admin\middleware\v1\Auth::class,
app\admin\middleware\v1\RequestId::class, app\admin\middleware\v1\RequestId::class,
app\admin\middleware\v1\OperateLog::class,
]; ];

View File

@@ -0,0 +1,53 @@
<?php
declare (strict_types = 1);
namespace app\admin\middleware\v1;
use app\admin\model\v1\SysOperateLog;
class OperateLog
{
/**
* 处理请求
*
* @param \think\Request $request
* @param \Closure $next
* @return Response
*/
public function handle($request, \Closure $next)
{
$response = $next($request);
$log = [
'user_id' => $request->uid,
'title' => '操作日志',
'version' => $request->layer(),
'method' => $request->method(),
'controller' => $request->controller(base: true),
'action' => $request->action(),
'url' => $request->url(),
'ip' => $request->ip(),
'params' => json_encode($request->param()),
'status' => $response->getCode()
];
if (empty($request->exception_info)) {
// 记录正常返回信息
$contentDisposition = $response->getHeader('Content-Disposition');
if (!empty($contentDisposition) && \think\helper\Str::startsWith($contentDisposition, 'attachment')) {
$log['message'] = $contentDisposition;
} else {
$log['message'] = $response->getData();
if (is_array($log['message'])) {
$log['message'] = json_encode($log['message'], JSON_UNESCAPED_UNICODE);
}
}
} else {
// 记录异常返回信息
$log['message'] = (string)$request->exception_info;
}
SysOperateLog::create($log);
return $response;
}
}

View File

@@ -0,0 +1,35 @@
<?php
declare (strict_types = 1);
namespace app\admin\model\v1;
use think\Model;
/**
* @mixin \think\Model
*/
class SysOperateLog extends Model
{
// 表名
protected $name = 'sys_operate_log';
// 主键
protected $pk = 'id';
// 字段信息
protected $schema = [
'id' => 'int',
'user_id' => 'int',
'title' => 'string',
'version' => 'string',
'method' => 'string',
'controller' => 'string',
'action' => 'string',
'url' => 'string',
'ip' => 'string',
'params' => 'string',
'status' => 'int',
'message' => 'string',
'created_at' => 'datetime'
];
}

View File

@@ -1,5 +1,6 @@
<?php <?php
use Phinx\Db\Adapter\MysqlAdapter;
use think\migration\Migrator; use think\migration\Migrator;
class CreateSysOperateLog extends Migrator class CreateSysOperateLog extends Migrator
@@ -31,14 +32,15 @@ class CreateSysOperateLog extends Migrator
$table = $this->table('sys_operate_log', ['engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '操作日志表']); $table = $this->table('sys_operate_log', ['engine' => 'InnoDB', 'collation' => 'utf8mb4_general_ci', 'comment' => '操作日志表']);
$table->addColumn('user_id', 'integer', ['limit' => 11, 'default' => 0, 'comment' => '用户ID']) $table->addColumn('user_id', 'integer', ['limit' => 11, 'default' => 0, 'comment' => '用户ID'])
->addColumn('title', 'string', ['limit' => 50, 'default' => '', 'comment' => '标题']) ->addColumn('title', 'string', ['limit' => 50, 'default' => '', 'comment' => '标题'])
->addColumn('version', 'string', ['limit' => 15, 'default' => '', 'comment' => '版本'])
->addColumn('method', 'string', ['limit' => 10, 'default' => '', 'comment' => '请求方式'])
->addColumn('controller', 'string', ['limit' => 50, 'default' => '', 'comment' => '控制器']) ->addColumn('controller', 'string', ['limit' => 50, 'default' => '', 'comment' => '控制器'])
->addColumn('action', 'string', ['limit' => 50, 'default' => '', 'comment' => '方法']) ->addColumn('action', 'string', ['limit' => 50, 'default' => '', 'comment' => '方法'])
->addColumn('url', 'string', ['limit' => 255, 'default' => '', 'comment' => 'URL']) ->addColumn('url', 'string', ['limit' => 255, 'default' => '', 'comment' => 'URL'])
->addColumn('ip', 'string', ['limit' => 50, 'default' => '', 'comment' => 'IP']) ->addColumn('ip', 'string', ['limit' => 50, 'default' => '', 'comment' => 'IP'])
->addColumn('method', 'string', ['limit' => 10, 'default' => '', 'comment' => '请求方式'])
->addColumn('params', 'text', ['comment' => '请求参数']) ->addColumn('params', 'text', ['comment' => '请求参数'])
->addColumn('status', 'boolean', ['limit' => 1, 'default' => 1, 'comment' => '状态 1成功 0失败']) ->addColumn('status', MysqlAdapter::PHINX_TYPE_SMALL_INTEGER, ['limit' => 5, 'default' => 200, 'comment' => '状态'])
->addColumn('message', 'string', ['limit' => 255, 'default' => '', 'comment' => '消息']) ->addColumn('message', MysqlAdapter::PHINX_TYPE_TEXT, ['default' => null, 'comment' => '消息'])
->addColumn('created_at', 'timestamp', ['null' => false, 'default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间']) ->addColumn('created_at', 'timestamp', ['null' => false, 'default' => 'CURRENT_TIMESTAMP', 'comment' => '创建时间'])
->create(); ->create();
} }