Development Guide
Update Time:2025.03.24Service process
Below shows how the merchant's backend interacts with the WeChat payment system:
Step 1:Users submit order on vendor’s page and select to pay by WeChat payment
Step 2:The Vendor's server calls the Unified Order API to create an order and get the payment jump url (trade_type = MWEB).
Step 3:hWeChat payment will verify the vendor’s authority
Step 4:The WeChat payment server returns payment jump url to the vendor to call WeChat payment
Step 5:The vendor returns the payment jump url to the front-end page
Step 6:The vendor will request the payment jump url through front-end page (WeChat will verify the request source, which is the “payment directory”, so please configure it in the WeChat backstage).
Step 7:The payment jump url will call the WeChat payment.
Step 8:The jump page will be closed when WeChat client is loaded.
Step 9:Jump back to the vendor’s page when payment is complete.
Guide for Obtaining User IP by H5 Payment
HH5 Payment requires merchants to upload the user’s real IP address "payer_client_ip" in the unified ordering API. The following guides for obtaining the user’s IP are provided to ensure that the user’s IP address obtained by WeChat is consistent with that obtained by the merchant.
Without agent
The way to obtain the IP is relatively simple when the front-end access layer of the merchant. Get 'REMOTE_ADDR' directly.
With agent
In the case of an agent, as the client needs to be replaced to access the server, when the request packet passes through the reverse agent, the IP header of the IP packet is modified in the agent server, and the source IP address of the packet header obtained by the back-end web server is the IP address of the agent server. Therefore, the backend server program cannot obtain the user's real IP.
When nginx has an agent:
Add the following to the configuration in nginx:
When Apache has an agent:
Code example
FAQs
Callback page
In the normal process, the user will return to the page where the payment is initiated after completing the payment. If the user needs to return to the specified page, you can splice the redirect_url parameter after MWEB_URL to specify the callback page.
For example, if you want to redirect users to https://www.wechatpay.com.cn after the payment is completed, you can do the following:
Note:
Urlencode processing for redirect_url is required.
After the redirect_url is set, the user may return to the specified page when: 1. more than 5 seconds after the WeChat Pay middle page calls the WeChat cashier; 2. the user taps Cancel Payment or taps Finish after the payment is completed. There is no guarantee that the payment process has ended when the user returns to the specified page. Therefore, the redirect_url address set by the merchant cannot automatically perform the order check operation. The user needs to tap the button to trigger the order check operation. See the figure below for the display effect of returning to the specified page.
Other Common Errors
-->
Problem | Problem Description | Solution |
---|---|---|
| The network environment fails to pass the security verification. Please try again later. |
|
| The merchant parameter format is incorrect. Please contact the merchant. |
extraHeaders.put("Referer", "the authorized domain submitted by the merchant when you apply for H5 Payment");//e.g. http://www.baidu.com )) |
| The merchant has unconfigured parameters. Please contact the merchant. |
|
| Payment request has expired. Please re-initiate payment. | After the MWEB_URL returned by the unified order is generated, it will remain valid for 5 minutes. If it expires, regenerate the MWEB_URL and initiate the payment. |
| Open the order outside WeChat to make payment. | H5 Payment cannot be called directly in WeChat. Instead, call it in a third-party browser. |
| iOS: Signature verification failed |
https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx20161110163838f23161 |