说明
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 FacadeRateLimiter::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-10-30 -
什么是网络协议?它包括哪些要素和内容? 时间:2025-10-30 -
简述Zookeeper的原理和作用 时间:2025-10-30 -
什么是ZooKeeper ZooKeeper是干什么的 ZooKeeper和Nacos的区别 时间:2025-10-30 -
集线器和交换机在原理,实现与使用上有哪些区别? 时间:2025-10-30 -
集线器和交换机的功能是什么?区别在哪? 时间:2025-10-30
今日更新
-
SKL币2026年价格预测 币安行情分析与投资策略指南
阅读:18
-
【SEO优化标题】
小婷是什么梗 揭秘网络热梗小婷的爆火原因和表情包出处
阅读:18
-
MANTA币2026年价格预测及欧易交易教程 项目前景分析
阅读:18
-
2026全球十大加密货币交易所排名 新手投资入门指南
阅读:18
-
狗头是什么梗?揭秘聊天神回复背后的幽默暗号,看完秒懂!
阅读:18
-
2026最佳加密货币交易平台排行 新手入门必看指南
阅读:18
-
**"摆烂娃是什么梗?揭秘年轻人躺平自嘲新潮流"**
(注:严格控制在48字内,符合百度SEO标题规范,用疑问句式吸引点击,关键词前置,突出热点话题和用户需求。)
阅读:18
-
2026年加密货币新手必选5大交易所 安全靠谱交易平台排名
阅读:18
-
重返未来3.2版本迁流的盛宴今日开启-海量活动来袭
阅读:18
-
2026年最佳虚拟币交易所排名 币圈用户必看指南
阅读:18










