合单下单-JSAPI

更新时间:2023.12.07

通过本接口提交微信支付JSAPI支付订单。

注意

  • 订单如果需要进行抽佣等,需要在合单中指定需要进行分账(profit_sharing为true);指定后,交易资金进入二级商户账户,处于冻结状态,可在后续使用分账接口进行分账,利用分账完结进行资金解冻,实现抽佣和对二级商户的账期。
  • 商户上送敏感信息时使用微信支付平台公钥加密,证书序列号包含在请求HTTP头部的Wechatpay-Serial,详见接口规则

# 接口说明

支持商户: 【普通商户】

请求URL: "https://api.mch.weixin.qq.com/v3/combine-transactions/jsapi"

请求方式: 【POST】

# 请求参数

    Header HTTP头参数
  • Authorization 必填 string
    请参考 签名认证 生成认证信息
  • Accept 必填 string
    请设置为 application/json
  • Content-Type 必填 string
    请设置为 application/json
    Body 包体参数
  • combine_appid 必填 string(32)
    【合单商户AppID】 合单发起方的AppID
  • combine_out_trade_no 必填 string(32)
    【合单商户订单号】 商户系统内部订单号,可以是数字、大小写字母以及特殊符号_-*的任意组合,且在同一个商户号下唯一。
  • combine_mchid 必填 string(32)
    【合单商户号】 合单发起方商户号
  • scene_info 选填 ReqSceneInfo
    【场景信息】 支付场景信息描述
    • 属性
  • sub_orders 必填 array
    【子单信息】 子单列表,最多支持子单条数:50。
    • 数组
  • combine_payer_info 选填 object
    【支付者】 支付者信息,可以指定用户的实名信息,也可以指定用户的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协议。

# 应答参数

    200OK
  • prepay_id 必填 string(64)
    【预支付交易会话标识】 数字和字母,微信生成的预支付会话标识,用于后续接口调用使用。

请求示例

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": "POS1:1",
17 "payer_client_ip": "14.17.22.32"
18 },
19 "sub_orders": [
20 {
21 "amount": {
22 "currency": "CNY",
23 "total_amount": 10
24 },
25 "attach": "深圳分店",
26 "description": "腾讯充值中心-QQ会员充值",
27 "goods_tag": "WXG",
28 "mchid": "1230000109",
29 "out_trade_no": "20150806125346",
30 "profit_sharing": "",
31 "settle_info": {
32 "profit_sharing": false,
33 "subsidy_amount": 10
34 }
35 }
36 ],
37 "time_expire": "2018-06-08T10:34:56+08:00",
38 "time_start": "2018-06-08T10:34:56+08:00"
39}

返回示例

1{
2 "prepay_id": "wx201410272009395522657a690389285100"
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 系统错误 系统异常,请用相同参数重新调用
反馈
咨询
目录