fyre/ratelimiter
最新稳定版本:v5.0.8
Composer 安装命令:
composer require fyre/ratelimiter
包简介
A rate limiter library.
README 文档
README
FyreRateLimiter is a free, open-source rate limiting library for PHP.
Table Of Contents
Installation
Using Composer
composer require fyre/ratelimiter
In PHP:
use Fyre\Security\RateLimiter;
Basic Usage
$containeris a Container.$cacheManageris a CacheManager.$optionsis an array containing options for the RateLimiter.cacheConfigis a string representing the configuration key for the Cache, and will default to "ratelimiter".limitis a number representing the maximum number of requests that can be made within the period, and will default to 60.periodis a number representing the number of seconds per rate limiting period, and will default to 60.messageis a string representing the rate limit error message, and will default to "Rate limit exceeded".headersis an array containing the rate limit headers.limitis a string representing the rate limit header, and will default to "X-RateLimit-Limit".remainingis a string representing the rate limit remaining header, and will default to "X-RateLimit-Remaining".resetis a string representing the rate limit reset header, and will default to "X-RateLimit-Reset".
identifieris a Closure that accepts a ServerRequest as the first argument, and should return a string representing the client identifier.skipCheckis a Closure that accepts a ServerRequest as the first argument, and can return true to skip rate limit checks for the request.errorRendereris a Closure that accepts a ServerRequest and a ClientResponse as the arguments, and should return a ClientResponse.
$limiter = new RateLimiter($container, $cacheManager, $options);
If the cacheConfig doesn't exist in the CacheManager, a default FileCacher will be created instead.
If the identifier callback is omitted, it will default to using the $_SERVER['REMOTE_ADDR'].
If the errorRenderer callback is omitted, it will default to negotiating a json or plaintext response containing the message option.
Autoloading
Any dependencies will be injected automatically when loading from the Container.
$limiter = $container->use(RateLimiter::class, ['options' => $options]);
Methods
Add Headers
Add rate limit headers to a ClientResponse.
$responseis a ClientResponse.
$response = $limiter->addHeaders($response);
Check Limit
Determine whether the rate limit has been reached for a request.
$requestis the ServerRequest.
$result = $limiter->checkLimit($request);
Error Response
Generate an error response.
$requestis the ServerRequest.
$response = $limiter->errorResponse($request);
Middleware
use Fyre\Security\Middleware\RateLimiterMiddleware;
$containeris a Container.$optionsis an array containing options for the RateLimiter.cacheConfigis a string representing the configuration key for the Cache, and will default to "ratelimiter".limitis a number representing the maximum number of requests that can be made within the period, and will default to 60.periodis a number representing the number of seconds per rate limiting period, and will default to 60.messageis a string representing the rate limit error message, and will default to "Rate limit exceeded".headersis an array containing the rate limit headers.limitis a string representing the rate limit header, and will default to "X-RateLimit-Limit".remainingis a string representing the rate limit remaining header, and will default to "X-RateLimit-Remaining".resetis a string representing the rate limit reset header, and will default to "X-RateLimit-Reset".
identifieris a Closure that accepts a ServerRequest as the first argument, and should return a string representing the client identifier.skipCheckis a Closure that accepts a ServerRequest as the first argument, and can return true to skip rate limit checks for the request.errorRendereris a Closure that accepts a ServerRequest and a ClientResponse as the arguments, and should return a ClientResponse.
$middleware = new RateLimiterMiddleware($container, $options);
Any dependencies will be injected automatically when loading from the Container.
$middleware = $container->build(RateLimiterMiddleware::class, ['options' => $options]);
Handle
Handle a ServerRequest.
$requestis a ServerRequest.$nextis a Closure.
$response = $middleware->handle($request, $next);
This method will return a ClientResponse.
统计信息
- 总下载量: 20
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-08-18