Payment Result Notification
Update Time:2025.02.21After completing a payment, the WeChat payment system will send the relevant payment result and user information to the Merchant. When this happens, the Merchant’s backend will need to receive the result and return a reply to the WeChat payment system.
|
API intro
Request Url: This URL may be configured via notify_url, a parameter submitted via the 【Unified Order API】, If merchants can't open this URL, they will not be able to receive any notifications sent from the WeChat payment system.
Request Method: POST
Certificate Requirements: No certificate is required.
Developers can login to the merchant platform of WeChat Pay and join the API warning group.
Applicable Object: Common mode Institutional mode
Request Parameters
Name | ID | Type | Required | Description |
---|---|---|---|---|
Return Status Code | return_code | String(16) | Yes | SUCCESS or FAIL |
Return Data | return_msg | String(128) | No | If not empty, this is the error description |
If return_code is SUCCESS, return data will also include the following fields:
Name | ID | Type | Required | Description |
---|---|---|---|---|
Official Account ID | appid | String(32) | Yes | Specifies Official Account ID assigned by WeChat |
Merchant ID | mch_id | String(32) | Yes | Specifies merchant ID assigned by WeChat Payment |
Sub Official Account ID | sub_appid | String(32) | No | Specifies an Official Account ID assigned by WeChat |
Sub Merchant ID | sub_mch_id | String(32) | Yes | Specifies merchant ID assigned by WeChat Payment |
Device ID | device_info | String(32) | No | Specifies the terminal device ID assigned by WeChat Payment |
Random String | nonce_str | String(32) | Yes | 32 characters or fewer |
Signature | sign | String(64) | Yes | Specifies a signature. For more information, see Signature Algorithm. |
Service Result | result_code | String(16) | Yes | SUCCESS or FAIL |
Error Code | error_code | String(32) | No | The error code returned |
Error Code Description | error_code_des | String(128) | No | The detailed error description returned. |
User Tag | openid | String(128) | Yes | The user id of the Payer provided by the WeChat system in OpenID format as unique tag on merchant’s appid. Also it is unique to each appid instance. |
Follows Official Account or not | is_subscribe | String(1) | Yes | Specifies whether the payer follows the associated official account or not, with Y meaning ‘follows’ and N meaning ’not follows’. |
Sub User Tag | sub_openid | String(128) | No | The user id of the Payer provided by the WeChat system in OpenID format as unique tag on merchant’s appid. Also it is unique to each appid instance. |
Follows Sub Official Account or not | sub_is_subscribe | String(1) | No | Specifies whether the payer follows the associated official account or not, with Y meaning ‘follows’ and N meaning ’not follows’. |
Transaction Type | trade_type | String(16) | Yes | Set as JSAPI, NATIVE, or APP |
Payment Bank | bank_type | String(32) | Yes | Use strings for bank type. For more information, see attachments. |
Total Amount | total_fee | int | Yes | Specifies the total amount for a transaction in cents. For more information, see Payment Amount. |
Currency Type | fee_type | String(8) | Yes | ISO-4217 standard compliant and be described by three characters based code. For more information, see Currency Type |
Cash Payment Amount | cash_fee | int | Yes | Specifies the total amount of a transaction. For more information, see Payment Amount. |
Cash Type | cash_fee_type | String(16) | No | Complies with ISO 4217 standards and uses CNY (Chinese yuan) by default. For more information, see Currency Type |
Specifies the number of a WeChat payment order | transaction_id | String(32) | Yes | Specifies the WeChat payment order id number |
Merchant Order Number | out_trade_no | String(32) | Yes | Specifies an order number created by a Merchants' system, which is consistent with request. |
Merchant's Data Package | attach | String(128) | No | Specifies merchant's data package, which is returned as it is. |
Payment End Time | time_end | String(14) | Yes | Specifies the time of completing payment in the format of yyyyMMddHHmmss, such as 20091225091010 for Dec 25, 2009 09:10:10. For more information, see Time Protocol. |
Exchange Rate | rate_value | String(16) | Yes | The value is 10 to the 8th power times of the exchange rate from foreign currency to RMB. For example, the exchange rate from foreign currency to RMB is 6.5, the value will be 650000000 |
Example:
Return Data:
Field Name | ID | Type | Required | Description |
---|---|---|---|---|
Return Status Code | return_code | string(16) | Yes | Set to SUCCESS or FAIL Specifies communicating label instead of transaction label. The status of the transaction is determined by the value of the result_code field. |
Return Data | return_msg | string(128) | No | If not empty, this is the error description. If not empty, this is the error description Signature Failure Parameter format checking error |
Example: