1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        服務(wù)端如何防止重復(fù)支付

        共 1487字,需瀏覽 3分鐘

         ·

        2021-12-26 00:12

        1、五年工作經(jīng)驗(yàn)總結(jié) 16 條的代碼規(guī)范
        2、突發(fā)!Apache Log4j2 報(bào)核彈級漏洞
        3、都在建議你不要直接使用 @Async 注解,為什么?
        4、面試官:拋開Spring來說,如何自己實(shí)現(xiàn)Spring AOP?
        5、藍(lán)綠發(fā)布、滾動(dòng)發(fā)布、灰度發(fā)布,有什么區(qū)別?這下明白了

        概述

        如圖是一個(gè)簡化的下單流程,首先是提交訂單,然后是支付。支付的話,一般是走支付網(wǎng)關(guān)(支付中心),然后支付中心與第三方支付渠道(微信、支付寶、銀聯(lián))交互,支付成功以后,異步通知支付中心,支付中心更新自身支付訂單狀態(tài),再通知業(yè)務(wù)應(yīng)用,各業(yè)務(wù)再更新各自訂單狀態(tài)。

        這個(gè)過程中經(jīng)??赡苡龅降膯栴}是掉單,無論是超時(shí)未收到回調(diào)通知也好,還是程序自身報(bào)錯(cuò)也好,總之由于各種各樣的原因,沒有如期收到通知并正確的處理后續(xù)邏輯等等,都會(huì)造成用戶支付成功了,但是服務(wù)端這邊訂單狀態(tài)沒更新,這個(gè)時(shí)候有可能產(chǎn)生投訴,或者用戶重復(fù)支付。

        由于③⑤造成的掉單稱之為外部掉單,由④⑥造成的掉單我們稱之為內(nèi)部掉單

        為了防止掉單,這里可以這樣處理:

        1、支付訂單增加一個(gè)中間狀態(tài)“支付中”,當(dāng)同一個(gè)訂單去支付的時(shí)候,先檢查有沒有狀態(tài)為“支付中”的支付流水,當(dāng)然支付(prepay)的時(shí)候要加個(gè)鎖。支付完成以后更新支付流水狀態(tài)的時(shí)候再講其改成“支付成功”狀態(tài)。

        2、支付中心這邊要自己定義一個(gè)超時(shí)時(shí)間(比如:30秒),在此時(shí)間范圍內(nèi)如果沒有收到支付成功回調(diào),則應(yīng)調(diào)用接口主動(dòng)查詢支付結(jié)果,比如10s、20s、30s查一次,如果在最大查詢次數(shù)內(nèi)沒有查到結(jié)果,應(yīng)做異常處理

        3、支付中心收到支付結(jié)果以后,將結(jié)果同步給業(yè)務(wù)系統(tǒng),可以發(fā)MQ,也可以直接調(diào)用,直接調(diào)用的話要加重試(比如:SpringBoot Retry)

        4、無論是支付中心,還是業(yè)務(wù)應(yīng)用,在接收支付結(jié)果通知時(shí)都要考慮接口冪等性,消息只處理一次,其余的忽略

        5、業(yè)務(wù)應(yīng)用也應(yīng)做超時(shí)主動(dòng)查詢支付結(jié)果

        對于上面說的超時(shí)主動(dòng)查詢可以在發(fā)起支付的時(shí)候?qū)⑦@些支付訂單放到一張表中,用定時(shí)任務(wù)去掃

        為了防止訂單重復(fù)提交,可以這樣處理:

        1、創(chuàng)建訂單的時(shí)候,用訂單信息計(jì)算一個(gè)哈希值,判斷redis中是否有key,有則不允許重復(fù)提交,沒有則生成一個(gè)新key,放到redis中設(shè)置個(gè)過期時(shí)間,然后創(chuàng)建訂單。其實(shí)就是在一段時(shí)間內(nèi)不可重復(fù)相同的操作

        附上微信支付最佳實(shí)踐:


        文章來源:https://cnblogs.com/cjsblog/p/14516909.html


        最近熱文閱讀:

        1、五年工作經(jīng)驗(yàn)總結(jié) 16 條的代碼規(guī)范
        2、為什么我勸你放棄了Restful API?
        3、Java8 Stream:2萬字20個(gè)實(shí)例,玩轉(zhuǎn)集合的篩選、歸約、分組、聚合
        4、公司規(guī)定所有接口都用 POST請求,這是為什么?
        5、為什么阿里強(qiáng)制 boolean 類型變量不能使用 is 開頭?
        6、面試官:InnoDB中一棵B+樹可以存放多少行數(shù)據(jù)?
        7、MyBatis批量插入幾千條數(shù)據(jù),請慎用foreach
        8、有了 for (;;) ,為什么還需要while (true) ?到底哪個(gè)更快?
        9、名企公開掛“加班真好”標(biāo)語,員工稱一年被免費(fèi)“白嫖”600多小時(shí)!網(wǎng)友看不下去了,稽查部門展開調(diào)查...
        10、面試官:為什么 Java 不把基本類型放在堆中?我竟然答不上來。。
        關(guān)注公眾號(hào),你想要的Java都在這里

        瀏覽 42
        點(diǎn)贊
        評論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        評論
        圖片
        表情
        推薦
        點(diǎn)贊
        評論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報(bào)
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            91成熟丰满女人少妇777 sm调教小sao货叫主人语录 | 国内精品成人 | cuckold系列夹精喂绿奴 | 免费看国产黄色 | 三级欧美韩日大片在线看 | 啊~我是sao货快cao我视频 | 天天射天天舔 | 国产高清无码免费在线观看 | 中国国产一级毛片 | 天天干夜夜操视频免费专区 |