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