1、业务场景
业务开发中,常常涉及对前端操作进行重复校验,避免重复提交造成数据重复操作。比如转账操作,因为网络卡顿,客户连续点击转账按钮,造成多次转成;又比如,连点"核保"操作,如果不做限制,核保通过,如有积分下发功能,有可能会重复下发积分。
2、基础解决方案
通常,我们在数据库层面进行数据校验,但是并发操作下,并不理想。
3、解决方案
本文,使用redis,实现对重复提交进行判断和阻止。
实现代码:
return new DataVO<>("已经提交核保"); String key = "checkInsurance_" + orderId; String flag = stringRedisTemplate.opsForValue().get(key); log.error("前段连续提交核保,已被阻止orderId:{},userId:{}", orderId, userId); return new DataVO<>("您连续提交核保,请3分钟后再试"); stringRedisTemplate.opsForValue().set(key, "1"); stringRedisTemplate.expire(key, 180, TimeUnit.SECONDS); stringRedisTemplate.delete(key);
|