SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能
本文主要介紹如何使用AOP實(shí)現(xiàn)IP黑名單功能
主要涉及三個(gè)類
- 注解類
- 切面實(shí)現(xiàn)類
- Controller類
注解類
在注解中包含了幾個(gè)檢測(cè)參數(shù)
@Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface IPBlackList { int maxRequests() default 10; // 最大請(qǐng)求次數(shù) long timeWindow() default 60000L; // 計(jì)數(shù)時(shí)間窗口,單位:毫秒 long blockTime() default 60000L; // 拉黑時(shí)間,單位:毫秒 }
切面實(shí)現(xiàn)
在doBefore方法中我調(diào)了自己的工具類不過就是一個(gè)獲取請(qǐng)求ip的方法,還有我過濾了內(nèi)網(wǎng)ip,如果不需要可以去掉。
@Aspect @Component public class IPBlackListAspect { private final Map<String, List<Long>> requestTimes = new ConcurrentHashMap<>(); private final Map<String, Long> blackList = new ConcurrentHashMap<>(); @Before(value = "@annotation(ipBlackList)") public void doBefore(IPBlackList ipBlackList) { String clientIP = ServletUtils.getClientIP(); if (StringUtils.isBlank(clientIP)) { return; } // 內(nèi)網(wǎng)不查詢 clientIP = StringUtils.contains(clientIP, "0:0:0:0:0:0:0:1") ? "127.0.0.1" : HtmlUtil.cleanHtmlTag(clientIP); if (NetUtil.isInnerIP(clientIP)) { return; } int maxRequests = ipBlackList.maxRequests(); long timeWindow = ipBlackList.timeWindow(); long blockTime = ipBlackList.blockTime(); long currentTime = System.currentTimeMillis(); // 檢查 IP 是否在黑名單中 if (blackList.containsKey(clientIP)) { long blacklistedAt = blackList.get(clientIP); if (currentTime - blacklistedAt < blockTime) { throw new RuntimeException("IP 已被拉黑,請(qǐng)稍后再試"); } else { blackList.remove(clientIP); // 移除過期的黑名單記錄 blackList.remove(clientIP); // 重置計(jì)時(shí) } } // 獲取該 IP 的訪問記錄并清除超過時(shí)間窗口的記錄 List<Long> times = requestTimes.getOrDefault(clientIP, new CopyOnWriteArrayList<>()); times.removeIf(time -> currentTime - time > timeWindow); times.add(currentTime); // 記錄當(dāng)前訪問時(shí)間 requestTimes.put(clientIP, times); // 檢查在時(shí)間窗口內(nèi)的請(qǐng)求次數(shù) if (times.size() > maxRequests) { blackList.put(clientIP, currentTime); // 拉黑 IP throw new RuntimeException("請(qǐng)求次數(shù)過多,IP 已被拉黑"); } } }
Controller
只要在Http請(qǐng)求方法上加上上面定義的注解就可以
@RestController() @RequestMapping("/auth/auth") public class YunfuAuthController { @Resource private IYunfuAuthService yunfuAuthService; @PostMapping @SaIgnore @IPBlackList public R<YunfuAuthVo> auth(YunfuAuthBo bo){ return R.ok(yunfuAuthService.auth(bo)); } }
后言
到此這篇關(guān)于SpringBoot3利用AOP實(shí)現(xiàn)IP黑名單功能的文章就介紹到這了,更多相關(guān)SpringBoot3 IP黑名單內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Cloud?Gateway中netty線程池優(yōu)化示例詳解
這篇文章主要介紹了Spring?Cloud?Gateway中netty線程池優(yōu)化示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07Java StringBuilder和StringBuffer源碼分析
這篇文章主要針對(duì)Java中兩個(gè)常用的操作字符串的類 StringBuilder和StringBuffer進(jìn)行源碼分析,感興趣的小伙伴們可以參考一下2016-01-01java?中的HashMap的底層實(shí)現(xiàn)和元素添加流程
這篇文章主要介紹了java?中的HashMap的底層實(shí)現(xiàn)和元素添加流程,HashMap?是使用頻率最高的數(shù)據(jù)類型之一,同時(shí)也是面試必問的問題之一,尤其是它的底層實(shí)現(xiàn)原理,下文更多詳細(xì)內(nèi)容,需要的小伙伴可以參考一下2022-05-05