<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

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

          共 1378字,需瀏覽 3分鐘

           ·

          2021-04-06 19:59


          上一篇:深夜看了張一鳴的微博,讓我越想越后怕

          來源:廢物大師兄
          地址:www.cnblogs.com/cjsblog/p/14516909.html

          如圖是一個簡化的下單流程,首先是提交訂單,然后是支付。

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

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

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

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

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

          2、支付中心這邊要自己定義一個超時時間(比如:30秒),在此時間范圍內(nèi)如果沒有收到支付成功回調(diào),則應(yīng)調(diào)用接口主動查詢支付結(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é)果通知時都要考慮接口冪等性,消息只處理一次,其余的忽略

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

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

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

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

          附上微信支付最佳實踐:



          感謝您的閱讀,也歡迎您發(fā)表關(guān)于這篇文章的任何建議,關(guān)注我,技術(shù)不迷茫!小編到你上高速。
              · END ·
          最后,關(guān)注公眾號互聯(lián)網(wǎng)架構(gòu)師,在后臺回復(fù):2T,可以獲取我整理的 Java 系列面試題和答案,非常齊全


          正文結(jié)束


          推薦閱讀 ↓↓↓

          1.不認(rèn)命,從10年流水線工人,到谷歌上班的程序媛,一位湖南妹子的勵志故事

          2.如何才能成為優(yōu)秀的架構(gòu)師?

          3.從零開始搭建創(chuàng)業(yè)公司后臺技術(shù)棧

          4.程序員一般可以從什么平臺接私活?

          5.37歲程序員被裁,120天沒找到工作,無奈去小公司,結(jié)果懵了...

          6.IntelliJ IDEA 2019.3 首個最新訪問版本發(fā)布,新特性搶先看

          7.漫畫:程序員相親圖鑒,笑屎我了~

          8.15張圖看懂瞎忙和高效的區(qū)別!

          一個人學(xué)習(xí)、工作很迷茫?


          點擊「閱讀原文」加入我們的小圈子!


          瀏覽 25
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  青娱乐青青草视频 | 久久人妻熟女中文字幕av蜜芽 | 日本a在线免费观看 | 囯产精品久久久久久久免牛肉蒲团 | 三级麻豆av |