本篇文章给大家介绍关于适用于 Hyperf 的计数器限流组件。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

说明

BETA

并对 PsrSimpleCacheCacheInterface 进行了补充. 增加了以下方法:

  • increment
  • decrement
  • add
  • put

安装

composer require wilbur-yu/hyperf-cache-ext
登录后复制

配置

1. 修改cache配置文件:

'default' => [
    'driver' => WilburYuHyperfCacheExtDriverRedisDriver::class,
    'packer' => WilburYuHyperfCacheExtUtilsPackerPhpSerializerPacker::class,
    'prefix' => env('APP_NAME', 'skeleton').':cache:',
],
'limiter' => [
    'max_attempts' => 5,  // 最大允许次数
    'decay_minutes' => 1, // 限流单位时间
    'prefix' => 'counter-rate-limit:', // key 前缀
    'for' => [
        'common' => static function (HyperfHttpServerContractRequestInterface $request) {
            return Limit::perMinute(3);
        },
    ],
    'key' => ThrottleRequest::key(),
],
登录后复制
  • for 即对应 Laravel Facade RateLimiter::for(callable),
  • key 默认为当前请求 fullUrl + ip. 支持字符串与闭包.

2. 在exceptions配置文件中增加:

WilburYuHyperfCacheExtExceptionHandlerCounterRateLimitException::class
登录后复制

使用

在控制器中使用计数器限速注解

#[CounterRateLimitWithRedis(maxAttempts: 5, decayMinutes: 1)]or#[CounterRateLimit(for: "common")]
登录后复制

如果你的缓存驱动不是 redis, 可以使用 CounterRateLimit 注解,反之则直接使用 CounterRateLimitWithRedis 注解即可.

在其他地方使用限速时, 可以使用辅助函数 counter_limiter(), 使用方法同 laravel中的 RateLimiter Facade, 可参考 Laravel 限流文档

$executed = counter_limiter()->attempt('send-sms:'.$user->id,2,function(){
    // send sms logic
});
if (!$executed) {
    return 'Too many messages sent!';
}
登录后复制

推荐学习:《PHP视频教程》

以上就是可用于PHP Hyperf的计数器限流组件(安装配置)的详细内容,更多请关注悠悠之家其它相关文章!

点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部