• 新增订单如何防止重复提交


            上篇文章写了幂等性防抖防止重复提交,可以有效阻止连续不停的点击提交,但是现在出现了一个情况,因为网络慢或者后台服务器慢导致提交的数据处理返回超时,等了大概1分钟甚至几分钟之后的提交,幂等性防抖就不起作用,订单生成多次。

           为了解决这个问题,我在进入订单页面就请求了一个UUID,除非是重新进入该页面UUID不会变动,然后提交时候带着这个UUID去请求,如果REIDS中该UUID存在那么判断重复请求,不存在那么后台接受到了将UUID存入REDIS中,如果处理失败那么还是要移除这个KEY。

    参考代码如下:

    1. String key= MessageFormat.format("INSERT:HYKCZD:{0}:{1}",vo.getTenantId(),vo.getDjbh());
    2. if(redisService.haskey(key)) throw new BusinessException("本页面请求已处理,请勿重复提交");
    3. redisService.setCacheObject(key,vo.getZdr()+"-"+getDateTime(),7, TimeUnit.DAYS);
    4. PosVipCzsz czsz=czszMapper.selectById(vo.getCzszId());
    5. if(czsz.getType()==0){
    6. vo.setJe1(czsz.getJe2());
    7. vo.setJe2(czsz.getJe());
    8. vo.setJe3(czsz.getJe1());
    9. }else{
    10. validObjectParam(vo, VpczdVO.class, "je2","je3");
    11. Double je1=add(vo.getJe2(), vo.getJe3());
    12. vo.setJe1(je1);
    13. }
    14. String host=getHost(),url="pos/vpczd/cz",json= JSON.toJSONString(vo);
    15. JsonResult jsonResult= doGetJsonResult$post(host, url, json);
    16. if(!jsonResult.isSuccess()) {
    17. redisService.deleteObject(key);
    18. throw new DataIntefaceException(jsonResult.getMsg());
    19. }
    20. return 1;

  • 相关阅读:
    java -- abstract
    MySQL高级篇之索引的使用
    JSP pageContext对象
    CDH CDH 13Cloudera Manager Console FreeIPA 用户规划(markdown新版)
    websocket
    N-S图(盒图)
    【Docker-k8s学习和实战】(四)Docker生命周期 && 利用docker实现在CentOS上再运行三种不同的操作系统
    NPM 常用命令(七)
    Javascript知识【案例:表格隔行换色】
    流量抓取工具(wireshark)
  • 原文地址:https://blog.csdn.net/chengmin123456789/article/details/124712060