taravel/app/Http/Middleware/ThrottlePrompts.php
2024-11-13 16:26:27 +08:00

34 lines
813 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Cache\RateLimiter;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class ThrottlePrompts
{
protected RateLimiter $limiter;
public function __construct(RateLimiter $limiter)
{
$this->limiter = $limiter;
}
public function handle(Request $request, Closure $next): Response
{
$key = 'prompts:' . $request->user()->id;
if ($this->limiter->tooManyAttempts($key, 60)) { // 每分鐘 60 次
return response()->json([
'error' => '請求過於頻繁,請稍後再試。',
'retry_after' => $this->limiter->availableIn($key)
], 429);
}
$this->limiter->hit($key);
return $next($request);
}
}