網站首頁 編程語言 正文
前言
主要針對目前線上短信被腳本惡意盜刷的情況,用Redis實現滑動窗口限流
public void checkCurrentWindowValue(String telNum) { String windowKey = CommonConstant.getNnSmsWindowKey(telNum); //獲取當前時間戳 long currentTime = System.currentTimeMillis(); //1小時,默認只能發5次,參數smsWindowMax做成可配置項,配置到Nacos配置中心,可以動態調整 if (RedisUtil.hasKey(windowKey)) { //參數smsWindowTime表示限制的窗口時間 //這里獲取當前時間與限制窗口時間之間的短信發送次數 Optional<Long> optional = Optional.ofNullable(RedisUtil.zCount(windowKey, currentTime - smsWindowTime, currentTime)); if (optional.isPresent()) { long count = optional.get(); if (count >= smsWindowMax) { log.error("==========>當前號碼:{} 短信發送太頻繁,{}", telNum, count); throw new ServiceException(MidRetCode.umid_10060); } } } StringBuilder sb =new StringBuilder(); String windowEle = sb.append(telNum).append(":").append(currentTime).toString(); //添加當前發送元素到zSet中(由于保證元素唯一,這里將元素加上了當前時間戳) RedisUtil.zAdd(windowKey, windowEle, currentTime); //設置2倍窗口Key:windowKey 的過期時間 RedisUtil.expire(windowKey, smsWindowTime*2, TimeUnit.MILLISECONDS); }
補充:下面看下以php語言為例基于redis實現滑動窗口式的短信發送接口限流
滑動窗口短信發送限流算法
1.有兩條規則
基于IP的限制和基于手機號的限制
IP規則:
1分鐘限制5
10分鐘限制30
1小時限制50
手機號規則:
1分鐘限制1
10分鐘限制5
1小時限制10
2.滑動窗口就是隨著時間的流動 , 進行動態的刪減區間內的數據 , 限制時獲取區間內的數據
最主要的是用到了redis的zRemRangeByScore來進行刪除區間外的數據
<?php /*滑動窗口短信發送限流算法 1.有兩條規則 基于IP的限制和基于手機號的限制 IP規則: 1分鐘限制5 10分鐘限制30 1小時限制50 手機號規則: 1分鐘限制1 10分鐘限制5 1小時限制10 */ //IP規則 $ipRules=array( 60=>5, 600=>30, 3600=>50 ); //手機號規則 $phoneRules=array( 60=>1, 600=>5, 3600=>10 ); $r = checkLimits($ipRules,$_SERVER["REMOTE_ADDR"],$_GET['tel']); var_dump($r); $r = checkLimits($phoneRules,$_GET['tel'],$_GET['tel']); var_dump($r); function checkLimits($rules,$key,$tel){ $redis = new Redis(); $redis->connect('115.159.28.111', 1991); foreach($rules as $ruleTime=>$rule) { $redisKey=$key."_".$ruleTime; $score=time(); $member=$tel.'_'.$score; $redis->multi(); $redis->zRemRangeByScore($redisKey, 0, $score - $ruleTime);//移除窗口以外的數據 $redis->zAdd($redisKey, $score, $member); $redis->expire($redisKey, $ruleTime); $redis->zRange($redisKey, 0, -1, true); $members = $redis->exec(); if (empty($members[3])) { break; } $nums=count($members[3]); var_dump($nums); if($nums>$rule){ return false; } } return true; }
原文鏈接:https://www.cnblogs.com/july-sunny/p/15874026.html
- 上一篇:C語言?指針數組進階詳解_C 語言
- 下一篇:C語言各種操作符透徹理解上篇_C 語言
相關推薦
- 2022-07-16 遠程管理常用命令(ipconfig、ping等)
- 2022-01-26 maatwebsite/Excel 導入 iconv (): Detected an illegal
- 2022-05-02 python庫h5py入門詳解_python
- 2022-12-05 python中的單下劃線與雙下劃線以及絕對導入與相對導入_python
- 2022-07-12 解決錯誤:Cannot resolve symbol ‘JdbcTemplate‘
- 2022-06-19 docker容器非root用戶提權的問題解決_docker
- 2022-03-15 C語言if選擇結構語句詳解_C 語言
- 2022-08-20 解決WPF繪制矢量圖形模糊的問題_C#教程
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支