laravel8更新之速率限制改进

原文地址:https://www.wjcms.net/archive...

Laravel的请求速率限制器功能已加强,具备更大的灵活性和功能,同时仍保持与先前版本的throttle中间件API的向后兼容性。
laravel

速率限制器是使用RateLimiter立面的for方法定义的。该for方法接受一个速率限制器名称和一个Closure,该Closure返回应应用于分配了该速率限制器的路由的限制配置:ide

use Illuminate\Cache\RateLimiting\Limit;
use Illuminate\Support\Facades\RateLimiter;

RateLimiter::for('global', function (Request $request) {
    return Limit::perMinute(1000);
});

因为速率限制器回调接收传入的HTTP请求实例,所以您能够根据传入的请求或通过身份验证的用户动态构建适当的速率限制:post

RateLimiter::for('uploads', function (Request $request) {
    return $request->user()->vipCustomer()
                ? Limit::none()
                : Limit::perMinute(100);
});

有时您可能但愿将速率限制按任意值进行细分。例如,您可能但愿容许用户每一个IP地址每分钟100次访问给定路由。为此,您能够by在创建速率限制时使用如下方法:spa

RateLimiter::for('uploads', function (Request $request) {
    return $request->user()->vipCustomer()
                ? Limit::none()
                : Limit::perMinute(100)->by($request->ip());
});

能够使用throttle 中间件将速率限制器附加到路由或路由组。油门中间件接受您但愿分配给路线的速率限制器的名称:.net

Route::middleware(['throttle:uploads'])->group(function () {
    Route::post('/audio', function () {
        //
    });

    Route::post('/video', function () {
        //
    });
});
相关文章
相关标签/搜索