可用于PHP Hyperf的计数器限流组件(安装配置)

可用于PHP Hyperf的计数器限流组件(安装配置),第1张

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

说明

BETA

移植了 Laravel Cache 组件的 rate-limiter.

并对 \Psr\SimpleCache\CacheInterface 进行了补充. 增加了以下方法:

incrementdecrementaddput

安装

composer require wilbur-yu/hyperf-cache-ext

配置

1. 修改cache配置文件:

'default' => [    'driver' => WilburYu\HyperfCacheExt\Driver\RedisDriver::class,    'packer' => WilburYu\HyperfCacheExt\Utils\Packer\PHPSerializerPacker::class,    'prefix' => env('APP_name', 'skeleton').':cache:',],'limiter' => [    'max_attempts' => 5,  // 最大允许次数    'decay_minutes' => 1, // 限流单位时间    'prefix' => 'counter-rate-limit:', // key 前缀    'for' => [        'common' => static function (\Hyperf\httpServer\Contract\RequestInterface $request) {            return limit::perMinute(3);        },    ],    'key' => ThrottleRequest::key(),],
for 即对应 Laravel Facade Ratelimiter::for(callable),

在服务启动时, 监听器会收集该命名限制器数组, 供在注解中使用 for 参数引用. 在注解切面执行时, 会将当前请求 \Hyperf\httpServer\Contract\RequestInterface 实例注入到该命名闭包.

key 默认为当前请求 fullUrl + ip. 支持字符串与闭包.

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

\WilburYu\HyperfCacheExt\Exception\Handler\CounterRatelimitException::class

可选, 也可自行捕获, 该异常自带一个 getheaders 方法, 值为: array(‘X-Ratelimit-limit’, ‘X-Ratelimit-Remaining’, ‘Retry-After’, ‘X-Ratelimit-reset’)

使用

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

#[CounterRatelimitWithRedis(maxAttempts: 5, decayMinutes: 1)]or#[CounterRatelimit(for: "common")]

注解参数同配置文件, 优先级为注解>配置>默认.
使用 for 时, max_attemptsdecay_minutes 不起作用.

如果你的缓存驱动不是 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的计数器限流组件(安装配置)全部内容,希望文章能够帮你解决可用于PHP Hyperf的计数器限流组件(安装配置)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/langs/1008664.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存