可用于PHP Hyperf的计数器限流组件(安装配置)
说明
BETA
移植了 Laravel Cache 组件的 rate-limiter.
并对 \Psr\SimpleCache\CacheInterface
进行了补充. 增加了以下方法:
- increment
- decrement
- add
- put
安装
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_attempts
和decay_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视频教程》
-
英雄联盟手游乐斗赛季什么时候出-乐斗赛季时间 时间:2025-05-09
-
VBoxManage的基本用法和常见命令 时间:2025-05-09
-
Kraken地址证明怎么证明?Kraken地址证明认证教程完全版 时间:2025-05-09
-
VBoxManage的基本用法和常见命令 时间:2025-05-09
-
Service Control Manager出错如何处理? 时间:2025-05-09
-
金铲铲之战s14恭喜发财佛耶戈阵容要如何搭配_金铲铲之战s14恭喜发财佛耶戈要怎么过渡 时间:2025-05-09
今日更新
-
《卧龙吟2》七擒孟获战役快速通关技巧
阅读:18
-
编写PHP MVC框架【保姆级教程推荐】
阅读:18
-
实例讲解MVC架构的含义及职责划分
阅读:18
-
opporeno7在哪开启录音云同步
阅读:18
-
《皇帝成长计划2》外国臣子如何获取
阅读:18
-
PHP也可以实现词法分析与自定义语言!
阅读:18
-
PHPSpreadsheet导出Excel列数超过26报错怎么办?
阅读:18
-
《枪火重生手游》元素异常效果有什么
阅读:18
-
PHP遇见Serverless,帮你解决这些痛点!
阅读:18
-
《皇帝成长计划2》精力增加攻略2022
阅读:18