合单下单-JSAPI

更新时间:2024.11.14

使用合单支付接口,用户只输入一次密码,即可完成多个订单的支付。目前最多一次可支持50笔订单进行合单支付。

订单如果需要进行抽佣等,需要在合单中指定需要进行分账(profit_sharing为true);指定后,交易资金进入二级商户账户,处于冻结状态,可在后续使用分账接口进行分账,利用分账完结进行资金解冻,实现抽佣和对二级商户的账期。

接口说明

支持商户:【普通服务商】 【平台商户】

请求方式:【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)

【合单商户Appid】 合单发起方的Appid


combine_mchid  必填 string(32)

【合单商户号】 合单发起方商户号


combine_out_trade_no  必填 string(32)

【合单商户订单号】 合单支付总订单号,最短2个字符,最长32个字符,只能是数字、大小写字母,以及_-|* ,且在同一个商户号下唯一


scene_info  选填 object

【场景信息】 支付场景描述。

属性

sub_orders  必填 array[UnionSubOrder]

【商品单信息】 子单列表,最多支持商品单条数:50。

属性

combine_payer_info  必填 object

【支付者】 支付者信息,必须指定用户的openid或sub_openid。

属性

time_start  选填 string

【交易起始时间】 订单生效时间,按照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  选填 string

【交易结束时间】 订单失效时间,按照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  选填 string(255)

【通知地址】 接收微信支付异步通知回调地址,通知url必须为直接可访问的url,不能携带参数。必须使用https协议。

请求示例

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    "combine_appid" : "wxd678efh567hg6787",
8    "combine_mchid" : "1230000109",
9    "combine_out_trade_no" : "P20150806125346",
10    "scene_info" : {
11      "device_id" : "POS1:1",
12      "payer_client_ip" : "127.0.0.1"
13    },
14    "sub_orders" : [
15      {
16        "mchid" : "1230000109",
17        "sub_mchid" : "1900000109",
18        "sub_appid" : 
19        "out_trade_no" : "20150806125346",
20        "amount" : {
21          "total_amount" : 10,
22          "currency" : "CNY"
23        },
24        "attach" : "深圳分店",
25        "description" : "Image形象店-深圳腾大-QQ公仔",
26        "detail" : "买单费用",
27        "goods_tag" : "WXG",
28        "settle_info" : {
29          "profit_sharing" : false,
30          "subsidy_amount" : 10
31        }
32      }
33    ],
34    "combine_payer_info" : {
35      "openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o",
36      "sub_openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"
37    },
38    "time_start" : "2018-06-08T10:34:56+08:00",
39    "time_expire" : "2018-06-08T10:34:56+08:00",
40    "notify_url" : "https://yourapp.com/notify"
41  }'
42

应答参数

prepay_id  必填 string(64)

【预支付交易会话标识】 微信生成的预支付会话标识,数字和字母组成,用于后续接口调用使用,该值有效期为2小时。

应答示例

1{
2  "prepay_id" : "wx201410272009395522657a690389285100"
3}
4

 

错误码

公共错误码

状态码

错误码

描述

解决方案

400

PARAM_ERROR

参数错误

请根据错误提示正确传入参数

400

INVALID_REQUEST

HTTP 请求不符合微信支付 APIv3 接口规则

请参阅 接口规则

401

SIGN_ERROR

验证不通过

请参阅 签名常见问题

500

SYSTEM_ERROR

系统异常,请稍后重试

请稍后重试

业务错误码

状态码

错误码

描述

解决方案

202

USERPAYING

用户支付中,需要输入密码

等待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

ACCOUNTERROR

账号异常

用户账号异常,无需更多操作

403

NOAUTH

商户无权限

请商户前往申请此接口相关权限

403

OUT_TRADE_NO_USED

商户订单号重复

请核实商户订单号是否重复提交

403

RULELIMIT

业务规则限制

因业务规则限制请求频率,请查看接口返回的详细信息

403

TRADE_ERROR

交易错误

因业务原因交易失败,请查看接口返回的详细信息

404

ORDERNOTEXIST

订单不存在

请检查订单是否发起过交易

429

FREQUENCY_LIMITED

频率超限

请降低请求接口频率

500

BANKERROR

银行系统异常

银行系统异常,请用相同参数重新调用

500

INVALID_TRANSACTIONID

订单号非法

请检查微信支付订单号是否正确

500

OPENID_MISMATCH

OpenID和AppID不匹配

请确认OpenID和AppID是否匹配

500

SYSTEMERROR

系统错误

系统异常,请用相同参数重新调用

 

 

反馈
咨询
目录
置顶