定制 fyre/ratelimiter 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

  • $container is a Container.
  • $cacheManager is a CacheManager.
  • $options is an array containing options for the RateLimiter.
    • cacheConfig is a string representing the configuration key for the Cache, and will default to "ratelimiter".
    • limit is a number representing the maximum number of requests that can be made within the period, and will default to 60.
    • period is a number representing the number of seconds per rate limiting period, and will default to 60.
    • message is a string representing the rate limit error message, and will default to "Rate limit exceeded".
    • headers is an array containing the rate limit headers.
      • limit is a string representing the rate limit header, and will default to "X-RateLimit-Limit".
      • remaining is a string representing the rate limit remaining header, and will default to "X-RateLimit-Remaining".
      • reset is a string representing the rate limit reset header, and will default to "X-RateLimit-Reset".
    • identifier is a Closure that accepts a ServerRequest as the first argument, and should return a string representing the client identifier.
    • skipCheck is a Closure that accepts a ServerRequest as the first argument, and can return true to skip rate limit checks for the request.
    • errorRenderer is 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.

$response = $limiter->addHeaders($response);

Check Limit

Determine whether the rate limit has been reached for a request.

$result = $limiter->checkLimit($request);

Error Response

Generate an error response.

$response = $limiter->errorResponse($request);

Middleware

use Fyre\Security\Middleware\RateLimiterMiddleware;
  • $container is a Container.
  • $options is an array containing options for the RateLimiter.
    • cacheConfig is a string representing the configuration key for the Cache, and will default to "ratelimiter".
    • limit is a number representing the maximum number of requests that can be made within the period, and will default to 60.
    • period is a number representing the number of seconds per rate limiting period, and will default to 60.
    • message is a string representing the rate limit error message, and will default to "Rate limit exceeded".
    • headers is an array containing the rate limit headers.
      • limit is a string representing the rate limit header, and will default to "X-RateLimit-Limit".
      • remaining is a string representing the rate limit remaining header, and will default to "X-RateLimit-Remaining".
      • reset is a string representing the rate limit reset header, and will default to "X-RateLimit-Reset".
    • identifier is a Closure that accepts a ServerRequest as the first argument, and should return a string representing the client identifier.
    • skipCheck is a Closure that accepts a ServerRequest as the first argument, and can return true to skip rate limit checks for the request.
    • errorRenderer is 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.

$response = $middleware->handle($request, $next);

This method will return a ClientResponse.

统计信息

  • 总下载量: 20
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-08-18