An article explaining in detail how to use throttle middleware in laravel8
This article will give you relevant knowledge about Laravel and throttle middleware. The main content is to teach you how to use the throttle middleware in laravel8. Let’s take a look together. I hope it will be helpful to you!
laravle8 Access restriction throttle middleware
throttle middleware introduction
Frequency limits are often used in APIs for Limit the frequency of requests to a specific API by an independent requester. Each API chooses its own frequency limit time span, GitHub chooses 1 hour, and the Laravel middleware chooses 1 minute.
For example: throttle:60,1, that is, set the frequency limit to 60 times per minute. If an IP exceeds this limit within one minute, the server will return a 429 Too Many Attempts. response. [Recommended learning: laravel video tutorial]
Using throttle middleware in laravel8
We usually use throttle middleware here. Make a rate limit with certain conditions, for example, limit the number of accesses per minute for IPs that are not in the IP whitelist. Compared with before, the throttle middleware in laravel8 has a simpler method of use.
First we can see that there is such a definition in the Kernel.php file
/** * 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, ];
It is obvious that the 'throttle' defined in laravel8 => \Illuminate\Routing\Middleware\ ThrottleRequests::class, has been defined by the framework, and the throttle:api is used in the api.
Of course, the general usage may be to comment out throttle:api here, create a new throttle middleware or directly use throttle:60,1 in routing.
What if I need to make some complex judgments, for example, I have many IP whitelists that I want to exclude without rate limit, or what if there is a VVVIP user who does not limit the rate?
At this time, we can find the App\Providers\RouteServiceProvider.php file in laravel8. At the bottom of the file we can see this writing
/** * 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()); }); }
The api defined here is the above in Kernel The throttle:api used in the .php file. Here, we can set custom rate limiting conditions, for example, limiting access to IPs outside the user IP whitelist to 60 times per hour, and the whitelist can access 1,000 times each time
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()); } });
Of course not Forgot to create a new ip.php file in the config folder
return [ 'whitelist' => [ '192.168.0.1', ], ];
:heart: Warm reminder: When using api interface routing, if you want to use a custom throttle:apiHour, don’t forget to change the original Comment out throttle:api in Kernel.php!
Finally we can happily use custom rate control middleware in routing
Route::group([ 'middleware' => ['throttle:apiHour'] ], function ($router) { Route::get('user', function (Request $request) { return $request->user(); }); });
The above is my summary of the problems of using custom throttle raters in laravel8. If you have any questions , you can make corrections at any time, thank you students for watching!
This article is reprinted, original address: https://learnku.com/articles/73728
The above is the detailed content of An article explaining in detail how to use throttle middleware in laravel8. For more information, please follow other related articles on the PHP Chinese website!

Laravelcanbeeffectivelyusedinreal-worldapplicationsforbuildingscalablewebsolutions.1)ItsimplifiesCRUDoperationsinRESTfulAPIsusingEloquentORM.2)Laravel'secosystem,includingtoolslikeNova,enhancesdevelopment.3)Itaddressesperformancewithcachingsystems,en

Laravel's core functions in back-end development include routing system, EloquentORM, migration function, cache system and queue system. 1. The routing system simplifies URL mapping and improves code organization and maintenance. 2.EloquentORM provides object-oriented data operations to improve development efficiency. 3. The migration function manages the database structure through version control to ensure consistency. 4. The cache system reduces database queries and improves response speed. 5. The queue system effectively processes large-scale data, avoid blocking user requests, and improve overall performance.

Laravel performs strongly in back-end development, simplifying database operations through EloquentORM, controllers and service classes handle business logic, and providing queues, events and other functions. 1) EloquentORM maps database tables through the model to simplify query. 2) Business logic is processed in controllers and service classes to improve modularity and maintainability. 3) Other functions such as queue systems help to handle complex needs.

The Laravel development project was chosen because of its flexibility and power to suit the needs of different sizes and complexities. Laravel provides routing system, EloquentORM, Artisan command line and other functions, supporting the development of from simple blogs to complex enterprise-level systems.

The comparison between Laravel and Python in the development environment and ecosystem is as follows: 1. The development environment of Laravel is simple, only PHP and Composer are required. It provides a rich range of extension packages such as LaravelForge, but the extension package maintenance may not be timely. 2. The development environment of Python is also simple, only Python and pip are required. The ecosystem is huge and covers multiple fields, but version and dependency management may be complex.

How does Laravel play a role in backend logic? It simplifies and enhances backend development through routing systems, EloquentORM, authentication and authorization, event and listeners, and performance optimization. 1. The routing system allows the definition of URL structure and request processing logic. 2.EloquentORM simplifies database interaction. 3. The authentication and authorization system is convenient for user management. 4. The event and listener implement loosely coupled code structure. 5. Performance optimization improves application efficiency through caching and queueing.

Laravel's popularity includes its simplified development process, providing a pleasant development environment, and rich features. 1) It absorbs the design philosophy of RubyonRails, combining the flexibility of PHP. 2) Provide tools such as EloquentORM, Blade template engine, etc. to improve development efficiency. 3) Its MVC architecture and dependency injection mechanism make the code more modular and testable. 4) Provides powerful debugging tools and performance optimization methods such as caching systems and best practices.

Both Django and Laravel are full-stack frameworks. Django is suitable for Python developers and complex business logic, while Laravel is suitable for PHP developers and elegant syntax. 1.Django is based on Python and follows the "battery-complete" philosophy, suitable for rapid development and high concurrency. 2.Laravel is based on PHP, emphasizing the developer experience, and is suitable for small to medium-sized projects.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Dreamweaver Mac version
Visual web development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Chinese version
Chinese version, very easy to use

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool