<kbd id="5sdj3"></kbd>
<th id="5sdj3"></th>

  • <dd id="5sdj3"><form id="5sdj3"></form></dd>
    <td id="5sdj3"><form id="5sdj3"><big id="5sdj3"></big></form></td><del id="5sdj3"></del>

  • <dd id="5sdj3"></dd>
    <dfn id="5sdj3"></dfn>
  • <th id="5sdj3"></th>
    <tfoot id="5sdj3"><menuitem id="5sdj3"></menuitem></tfoot>

  • <td id="5sdj3"><form id="5sdj3"><menu id="5sdj3"></menu></form></td>
  • <kbd id="5sdj3"><form id="5sdj3"></form></kbd>

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

    共 1235字,需瀏覽 3分鐘

     ·

    2021-04-18 23:53

    程序員的成長之路
    互聯(lián)網(wǎng)/程序員/技術(shù)/資料共享 
    關(guān)注


    閱讀本文大概需要 2 分鐘。

    來自: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ù)相同的操作
    附上微信支付最佳實踐:
    PS:如果覺得我的分享不錯,歡迎大家隨手點贊、在看。
    <END>

    推薦閱讀:

    聊一聊我在 B 站上自學(xué)編程的經(jīng)歷吧

    SQL語句中 left join 后用 on 還是 where,區(qū)別大了!

    5T技術(shù)資源大放送!包括但不限于:C/C++,Linux,Python,Java,PHP,人工智能,單片機,樹莓派,等等。在公眾號內(nèi)回復(fù)「2048」,即可免費獲取?。?/span>

    微信掃描二維碼,關(guān)注我的公眾號

    朕已閱 

    瀏覽 70
    點贊
    評論
    收藏
    分享

    手機掃一掃分享

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

    手機掃一掃分享

    分享
    舉報

    <kbd id="5sdj3"></kbd>
    <th id="5sdj3"></th>

  • <dd id="5sdj3"><form id="5sdj3"></form></dd>
    <td id="5sdj3"><form id="5sdj3"><big id="5sdj3"></big></form></td><del id="5sdj3"></del>

  • <dd id="5sdj3"></dd>
    <dfn id="5sdj3"></dfn>
  • <th id="5sdj3"></th>
    <tfoot id="5sdj3"><menuitem id="5sdj3"></menuitem></tfoot>

  • <td id="5sdj3"><form id="5sdj3"><menu id="5sdj3"></menu></form></td>
  • <kbd id="5sdj3"><form id="5sdj3"></form></kbd>
    青青草国产免费无码欧美 | 一节A片在线视频免费 | 懂色av蜜臀av粉嫩av分 麻豆的视频高清在线观看完整 | 污污在线无码 | 大鸡巴久久 |