JSAPI合单下单
更新时间:2025.01.14用户在商户前端选择微信支付后,商户需调用该接口在微信支付下单,生成用于调起支付的预支付交易会话标识(prepay_id)。
|
接口说明
支持商户:【普通商户】
请求方式:【POST】/v3/combine-transactions/jsapi
请求域名:【主域名】https://api.mch.weixin.qq.com 使用该域名将访问就近的接入点
【备域名】https://api2.mch.weixin.qq.com 使用该域名将访问异地的接入点 ,指引点击查看
请求参数
Header HTTP头参数
Authorization 必填 string
请参考签名认证生成认证信息
Accept 必填 string
请设置为application/json
Content-Type 必填 string
请设置为application/json
body 包体参数
combine_appid 必填 string(32)
【合单商户公众账号ID】合单发起方的APPID。APPID是微信开放平台(移动应用)或微信公众平台(小程序、公众号)为开发者的应用程序提供的唯一标识。此处请填写公众号类型的APPID,并确保该combine_appid
与combine_mchid
有绑定关系。详见:商户号绑定APPID账号操作指南。
combine_out_trade_no 必填 string(32)
【合单商户订单号】合单发起方商户系统内部订单号,要求6~32个字符内,只能是数字、大小写字母_-|*,且在同一个合单商户号下唯一。
combine_mchid 必填 string(32)
【合单商户号】 合单发起方的商户号,是由微信支付系统生成并分配给每个商户的唯一标识符,商户号获取方式请参考普通商户模式开发必要参数说明。
scene_info 选填 object
【场景信息】场景信息
属性 | |
device_id 选填 string(16) 【商户端设备号】 终端设备号(门店号或收银设备ID) payer_client_ip 必填 string(45) 【用户终端IP】用户端实际IP,支持IPv4和IPv6两种格式的IP地址。IP获取请参考获取用户IP指引 |
sub_orders 必填 array[ReqSubOrderCompatible]
【子单信息列表】合单支付的子单信息列表,一笔合单支付订单可支持2-10笔子单交易。
属性 | |||||||||
mchid 必填 string(32) 【子单商户号】子单参与方的商户号,必须与 attach 必填 string(128) 【商户数据包】商户在创建订单时可传入自定义数据包,该数据对用户不可见,用于存储订单相关的商户自定义信息,其总长度限制在128字符以内。支付成功后查询合单订单API和合单订单支付成功回调通知均会将此字段返回给商户,并且该字段还会体现在交易账单。 amount 必填 object 【子单金额信息】 子订单收款金额信息。
out_trade_no 必填 string(32) 【子单商户订单号】 合单发起方商户系统内部订单号,要求6~32个字符内,只能是数字、大小写字母_-|*,且在同一个合单商户号下唯一。 detail 选填 string(6000) 【商品详情】 对订单商品的详细描述。 description 必填 string(127) 【商品描述】商品信息描述,用户微信账单的商品字段中可见(可参考JSAPI合单支付模式介绍-6、账单示意图),商户需传递能真实代表商品信息的描述,不能超过127个字符。 settle_info 选填 object 【结算信息】 结算信息
goods_tag 选填 string(32) 【订单优惠标记】代金券在创建时可以配置多个订单优惠标记,标记的内容由创券商户自定义设置。详细参考:创建代金券批次API。 示例: |
combine_payer_info 必填 object
【合单支付者信息】 合单支付者信息。
属性 | |
openid 选填 string(128) 【用户标识】用户在合单商户号的 |
time_expire 选填 string
【支付结束时间】
1、定义:支付结束时间是指用户能够完成该笔订单支付的最后时限,并非订单关闭的时间。超过此时间后,用户将无法对该笔订单进行支付。如需关闭订单,请调用关闭合单订单API接口。
2、格式要求:支付结束时间需遵循rfc3339标准格式:yyyy-MM-DDTHH:mm:ss+TIMEZONE
。yyyy-MM-DD
表示年月日;T
字符用于分隔日期和时间部分;HH:mm:ss
表示具体的时分秒;TIMEZONE
表示时区(例如,+08:00
对应东八区时间,即北京时间)。
示例:2015-05-20T13:29:35+08:00
表示北京时间2015年5月20日13点29分35秒。
3、注意事项:
time_expire
参数仅在用户首次下单时可设置,且不允许后续修改,尝试修改将导致错误。若用户实际进行支付的时间超过了订单设置的支付结束时间,商户需使用新的商户订单号下单,生成新的订单供用户进行支付。若未超过支付结束时间,则可使用原参数重新请求下单接口,以获取当前订单最新的
prepay_id
进行支付。支付结束时间不能早于下单时间后1分钟,若设置的支付结束时间早于该时间,系统将自动调整为下单时间后1分钟作为支付结束时间。
notify_url 必填 string(255)
【商户回调地址】商户接收合单订单支付成功回调通知的地址,需按照notify_url填写注意事项规范填写。
请求示例
POST
合单支付-JSAPI合单下单-请求示例
1curl -X POST \ 2 https://api.mch.weixin.qq.com/v3/combine-transactions/jsapi \ 3 -H "Authorization: WECHATPAY2-SHA256-RSA2048 mchid=\"1900000001\",..." \ 4 -H "Accept: application/json" \ 5 -H "Content-Type: application/json" \ 6 -d '{ 7 "time_expire" : "2018-06-08T10:34:56+08:00", 8 "combine_appid" : "wxd678efh567hg6787", 9 "sub_orders" : [ 10 { 11 "mchid" : "1230000109", 12 "attach" : "深圳分店", 13 "amount" : { 14 "total_amount" : 10, 15 "currency" : "CNY" 16 }, 17 "out_trade_no" : "20150806125346", 18 "detail" : "买单费用", 19 "description" : "腾讯充值中心-QQ会员充值", 20 "settle_info" : { 21 "profit_sharing" : false 22 }, 23 "goods_tag" : "WXG" 24 }, 25 { 26 "mchid" : "1230000119", 27 "attach" : "广州分店", 28 "amount" : { 29 "total_amount" : 10, 30 "currency" : "CNY" 31 }, 32 "out_trade_no" : "20150806125347", 33 "detail" : "买单费用", 34 "description" : "腾讯充值中心-微信充值", 35 "settle_info" : { 36 "profit_sharing" : false 37 }, 38 "goods_tag" : "WXG" 39 } 40 ], 41 "combine_payer_info" : { 42 "openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o" 43 }, 44 "combine_out_trade_no" : "1217752501201407033233368018", 45 "notify_url" : "https://yourapp.com/notify", 46 "combine_mchid" : "1230000109", 47 "scene_info" : { 48 "device_id" : "POS1:1", 49 "payer_client_ip" : "14.17.22.32" 50 } 51 }' 52
需配合微信支付工具库 WXPayUtility 使用,请参考Java
1package com.java.demo; 2 3import com.java.utils.WXPayUtility; // 引用微信支付工具库,参考:https://pay.weixin.qq.com/doc/v3/merchant/4014931831 4 5import com.google.gson.annotations.SerializedName; 6import com.google.gson.annotations.Expose; 7import okhttp3.MediaType; 8import okhttp3.OkHttpClient; 9import okhttp3.Request; 10import okhttp3.RequestBody; 11import okhttp3.Response; 12 13import java.io.IOException; 14import java.io.UncheckedIOException; 15import java.security.PrivateKey; 16import java.security.PublicKey; 17import java.util.ArrayList; 18import java.util.HashMap; 19import java.util.List; 20import java.util.Map; 21 22/** 23 * 合单下单-JSAPI 24 */ 25public class UnionJsapiPrepay { 26 private static String HOST = "https://api.mch.weixin.qq.com"; 27 private static String METHOD = "POST"; 28 private static String PATH = "/v3/combine-transactions/jsapi"; 29 30 public static void main(String[] args) { 31 // TODO: 请准备商户开发必要参数,参考:https://pay.weixin.qq.com/doc/v3/merchant/4013070756 32 UnionJsapiPrepay client = new UnionJsapiPrepay( 33 "19xxxxxxxx", // 商户号,是由微信支付系统生成并分配给每个商户的唯一标识符,商户号获取方式参考 https://pay.weixin.qq.com/doc/v3/merchant/4013070756 34 "1DDE55AD98Exxxxxxxxxx", // 商户API证书序列号,如何获取请参考 https://pay.weixin.qq.com/doc/v3/merchant/4013053053 35 "/path/to/apiclient_key.pem", // 商户API证书私钥文件路径,本地文件路径 36 "PUB_KEY_ID_xxxxxxxxxxxxx", // 微信支付公钥ID,如何获取请参考 https://pay.weixin.qq.com/doc/v3/merchant/4013038816 37 "/path/to/wxp_pub.pem" // 微信支付公钥文件路径,本地文件路径 38 ); 39 40 UnionAPIv3JsapiPrepayRequest request = new UnionAPIv3JsapiPrepayRequest(); 41 request.combineAppid = "wxd678efh567hg6787"; 42 request.combineMchid = "1230000109"; 43 request.combineOutTradeNo = "1217752501201407033233368018"; 44 request.combinePayerInfo = new UnionPayerInfo(); 45 request.combinePayerInfo.openid = "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"; 46 request.sceneInfo = new UnionSceneInfo(); 47 request.sceneInfo.deviceId = "POS1:1"; 48 request.sceneInfo.payerClientIp = "14.17.22.32"; 49 request.subOrders = new ArrayList<>(); 50 { 51 UnionSubOrder subOrdersItem0 = new UnionSubOrder(); 52 subOrdersItem0.mchid = "1230000109"; 53 subOrdersItem0.outTradeNo = "20150806125346"; 54 subOrdersItem0.amount = new UnionAmountInfo(); 55 subOrdersItem0.amount.totalAmount = 10L; 56 subOrdersItem0.amount.currency = "CNY"; 57 subOrdersItem0.attach = "深圳分店"; 58 subOrdersItem0.description = "腾讯充值中心-QQ会员充值"; 59 subOrdersItem0.detail = "买单费用"; 60 subOrdersItem0.goodsTag = "WXG"; 61 subOrdersItem0.settleInfo = new UnionSettleInfo(); 62 subOrdersItem0.settleInfo.profitSharing = false; 63 request.subOrders.add(subOrdersItem0); 64 UnionSubOrder subOrdersItem1 = new UnionSubOrder(); 65 subOrdersItem1.mchid = "1230000119"; 66 subOrdersItem1.outTradeNo = "20150806125347"; 67 subOrdersItem1.amount = new UnionAmountInfo(); 68 subOrdersItem1.amount.totalAmount = 10L; 69 subOrdersItem1.amount.currency = "CNY"; 70 subOrdersItem1.attach = "广州分店"; 71 subOrdersItem1.description = "腾讯充值中心-微信充值"; 72 subOrdersItem1.detail = "买单费用"; 73 subOrdersItem1.goodsTag = "WXG"; 74 subOrdersItem1.settleInfo = new UnionSettleInfo(); 75 subOrdersItem1.settleInfo.profitSharing = false; 76 request.subOrders.add(subOrdersItem1); 77 }; 78 request.timeExpire = "2018-06-08T10:34:56+08:00"; 79 request.notifyUrl = "https://yourapp.com/notify"; 80 try { 81 UnionAPIv3JsapiPrepayResponse response = client.run(request); 82 // TODO: 请求成功,继续业务逻辑 83 System.out.println(response); 84 } catch (WXPayUtility.ApiException e) { 85 // TODO: 请求失败,根据状态码执行不同的逻辑 86 e.printStackTrace(); 87 } 88 } 89 90 public UnionAPIv3JsapiPrepayResponse run(UnionAPIv3JsapiPrepayRequest request) { 91 String uri = PATH; 92 String reqBody = WXPayUtility.toJson(request); 93 94 Request.Builder reqBuilder = new Request.Builder().url(HOST + uri); 95 reqBuilder.addHeader("Accept", "application/json"); 96 reqBuilder.addHeader("Wechatpay-Serial", wechatPayPublicKeyId); 97 reqBuilder.addHeader("Authorization", WXPayUtility.buildAuthorization(mchid, certificateSerialNo,privateKey, METHOD, uri, reqBody)); 98 reqBuilder.addHeader("Content-Type", "application/json"); 99 RequestBody requestBody = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), reqBody); 100 reqBuilder.method(METHOD, requestBody); 101 Request httpRequest = reqBuilder.build(); 102 103 // 发送HTTP请求 104 OkHttpClient client = new OkHttpClient.Builder().build(); 105 try (Response httpResponse = client.newCall(httpRequest).execute()) { 106 String respBody = WXPayUtility.extractBody(httpResponse); 107 if (httpResponse.code() >= 200 && httpResponse.code() < 300) { 108 // 2XX 成功,验证应答签名 109 WXPayUtility.validateResponse(this.wechatPayPublicKeyId, this.wechatPayPublicKey, 110 httpResponse.headers(), respBody); 111 112 // 从HTTP应答报文构建返回数据 113 return WXPayUtility.fromJson(respBody, UnionAPIv3JsapiPrepayResponse.class); 114 } else { 115 throw new WXPayUtility.ApiException(httpResponse.code(), respBody, httpResponse.headers()); 116 } 117 } catch (IOException e) { 118 throw new UncheckedIOException("Sending request to " + uri + " failed.", e); 119 } 120 } 121 122 private final String mchid; 123 private final String certificateSerialNo; 124 private final PrivateKey privateKey; 125 private final String wechatPayPublicKeyId; 126 private final PublicKey wechatPayPublicKey; 127 128 public UnionJsapiPrepay(String mchid, String certificateSerialNo, String privateKeyFilePath, String wechatPayPublicKeyId, String wechatPayPublicKeyFilePath) { 129 this.mchid = mchid; 130 this.certificateSerialNo = certificateSerialNo; 131 this.privateKey = WXPayUtility.loadPrivateKeyFromPath(privateKeyFilePath); 132 this.wechatPayPublicKeyId = wechatPayPublicKeyId; 133 this.wechatPayPublicKey = WXPayUtility.loadPublicKeyFromPath(wechatPayPublicKeyFilePath); 134 } 135 136 public static class UnionAPIv3JsapiPrepayRequest { 137 @SerializedName("combine_appid") 138 public String combineAppid; 139 140 @SerializedName("combine_mchid") 141 public String combineMchid; 142 143 @SerializedName("combine_out_trade_no") 144 public String combineOutTradeNo; 145 146 @SerializedName("combine_payer_info") 147 public UnionPayerInfo combinePayerInfo; 148 149 @SerializedName("scene_info") 150 public UnionSceneInfo sceneInfo; 151 152 @SerializedName("sub_orders") 153 public List<UnionSubOrder> subOrders = new ArrayList<UnionSubOrder>(); 154 155 @SerializedName("time_expire") 156 public String timeExpire; 157 158 @SerializedName("notify_url") 159 public String notifyUrl; 160 } 161 162 public static class UnionAPIv3JsapiPrepayResponse { 163 @SerializedName("prepay_id") 164 public String prepayId; 165 } 166 167 public static class UnionPayerInfo { 168 @SerializedName("openid") 169 public String openid; 170 171 @SerializedName("sub_openid") 172 public String subOpenid; 173 } 174 175 public static class UnionSceneInfo { 176 @SerializedName("device_id") 177 public String deviceId; 178 179 @SerializedName("payer_client_ip") 180 public String payerClientIp; 181 } 182 183 public static class UnionSubOrder { 184 @SerializedName("mchid") 185 public String mchid; 186 187 @SerializedName("out_trade_no") 188 public String outTradeNo; 189 190 @SerializedName("amount") 191 public UnionAmountInfo amount; 192 193 @SerializedName("attach") 194 public String attach; 195 196 @SerializedName("description") 197 public String description; 198 199 @SerializedName("detail") 200 public String detail; 201 202 @SerializedName("goods_tag") 203 public String goodsTag; 204 205 @SerializedName("settle_info") 206 public UnionSettleInfo settleInfo; 207 } 208 209 public static class UnionAmountInfo { 210 @SerializedName("total_amount") 211 public Long totalAmount; 212 213 @SerializedName("currency") 214 public String currency; 215 } 216 217 public static class UnionSettleInfo { 218 @SerializedName("profit_sharing") 219 public Boolean profitSharing; 220 } 221 222} 223
需配合微信支付工具库 wxpay_utility 使用,请参考Go
1package main 2 3import ( 4 "bytes" 5 "demo/wxpay_utility" // 引用微信支付工具库,参考 https://pay.weixin.qq.com/doc/v3/merchant/4015119334 6 "encoding/json" 7 "fmt" 8 "net/http" 9 "net/url" 10 "time" 11) 12 13func main() { 14 // TODO: 请准备商户开发必要参数,参考:https://pay.weixin.qq.com/doc/v3/merchant/4013070756 15 config, err := wxpay_utility.CreateMchConfig( 16 "19xxxxxxxx", // 商户号,是由微信支付系统生成并分配给每个商户的唯一标识符,商户号获取方式参考 https://pay.weixin.qq.com/doc/v3/merchant/4013070756 17 "1DDE55AD98Exxxxxxxxxx", // 商户API证书序列号,如何获取请参考 https://pay.weixin.qq.com/doc/v3/merchant/4013053053 18 "/path/to/apiclient_key.pem", // 商户API证书私钥文件路径,本地文件路径 19 "PUB_KEY_ID_xxxxxxxxxxxxx", // 微信支付公钥ID,如何获取请参考 https://pay.weixin.qq.com/doc/v3/merchant/4013038816 20 "/path/to/wxp_pub.pem", // 微信支付公钥文件路径,本地文件路径 21 ) 22 if err != nil { 23 fmt.Println(err) 24 return 25 } 26 27 request := &UnionApiv3JsapiPrepayRequest{ 28 CombineAppid: wxpay_utility.String("wxd678efh567hg6787"), 29 CombineMchid: wxpay_utility.String("1230000109"), 30 CombineOutTradeNo: wxpay_utility.String("1217752501201407033233368018"), 31 CombinePayerInfo: &UnionPayerInfo{ 32 Openid: wxpay_utility.String("oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"), 33 }, 34 SceneInfo: &UnionSceneInfo{ 35 DeviceId: wxpay_utility.String("POS1:1"), 36 PayerClientIp: wxpay_utility.String("14.17.22.32"), 37 }, 38 SubOrders: []UnionSubOrder{ 39 UnionSubOrder{ 40 Mchid: wxpay_utility.String("1230000109"), 41 OutTradeNo: wxpay_utility.String("20150806125346"), 42 Amount: &UnionAmountInfo{ 43 TotalAmount: wxpay_utility.Int64(10), 44 Currency: wxpay_utility.String("CNY"), 45 }, 46 Attach: wxpay_utility.String("深圳分店"), 47 Description: wxpay_utility.String("腾讯充值中心-QQ会员充值"), 48 Detail: wxpay_utility.String("买单费用"), 49 GoodsTag: wxpay_utility.String("WXG"), 50 SettleInfo: &UnionSettleInfo{ 51 ProfitSharing: wxpay_utility.Bool(false), 52 }, 53 }, 54 UnionSubOrder{ 55 Mchid: wxpay_utility.String("1230000119"), 56 OutTradeNo: wxpay_utility.String("20150806125347"), 57 Amount: &UnionAmountInfo{ 58 TotalAmount: wxpay_utility.Int64(10), 59 Currency: wxpay_utility.String("CNY"), 60 }, 61 Attach: wxpay_utility.String("广州分店"), 62 Description: wxpay_utility.String("腾讯充值中心-微信充值"), 63 Detail: wxpay_utility.String("买单费用"), 64 GoodsTag: wxpay_utility.String("WXG"), 65 SettleInfo: &UnionSettleInfo{ 66 ProfitSharing: wxpay_utility.Bool(false), 67 }, 68 }, 69 }, 70 TimeExpire: wxpay_utility.Time(time.Now()), 71 NotifyUrl: wxpay_utility.String("https://yourapp.com/notify"), 72 } 73 74 response, err := UnionJsapiPrepay(config, request) 75 if err != nil { 76 fmt.Printf("请求失败: %+v\n", err) 77 // TODO: 请求失败,根据状态码执行不同的处理 78 return 79 } 80 81 // TODO: 请求成功,继续业务逻辑 82 fmt.Printf("请求成功: %+v\n", response) 83} 84 85func UnionJsapiPrepay(config *wxpay_utility.MchConfig, request *UnionApiv3JsapiPrepayRequest) (response *UnionApiv3JsapiPrepayResponse, err error) { 86 const ( 87 host = "https://api.mch.weixin.qq.com" 88 method = "POST" 89 path = "/v3/combine-transactions/jsapi" 90 ) 91 92 reqUrl, err := url.Parse(fmt.Sprintf("%s%s", host, path)) 93 if err != nil { 94 return nil, err 95 } 96 reqBody, err := json.Marshal(request) 97 if err != nil { 98 return nil, err 99 } 100 httpRequest, err := http.NewRequest(method, reqUrl.String(), bytes.NewReader(reqBody)) 101 if err != nil { 102 return nil, err 103 } 104 httpRequest.Header.Set("Accept", "application/json") 105 httpRequest.Header.Set("Wechatpay-Serial", config.WechatPayPublicKeyId()) 106 httpRequest.Header.Set("Content-Type", "application/json") 107 authorization, err := wxpay_utility.BuildAuthorization(config.MchId(), config.CertificateSerialNo(), config.PrivateKey(), method, reqUrl.RequestURI(), reqBody) 108 if err != nil { 109 return nil, err 110 } 111 httpRequest.Header.Set("Authorization", authorization) 112 113 client := &http.Client{} 114 httpResponse, err := client.Do(httpRequest) 115 if err != nil { 116 return nil, err 117 } 118 respBody, err := wxpay_utility.ExtractResponseBody(httpResponse) 119 if err != nil { 120 return nil, err 121 } 122 if httpResponse.StatusCode >= 200 && httpResponse.StatusCode < 300 { 123 // 2XX 成功,验证应答签名 124 err = wxpay_utility.ValidateResponse( 125 config.WechatPayPublicKeyId(), 126 config.WechatPayPublicKey(), 127 &httpResponse.Header, 128 respBody, 129 ) 130 if err != nil { 131 return nil, err 132 } 133 response := &UnionApiv3JsapiPrepayResponse{} 134 if err := json.Unmarshal(respBody, response); err != nil { 135 return nil, err 136 } 137 138 return response, nil 139 } else { 140 return nil, wxpay_utility.NewApiException( 141 httpResponse.StatusCode, 142 httpResponse.Header, 143 respBody, 144 ) 145 } 146} 147 148type UnionApiv3JsapiPrepayRequest struct { 149 CombineAppid *string `json:"combine_appid,omitempty"` 150 CombineMchid *string `json:"combine_mchid,omitempty"` 151 CombineOutTradeNo *string `json:"combine_out_trade_no,omitempty"` 152 CombinePayerInfo *UnionPayerInfo `json:"combine_payer_info,omitempty"` 153 SceneInfo *UnionSceneInfo `json:"scene_info,omitempty"` 154 SubOrders []UnionSubOrder `json:"sub_orders,omitempty"` 155 TimeExpire *time.Time `json:"time_expire,omitempty"` 156 NotifyUrl *string `json:"notify_url,omitempty"` 157} 158 159type UnionApiv3JsapiPrepayResponse struct { 160 PrepayId *string `json:"prepay_id,omitempty"` 161} 162 163type UnionPayerInfo struct { 164 Openid *string `json:"openid,omitempty"` 165 SubOpenid *string `json:"sub_openid,omitempty"` 166} 167 168type UnionSceneInfo struct { 169 DeviceId *string `json:"device_id,omitempty"` 170 PayerClientIp *string `json:"payer_client_ip,omitempty"` 171} 172 173type UnionSubOrder struct { 174 Mchid *string `json:"mchid,omitempty"` 175 OutTradeNo *string `json:"out_trade_no,omitempty"` 176 Amount *UnionAmountInfo `json:"amount,omitempty"` 177 Attach *string `json:"attach,omitempty"` 178 Description *string `json:"description,omitempty"` 179 Detail *string `json:"detail,omitempty"` 180 GoodsTag *string `json:"goods_tag,omitempty"` 181 SettleInfo *UnionSettleInfo `json:"settle_info,omitempty"` 182} 183 184type UnionAmountInfo struct { 185 TotalAmount *int64 `json:"total_amount,omitempty"` 186 Currency *string `json:"currency,omitempty"` 187} 188 189type UnionSettleInfo struct { 190 ProfitSharing *bool `json:"profit_sharing,omitempty"` 191} 192
应答参数
|
prepay_id 必填 string(64)
【预支付交易会话标识】预支付交易会话标识,JSAPI调起支付时需要使用的参数,有效期为2小时,失效后需要重新请求该接口以获取新的prepay_id。
应答示例
200 OK
1{ 2 "prepay_id" : "wx201410272009395522657a690389285100" 3} 4
错误码
公共错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|---|---|---|
400 | PARAM_ERROR | 参数错误 | 请根据错误提示正确传入参数 |
400 | INVALID_REQUEST | HTTP 请求不符合微信支付 APIv3 接口规则 | 请参阅接口规则检查传入的参数 |
401 | SIGN_ERROR | 验证不通过 | 请参阅签名常见问题排查 |
500 | SYSTEM_ERROR | 系统异常,请稍后重试 | 请稍后重试 |
业务错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|---|---|---|
400 | APPID_MCHID_NOT_MATCH | AppID和mch_id不匹配 | 请确认AppID和mch_id是否匹配,参考:查询商户号绑定的APPID账号 |
400 | INVALID_REQUEST | 无效请求 | 请根据接口返回的详细信息检查 |
400 | MCH_NOT_EXISTS | 商户号不存在 | 请检查商户号是否正确,商户号获取方式请参考:普通商户模式开发必要参数说明 |
400 | ORDER_CLOSED | 订单已关闭 | 当前订单已关闭,请重新下单 |
401 | SIGN_ERROR | 签名错误 | 请检查签名参数和方法是否都符合签名算法要求,参考:如何生成签名 |
403 | NOAUTH | 商户无权限 | 请商户联系对接运营申请此接口相关权限,参考:快速开始-步骤3 |
403 | OUT_TRADE_NO_USED | 商户订单号重复 | 请核实商户订单号是否重复提交 |
403 | RULELIMIT | 业务规则限制 | 因业务规则限制请求频率,请查看接口返回的详细信息 |
429 | FREQUENCY_LIMITED | 频率超限 | 请降低请求接口频率 |
500 | OPENID_MISMATCH | OpenID和AppID不匹配 | 请确认OpenID和AppID是否匹配,参考:OpenID获取 |
500 | SYSTEMERROR | 系统错误 | 系统异常,请用相同参数重新调用 |