laravel中throttle 是怎么使用的-icode9专业技术文章分享

2024/10/10 6:03:24

本文主要是介绍laravel中throttle 是怎么使用的-icode9专业技术文章分享,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

在 Laravel 中,节流(Throttle)是一个用于限制用户请求频率的功能。它可以防止恶意攻击或不必要的资源浪费。Laravel 提供了简单而有效的节流功能,可以应用于路由或控制器方法。

1. 使用节流中间件

Laravel 默认提供 throttle 中间件,可以通过以下步骤使用它。

1.1 在路由中应用 Throttle

可以在 routes/web.php 或 routes/api.php 文件中使用 throttle 中间件来限制请求速率。例如:

Route::middleware('throttle:60,1')->group(function () {
    Route::get('/api/some-endpoint', 'ApiController@someMethod');
});

PHP

在此例中,throttle:60,1 意味着每个 IP 地址每分钟最多可以发出 60 次请求。

1.2 定义节流规则

你可以按照格式 throttle:number,minutes 定义频率限制。在上面的例子中:

  • 60 是允许的请求次数。
  • 1 是时间单位(以分钟为单位)。

1.3 设置限流的用户组

你也可以为某些特定路由或用户群组定义更严格或更宽松的限制。例如:

Route::middleware(['throttle:10,1'])->group(function () {
    Route::get('/rate-limited', 'RateLimitedController@handle');
});

PHP

2. 自定义节流逻辑

如果你需要更复杂的限制逻辑,可以创建自己的中间件,但 Laravel 提供的 throttle 中间件通常已满足大多数需求。

2.1 创建自定义中间件

你可以使用 Artisan 命令创建一个新的中间件,例如:

php artisan make:middleware CustomThrottle

Bash

在 app/Http/Middleware/CustomThrottle.php 中,实现你的节流逻辑。例如:

namespace App\Http\Middleware;

use Closure;
use Illuminate\Support\Facades\RateLimiter;

class CustomThrottle
{
    public function handle($request, Closure $next)
    {
        $key = 'custom-throttle:' . $request->ip();

        if (RateLimiter::tooManyAttempts($key, 30)) {
            return response()->json(['message' => 'Too many requests.'], 429);
        }

        RateLimiter::hit($key, 60); // 每分钟最多30次请求

        return $next($request);
    }
}

PHP

记得在 Kernel.php 中将这个中间件注册到 $routeMiddleware 中:

protected $routeMiddleware = [
    // ...
    'custom.throttle' => \App\Http\Middleware\CustomThrottle::class,
];

PHP

然后在路由中使用它。

3. 处理节流响应

当达到请求限制时,将返回 HTTP 429 状态码(“Too Many Requests”)。你可以自定义该响应内容。可以在 CustomThrottle 中返回一个自定义的响应体。

总结

Laravel 提供了灵活的节流功能,允许开发者根据需求进行配置。你只需要在路由中使用 throttle 中间件设置所需的限流次数和时间即可。如果内置功能不满足需求,仍然可以创建自定义中间件来实现更复杂的需求。

标签: 来源:

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。



这篇关于laravel中throttle 是怎么使用的-icode9专业技术文章分享的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程