撤銷訂單
應(yīng)用場景
支付交易返回失敗或支付系統(tǒng)超時,調(diào)用該接口撤銷交易。如果此訂單用戶支付失敗,微信支付系統(tǒng)會將此訂單關(guān)閉;如果用戶支付成功,微信支付系統(tǒng)會將此訂單資金退還給用戶。
注意:7天以內(nèi)的交易單可調(diào)用撤銷,其他正常支付的單如需實現(xiàn)相同功能請調(diào)用申請退款A(yù)PI。提交支付交易后調(diào)用【查詢訂單API】,沒有明確的支付結(jié)果再調(diào)用【撤銷訂單API】。
調(diào)用支付接口后請勿立即調(diào)用撤銷訂單API,建議支付后至少15s后再調(diào)用撤銷訂單接口。接口地址
https://apihk.mch.weixin.qq.com/secapi/pay/reverse (建議接入點:東南亞)
https://apius.mch.weixin.qq.com/secapi/pay/reverse (建議接入點:其它)
https://api.mch.weixin.qq.com/secapi/pay/reverse (建議接入點:中國國內(nèi))
注:商戶可根據(jù)實際請求情況選擇最優(yōu)域名進(jìn)行訪問,建議在接入時做好兼容,當(dāng)訪問其中一個域名出現(xiàn)異常時,可自動切換為其他域名。
是否需要證書
請求需要雙向證書。 詳見證書使用
請求參數(shù)
字段名 | 變量名 | 類型 | 必填 | 示例值 | 描述 |
---|---|---|---|---|---|
公眾賬號ID | appid | String(32) | 是 | wx8888888888888888 | 微信分配的公眾賬號ID(企業(yè)號corpid即為此appId) |
商戶號 | mch_id | String(32) | 是 | 1900000109 | 微信支付分配的商戶號 |
微信訂單號 | transaction_id | String(32) | 否 | 1217752501201407033233368018 | 微信的訂單號,優(yōu)先使用 |
商戶訂單號 | out_trade_no | String(32) | 是 | 1217752501201407033233368018 | 商戶系統(tǒng)內(nèi)部的訂單號,transaction_id、out_trade_no二選一,如果同時存在優(yōu)先級:transaction_id> out_trade_no |
隨機(jī)字符串 | nonce_str | String(32) | 是 | 5K8264ILTKCH16CQ2502SI8ZNMTM67VS | 隨機(jī)字符串,不長于32位。推薦隨機(jī)數(shù)生成算法 |
簽名 | sign | String(32) | 是 | C380BEC2BFD727A4B6845133519F3AD6 | 簽名,詳見簽名生成算法 |
簽名類型 | sign_type | 否 | String(32) | HMAC-SHA256 | 簽名類型,目前支持HMAC-SHA256和MD5,默認(rèn)為MD5 |
提交參數(shù)舉例如下:
<xml>
? ?<appid>wx2421b1c4370ec43b</appid>
? ?<mch_id>10000100</mch_id>
? ?<nonce_str>b7ffb16a7150cf08639db472c5f5bdae</nonce_str>
? ?<out_trade_no>1415717424</out_trade_no>
? ?<sign>9B2EA16C05A5CEF8E53B14D53932D012</sign>
</xml>
返回結(jié)果
字段名 | 變量名 | 類型 | 必填 | 示例值 | 描述 |
---|---|---|---|---|---|
返回狀態(tài)碼 | return_code | String(16) | 是 | SUCCESS | SUCCESS/FAIL,此字段是通信標(biāo)識,非交易標(biāo)識,交易是否成功需要查看result_code來判斷 |
返回信息 | return_msg | String(128) | 否 | 簽名失敗 | 返回信息,如非空,為錯誤原因;簽名失敗;具體某個參數(shù)格式校驗錯誤. |
當(dāng)return_code為SUCCESS的時候,還會包括以下字段:
字段名 | 變量名 | 類型 | 必填 | 示例值 | 描述 |
---|---|---|---|---|---|
公眾賬號ID | appid | String(32) | 是 | wx8888888888888888 | 返回提交的公眾賬號ID |
商戶號 | mch_id | String(32) | 是 | 1900000109 | 返回提交的商戶號 |
隨機(jī)字符串 | nonce_str | String(32) | 是 | 5K8264ILTKCH16CQ2502SI8ZNMTM67VS | 微信返回的隨機(jī)字符串 |
簽名 | sign | String(32) | 是 | C380BEC2BFD727A4B6845133519F3AD6 | 返回數(shù)據(jù)的簽名,詳見簽名算法 |
業(yè)務(wù)結(jié)果 | result_code | String(16) | 是 | SUCCESS | SUCCESS/FAIL |
錯誤代碼 | err_code | String(32) | 否 | SYSTEMERROR | 詳細(xì)參見錯誤列表 |
錯誤描述 | err_code_des | String(128) | 否 | 系統(tǒng)錯誤 | 結(jié)果信息描述 |
是否重調(diào) | recall | String(1) | 是 | Y | 是否需要繼續(xù)調(diào)用撤銷,Y-需要,N-不需要 |
匯率 | rate | String(16) | 是 | 650000000 | 標(biāo)價幣種與支付幣種的兌換比例乘以10的8次方即為此值,例如美元兌換人民幣的比例為6.5,則rate=650000000 |
返回參數(shù)舉例如下:
? ?<return_code><![CDATA[SUCCESS]]></return_code>
? ?<return_msg><![CDATA[OK]]></return_msg>
? ?<appid><![CDATA[wx2421b1c4370ec43b]]></appid>
? ?<mch_id><![CDATA[10000100]]></mch_id>
? ?<nonce_str><![CDATA[o5bAKF3o2ypC8hwa]]></nonce_str>
? ?<sign><![CDATA[6F5080EDDD196FFCDE53F786BBB93899]]></sign>
? ?<result_code><![CDATA[SUCCESS]]></result_code>
? ?<recall><![CDATA[N]]></recall>
</xml>
錯誤碼
名稱 | 描述 | 原因 | 解決方案 |
---|---|---|---|
SYSTEMERROR | 接口返回錯誤 | 系統(tǒng)超時 | 請立即調(diào)用被掃訂單結(jié)果查詢API,查詢當(dāng)前訂單狀態(tài),并根據(jù)訂單的狀態(tài)決定下一步的操作。 |
INVALID_TRANSACTIONID | 無效transaction_id | 請求參數(shù)未按指引進(jìn)行填寫 | 參數(shù)錯誤,請重新檢查 |
PARAM_ERROR | 參數(shù)錯誤 | 請求參數(shù)未按指引進(jìn)行填寫 | 請根據(jù)接口返回的詳細(xì)信息檢查您的程序 |
REQUIRE_POST_METHOD | 請使用post方法 | 未使用post傳遞參數(shù) | 請檢查請求參數(shù)是否通過post方法提交 |
SIGNERROR | 簽名錯誤 | 參數(shù)簽名結(jié)果不正確 | 請檢查簽名參數(shù)和方法是否都符合簽名算法要求 |
REVERSE_EXPIRE | 訂單無法撤銷 | 訂單有7天的撤銷有效期,過期將不能撤銷 | 請檢查需要撤銷的訂單是否超過可撤銷有效期 |
INVALID_REQUEST | 無效請求 | 商戶系統(tǒng)異常導(dǎo)致 | 請檢查商戶權(quán)限是否異常、重復(fù)請求支付、證書錯誤、頻率限制等 |
TRADE_ERROR | 訂單錯誤 | 業(yè)務(wù)錯誤導(dǎo)致交易失敗 | 請檢查用戶賬號是否異常、被風(fēng)控、是否符合規(guī)則限制等 |
USERPAYING | 用戶支付中 | 用戶正在支付中的訂單不允許撤銷 | 用戶正在支付中的訂單不允許撤銷,請稍后再試 |