jeecg限制用户访问次数

该代码实现了一个基于Redis的访问限制策略,通过记录用户在一小时内访问接口的次数,防止恶意点击或爬虫攻击。当访问次数超过100次且在30分钟内时,返回不可访问。此外,提供了优化版本,利用Redis的List数据结构存储时间戳,确保在限制次数和间隔时间内有效控制访问。

jeecg限制用户访问次数

**防止客户恶意点击或者爬虫不断访问接口对接口进行次数限制**
*版本1 超过一定时间内次数不到指定次数返回不可访问,会产生一定时间内连续点击,只要不超过100次*
	public class RedisCountUtils {
   
   
    private static final Logger logger = LoggerFactory.getLogger(RedisCountUtils.class);

    // 30分钟
    public static final long MORE_TIME = 30 * 60 * 1000; // 30分钟
    public static final long EXPIRE_TIME = 60 * 60 * 1000; // 1个小时
    public static final int VISITS_TIME = 100; // 次数
    // 5分钟
    public static final long SAVE_TIME = 5 * 60 * 1000; // 30分钟

    /**
     * 每个人一个小时内最多访问100次接口 【版本1】
     *
     * @param message 判断缓存的KEy值
     * @param redisUtil redis工具类
     * @return
     */
    public static boolean CheckVisitsCount(RedisUtil redisUtil,String message) {
   
   
        if (oConvertUtils.isEmpty(message)) {
   
   
            return false;
        }
        // 访问次数
        int limitCount = 0;
        // 获取保存得时间戳
        Object obj = redisUtil.hget(CommonConstant.CSOM_CHECK + message, message);
        // 保存次数得key值 Item项
        String limitCountKey = "LIMIT_COUNT"+message;
        String limitCountItem = message+"_limitCount";
        // 获取保存得key值
        if (redisUtil.hget(limitCountKey,limitCountItem) == null) {
   
   
            limitCount = 1; //记录第一次
        } else {
   
   
        	// 获取缓存保存的次数
            limitCount = (int
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值