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 () {
        //
    });
});
相關文章
相關標籤/搜索