调用接口限制频率

本文讨论了验证码存在的破解风险,通过原子操作如Redis和Lua实现的分钟级别和天级别调用频率控制,以保护系统免受频繁攻击。伪代码展示了如何使用lua脚本管理过期时间和调用次数限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

适用场景:漏洞问题,主要是有些验证码通过随机数生成存在破解的可能。

原子操作:目前的处理逻辑主要是通过分钟级别和天级别的控制,多少分钟限制调用多少次,一天最多多少次,主要的是通过返回的值,判断是否超过限制次数。

伪代码逻辑:

        1.初始化天级别的时间控制,设置过期时间为一天,key:daylock主要通过redis+lua实现,lua如下:

if(redis.call('exists', KEYS[1]) ~= 1) then 
    redis.call('set', KEYS[1], tonumber(ARGV[1])) 
    redis.call('expire', KEYS[1], tonumber(ARGV[2]))
    return 1 
else 
    return -1 
end

        2.取出daylock的值,添加判断,根据不同的daylock的值,初始化分钟级别minutelock的过期时间

        3.然后初始化分钟级别的时间控制,lua和上面一样

        4.天级别和分钟级别的控制频率,通过lua判断,如下

if(redis.call('exists', KEYS[1]) ~= 1) then 
    return -2
elseif(tonumber(redis.call('get', KEYS[1])) >= tonumber(ARGV[1])) then 
    return -1
else 
    return redis.call('incr', KEYS[1]) 
end

        5.返回-1,即超过限制次数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值