This commit is contained in:
zimoyin
2026-04-03 11:32:19 +08:00
parent 4c841b9dbf
commit 1a84e92384
30 changed files with 403 additions and 1030 deletions
@@ -1,57 +0,0 @@
<?php
namespace plugin\admin\app\middleware;
use app\utils\Logger;
use plugin\admin\api\Auth;
use ReflectionException;
use support\exception\BusinessException;
use Webman\Http\Request;
use Webman\Http\Response;
use Webman\MiddlewareInterface;
/**
* 账户数据权限表
*/
class AccessDataControl implements MiddlewareInterface
{
/**
* @param Request $request
* @param callable $handler
* @return Response
* @throws ReflectionException|BusinessException
*/
public function process(Request $request, callable $handler): Response
{
// 获取当前登录的管理员
$admin = runCatching(fn() => admin(), "无法获取到管理员登录信息")->getOrNull();
$controller = $request->controller;
$action = $request->action;
$code = 0;
$msg = '';
if (!Auth::canAccess($controller, $action, $code, $msg)) {
if ($request->expectsJson()) {
$response = json(['code' => $code, 'msg' => $msg, 'data' => []]);
} else {
if ($code === 401) {
$response = admin_error_401_script();
} else {
$request->app = '';
$request->plugin = 'admin';
$response = view('common/error/403')->withStatus(403);
}
}
} else {
$response = $request->method() == 'OPTIONS' ? response('') : $handler($request);
}
return $response;
}
}
@@ -0,0 +1,50 @@
<?php
namespace plugin\admin\app\middleware;
use app\config\Config;
use app\utils\Logger;
use Webman\MiddlewareInterface;
use Webman\Http\Response;
use Webman\Http\Request;
/**
* 请求耗时监测中间件
* 记录从请求进入到响应返回的全流程耗时
*/
class RequestTimeMiddleware implements MiddlewareInterface
{
public function process(Request $request, callable $handler): Response
{
// 1. 请求进入时记录开始时间(微秒级,高精度)
$startTime = microtime(true);
if (Config::getInstance()->enableRequestTimeLog) {
Logger::debug("{} {}", [$request->method(), $request->fullUrl()]);
}
// 2. 执行后续中间件/控制器业务逻辑
$response = $handler($request);
if (Config::getInstance()->enableRequestTimeLog) {
// 3. 请求处理完成后计算耗时
$endTime = microtime(true);
$costTime = round(($endTime - $startTime) * 1000, 2); // 转换为毫秒,保留2位小数
// 获取请求信息(方便日志定位)
$requestMethod = $request->method();
$requestUrl = $request->fullUrl();
$clientIp = $request->getRealIp();
// 4. 打印耗时日志
Logger::debug("[请求耗时] {} {} | IP: {} | 耗时: {} ms", [
$requestMethod,
$requestUrl,
$clientIp,
$costTime
]);
}
// 5. 返回响应给客户端
return $response;
}
}