一文詳解laravel8如何使用throttle中間件
這篇文章給大家Laravel和throttle中間件的相關知識,主要內容是教大家怎麼在 laravel8 中去使用 throttle 中間件的,下面一起來看看吧,希望對大家有所幫助!
laravle8 存取限制throttle 中介軟體
throttle 中介軟體介紹
頻率限制常用在API 中,用於限制獨立請求者對特定API 的請求頻率。每個 API 都會選擇一個自己的頻率限制時間跨度,GitHub 選擇的是 1 小時,Laravel 中介軟體選擇的是 1 分鐘。
例如:throttle:60,1,即設定頻率限制為每分鐘 60 次,如果一個 IP 一分鐘內超過這個限制,那麼伺服器就會傳回 429 Too Many Attempts. 回應。 【推薦學習:laravel影片教學】
在laravel8 使用throttle 中間件
我們通常在這裡一般會使用throttle 中介軟體來做一個限定條件的速率限定,比如說不在IP 白名單中的IP 限制一分鐘訪問多少次。相對於之前來說,laravel8 中的 throttle 中間件,有了更簡單的使用方法。
首先我們可以看到在Kernel.php 檔案中有這樣的定義
/** * The application's route middleware groups. * * @var array<string, array<int, class-string|string>> */ protected $middlewareGroups = [ 'web' => [ \App\Http\Middleware\EncryptCookies::class, \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, \Illuminate\Session\Middleware\StartSession::class, // \Illuminate\Session\Middleware\AuthenticateSession::class, \Illuminate\View\Middleware\ShareErrorsFromSession::class, \App\Http\Middleware\VerifyCsrfToken::class, \Illuminate\Routing\Middleware\SubstituteBindings::class, ], 'api' => [ // \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class, 'throttle:api', \Illuminate\Routing\Middleware\SubstituteBindings::class, ], ]; /** * The application's route middleware. * * These middleware may be assigned to groups or used individually. * * @var array<string, class-string|string> */ protected $routeMiddleware = [ 'auth' => \App\Http\Middleware\Authenticate::class, 'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, 'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class, 'can' => \Illuminate\Auth\Middleware\Authorize::class, 'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, 'password.confirm' => \Illuminate\Auth\Middleware\RequirePassword::class, 'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class, 'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, 'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class, ];
很明顯看到其實laravel8 中定義的'throttle' => \Illuminate\Routing\Middleware\ ThrottleRequests::class, 是框架已經定義好的,並且在api 中使用的是throttle:api。
當然,一般的大家的用法可能就是在這裡把 throttle:api 註解掉,新建一個 throttle 中間件或者是在路由中可以直接使用 throttle:60,1 這樣的。
那如果是需要做一些複雜的判斷,比如說我有很多個 IP 白名單想要排除掉,不做速率限制,或者是有個 VVVIP 用戶不限制速率的時候怎麼辦呢?
這時,我們可以在laravel8 中找到App\Providers\RouteServiceProvider.php 文件,在文件最下面我們可以看到這樣的寫法
/** * Configure the rate limiters for the application. * * @return void */ protected function configureRateLimiting() { RateLimiter::for('api', function (Request $request) { return Limit::perMinute(60)->by(optional($request->user())->id ?: $request->ip()); }); }
這裡定義的api 就是上面在Kernel .php 檔案中所使用的的throttle:api。在這裡,我們可以設定自訂的速率限制條件,比如說限制用戶IP 白名單之外的IP 訪問限制為每小時60 次,白名單每次可以訪問1000 次
RateLimiter::for('apiHour', function (Request $request) { if(!in_array($request->ip(), config('ip.whitelist'))){ return Limit::perHour(60)->by($request->ip()); }else{ return Limit::perHour(1000)->by($request->ip()); } });
當然別忘記在config 資料夾中新建ip.php 檔案
return [ 'whitelist' => [ '192.168.0.1', ], ];
:heart:溫馨提示:在使用的時候,用的是api 介面路由的話,如果想使用自訂的throttle:apiHour 不要忘記把原來Kernel.php 中的throttle:api 註解掉喲!
最後我們就可以在路由中快樂的使用自訂的速率控制中間件了
Route::group([ 'middleware' => ['throttle:apiHour'] ], function ($router) { Route::get('user', function (Request $request) { return $request->user(); }); });
以上就是我總結的laravel8 中使用自訂throttle 速率器的問題,如有問題,大家可以隨時指正,謝謝各位同學觀看!
#本文系轉載,原文網址:https://learnku.com/articles/73728
以上是一文詳解laravel8如何使用throttle中間件的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

本文討論了使用組件在Laravel中創建和自定義可重複使用的UI元素,從而為組織提供最佳實踐並建議增強包裝。

本文討論了Laravel中的創建和使用自定義刀片指令以增強模板。它涵蓋了定義指令,在模板中使用它們,並在大型項目中管理它們,強調了改進的代碼可重複性和R等好處

本文討論了Laravel中的創建和使用自定義驗證規則,提供了定義和實施的步驟。它突出了諸如可重複性和特異性之類的好處,並提供了擴展Laravel驗證系統的方法。

Laravel的工匠控制台可以自動化任務,例如生成代碼,運行遷移和調度。關鍵命令包括:控制器,遷移和DB:種子。可以為特定需求創建自定義命令,增強工作流效率。

文章討論了使用Laravel的路由來創建SEO友好的URL,涵蓋最佳實踐,規範的URL和SEO優化工具。WordCount:159

Django和Laravel都是全棧框架,Django適合Python開發者和復雜業務邏輯,Laravel適合PHP開發者和優雅語法。 1.Django基於Python,遵循“電池齊全”哲學,適合快速開發和高並發。 2.Laravel基於PHP,強調開發者體驗,適合小型到中型項目。

本文討論了使用Laravel中的數據庫交易來維持數據一致性,使用DB立面和雄辯模型的詳細方法,最佳實踐,異常處理以及用於監視和調試交易的工具。

本文討論了在Laravel中實施緩存以提高性能,使用緩存外觀,緩存標籤和原子操作涵蓋配置。它還概述了緩存配置的最佳實踐,並提出了用於緩存的數據類型
