合单下单-H5
更新时间:2023.12.07通过本接口提交微信支付H5支付订单。
注意
- 订单如果需要进行抽佣等,需要在合单中指定需要进行分账(profit_sharing为true);指定后,交易资金进入二级商户账户,处于冻结状态,可在后续使用分账接口进行分账,利用分账完结进行资金解冻,实现抽佣和对二级商户的账期。
- 商户上送敏感信息时使用微信支付平台公钥加密,证书序列号包含在请求HTTP头部的Wechatpay-Serial,详见接口规则
# 接口说明
支持商户: 【普通商户】
请求URL: "https://api.mch.weixin.qq.com/v3/combine-transactions/h5"
请求方式: 【POST】
# 请求参数
- Authorization 必填请参考签名认证
生成认证信息 - Accept 必填请设置为
application/json
- Content-Type 必填请设置为
application/json
Header HTTP头参数
- combine_appid 必填【合单商户AppID】 合单发起方的AppID
- combine_out_trade_no 必填【合单商户订单号】 合单支付总订单号,最短2个字符,最长32个字符,只能是数字、大小写字母,以及_-|* ,且在同一个商户号下唯一。
- combine_mchid 必填【合单商户号】 合单发起方商户号
- scene_info 选填【场景信息】 支付场景信息描述
- 属性
- sub_orders 必填【子单信息】 子单列表,最多支持子单条数:50。
- 数组
- time_start 选填【交易起始时间】 订单生效时间,按照rfc3339格式
,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC8小时,即北京时间)如 2018-06-08T10:34:56+08:00 代表,北京时间2018年06月08日10时34分56秒。 - time_expire 选填【交易结束时间】 订单失效时间,按照rfc3339格式
,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC8小时,即北京时间)如 2018-06-08T10:34:56+08:00 代表,北京时间2018年06月08日10时34分56秒。 - notify_url 必填【通知地址】 接收微信支付异步通知回调地址,通知URL必须为直接可访问的URL,不能携带参数。必须使用HTTPS协议。
- combine_payer_info 选填【支付者】 支付者信息,可以指定用户的实名信息,也可以指定用户的OpenID。
- 属性
Body 包体参数
# 应答参数
- h5_url 必填【支付跳转链接】 支付跳转链接,链接有效期为5分钟。
200OK
请求示例
1{2 "combine_appid": "wxd678efh567hg6787",3 "combine_mchid": "1230000109",4 "combine_out_trade_no": "1217752501201407033233368018",5 "combine_payer_info": {6 "identity": {7 "name": "6B46824C852FA29AAC3DCE6BFD852E27",8 "number": "6B46824C852FA29AAC3DCE6BFD852E27",9 "type": "IDCARD"10 },11 "openid": "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"12 },13 "limit_pay": "",14 "notify_url": "https://yourapp.com/notify",15 "scene_info": {16 "device_id": "013467007045764",17 "h5_info": {18 "app_name": "王者荣耀",19 "app_url": "https://pay.qq.com",20 "bundle_id": "com.tencent.wzryiOS",21 "package_name": "com.tencent.tmgp.sgame",22 "type": "iOS"23 },24 "payer_client_ip": "14.23.150.211"25 },26 "sub_orders": [27 {28 "amount": {29 "currency": "CNY",30 "total_amount": 1031 },32 "attach": "深圳分店",33 "description": "腾讯充值中心-QQ会员充值",34 "goods_tag": "WXG",35 "mchid": "1230000109",36 "out_trade_no": "20150806125346",37 "settle_info": {38 "profit_sharing": false,39 "subsidy_amount": 1040 }41 }42 ],43 "time_expire": "2018-06-08T10:34:56+08:00",44 "time_start": "2018-06-08T10:34:56+08:00"45}
应答示例
1{2 "h5_url" : "https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx2016121516420242444321ca0631331346&package=1405458241"3}
# 错误码
# 公共错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|---|---|---|
400 | PARAM_ERROR | 参数错误 | 请根据错误提示正确传入参数 |
400 | INVALID_REQUEST | HTTP 请求不符合微信支付 APIv3 接口规则 | 请参阅 接口规则 |
401 | SIGN_ERROR | 验证不通过 | 请参阅 签名常见问题 |
500 | SYSTEM_ERROR | 系统异常,请稍后重试 | 请稍后重试 |
# 业务错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|---|---|---|
202 | USER_PAYING | 用户支付中,需要输入密码 | 等待5秒,然后调用被扫订单结果查询API,查询当前订单的不同状态,决定下一步的操作 |
400 | APPID_MCHID_NOT_MATCH | AppID和mch_id不匹配 | 请确认AppID和mch_id是否匹配 |
400 | INVALID_REQUEST | 无效请求 | 请根据接口返回的详细信息检查 |
400 | MCH_NOT_EXISTS | 商户号不存在 | 请检查商户号是否正确 |
400 | ORDER_CLOSED | 订单已关闭 | 当前订单已关闭,请重新下单 |
401 | SIGN_ERROR | 签名错误 | 请检查签名参数和方法是否都符合签名算法要求 |
403 | ACCOUNT_ERROR | 账号异常 | 用户账号异常,无需更多操作 |
403 | NO_AUTH | 商户无权限 | 请商户前往申请此接口相关权限 |
403 | OUT_TRADE_NO_USED | 商户订单号重复 | 请核实商户订单号是否重复提交 |
403 | RULE_LIMIT | 业务规则限制 | 因业务规则限制请求频率,请查看接口返回的详细信息 |
403 | TRADE_ERROR | 交易错误 | 因业务原因交易失败,请查看接口返回的详细信息 |
404 | ORDER_NOT_EXIST | 订单不存在 | 请检查订单是否发起过交易 |
429 | FREQUENCY_LIMITED | 频率超限 | 请降低请求接口频率 |
500 | BANK_ERROR | 银行系统异常 | 银行系统异常,请用相同参数重新调用 |
500 | INVALID_TRANSACTIONID | 订单号非法 | 请检查微信支付订单号是否正确 |
500 | OPENID_MISMATCH | OpenID和AppID不匹配 | 请确认OpenID和AppID是否匹配 |
500 | SYSTEM_ERROR | 系统错误 | 系统异常,请用相同参数重新调用 |
文档是否有帮助