小程序合单下单

更新时间:2025.01.16

用户在服务商/子商户小程序端选择微信支付后,服务商需调用该接口在微信支付下单,生成用于调起支付的预支付交易会话标识(prepay_id)。

注意

服务商模式支持1-50笔订单进行合单支付。

接口说明

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

请求方式:【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。APPID是微信开放平台(移动应用)或微信公众平台(小程序、公众号)为开发者的应用程序提供的唯一标识。此处请填写小程序类型的APPID,并确保该combine_appidcombine_mchid有绑定关系。详见:商户号绑定APPID操作说明


 combine_mchid  必填   string(32)

【合单服务商商户号】 服务商(合单发起方)的商户号,是由微信支付系统生成并分配给每个商户的唯一标识符,具体请参考服务商模式开发必要参数说明


 combine_out_trade_no  必填   string(32)

【合单商户订单号】服务商系统内部订单号,要求6~32个字符内,只能是数字、大小写字母_-|*,且在同一个合单服务商商户号combine_mchid下唯一。


 scene_info  选填   object

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

属性

 device_id  选填   string(16)

【商户端设备号】 终端设备号(门店号或收银设备ID)。


 payer_client_ip  必填   string(45)

【用户终端IP】 用户端实际IP,支持IPv4和IPv6两种格式的IP地址。IP获取请参考获取用户IP指引


 sub_orders  必填   array[UnionSubOrder]

【商品单信息】 商品单列表,一笔合单支付订单可支持1-50笔商品单交易。

属性

 mchid  必填   string(32)

【商品单商户号】 此处请填写服务商(合单发起方)的商户号combine_mchid


 attach  必填   string(128)

【商户数据包】服务商在创建订单时可传入自定义数据包,该数据对用户不可见,用于存储订单相关的服务商自定义信息,其总长度限制在128字符以内。支付成功后查询合单订单API合单订单支付成功回调通知均会将此字段返回给服务商,并且该字段还会体现在交易账单。


 amount  必填   object

【商品单金额信息】 商品单收款金额信息。

属性

 total_amount  必填   integer

【标价金额】商品单的金额,整型,单位为分。


 currency  必填   string(8)

【标价币种】 符合ISO 4217标准的三位字母代码,固定传:CNY,代表人民币。


 out_trade_no  必填   string(32)

【商品单商户订单号】 服务商系统内部订单号,要求6~32个字符内,只能是数字、大小写字母_-|*,且在同一个合单服务商商户号combine_mchid下唯一。


 sub_mchid  必填  string(32)

【子商户号(也叫特约商户号)】 商品单参与方,由服务商为子商户进件后获取,具体请参考服务商模式开发必要参数说明


 description  必填   string(127)

【商品描述】商品信息描述,用户微信账单的商品字段中可见(可参考小程序合单支付模式介绍-5、账单示意图),商户需传递能真实代表商品信息的描述,不能超过127个字符。


 settle_info  选填   object

【结算信息】 结算信息。

属性

 profit_sharing  选填   boolean

【分账标识】订单的分账标识在下单时设置,传入true表示在订单支付成功后可进行分账操作。以下是详细说明:

  • 需要分账(传入true):
    订单收款成功后,资金将被冻结并转入子商户基本账户的不可用余额。服务商可通过请求分账API,将收款资金分配给服务商或其他商户及用户。完成分账操作后,可通过接口解冻剩余资金,或在支付成功30天后自动解冻。

  • 不需要分账(传入false或不传,默认为false):
    订单收款成功后,资金不会被冻结,而是直接转入子商户基本账户的可用余额。


 sub_appid  选填   string(32)

【子商户APPID】是子商户在微信开放平台(移动应用)或公众平台(公众号/小程序)上申请的一个唯一标识。此处请填写小程序类型的APPID(只允许一笔商品单填写该参数),并确保该sub_appidsub_mchid有绑定关系。具体请参考商户号绑定APPID操作说明


 goods_tag  选填   string(32)

【订单优惠标记】代金券在创建时可以配置多个订单优惠标记,标记的内容由创券商户自定义设置。详细参考:创建代金券批次API
如果代金券有配置订单优惠标记,则必须在该参数传任意一个配置的订单优惠标记才能使用券。
如果代金券没有配置订单优惠标记,则可以不传该参数。

示例:
如有两个活动,活动A设置了两个优惠标记:WXG1、WXG2;活动B设置了两个优惠标记:WXG1、WXG3;
下单时优惠标记传WXG2,则订单参与活动A的优惠;
下单时优惠标记传WXG3,则订单参与活动B的优惠;
下单时优惠标记传共同的WXG1,则订单参与活动A、B两个活动的优惠;


 combine_payer_info  必填   object

【合单支付者信息】 合单支付者信息,openidsub_openid二选一必填。

属性

 openid  选填   string(128)

【用户服务商标识】 用户在合单服务商商户号绑定的combine_appid下的唯一标识,获取方式详见OpenID获取


 sub_openid  选填   string(128)

【用户子商户标识】 用户在子商户号绑定的sub_appid下的唯一标识,传了此参数则sub_appid必填,获取方式详见OpenID获取


 time_expire  选填   string

【支付结束时间】

1、定义:支付结束时间是指用户能够完成该笔订单支付的最后时限,并非订单关闭的时间。超过此时间后,用户将无法对该笔订单进行支付。如商户需在超时后关闭订单,请调用关闭合单订单API接口。

2、格式要求:支付结束时间需遵循rfc3339标准格式:yyyy-MM-DDTHH:mm:ss+TIMEZONEyyyy-MM-DD 表示年月日;T 字符用于分隔日期和时间部分;HH:mm:ss 表示具体的时分秒;TIMEZONE 表示时区(例如,+08:00 对应东八区时间,即北京时间)。

示例:2015-05-20T13:29:35+08:00 表示北京时间2015年5月20日13点29分35秒。

3、若未指定支付结束时间,系统默认以下单时间为起始点计算时效;超过 7 天未支付的订单,无法再支付。

4、注意事项:

  • 若当前实际时间已超过订单设置的支付结束时间(time_expire),建议先使用关单接口关闭订单,再使用新的商户订单号重新下单,生成全新订单供用户支付。

  • 支付结束时间不能早于下单时间后1分钟,若设置的支付结束时间早于该时间,系统将自动调整为下单时间后1分钟作为支付结束时间。

  • 传递的支付结束时间需在下单时间的7天以内,如超过7天,微信支付会自动将该时间调整为下单时间后的第7天。


 notify_url  选填   string(255)

【商户回调地址】服务商接收合单订单支付成功回调通知的地址,需按照notify_url填写注意事项规范填写。

请求示例

curl
Java
Go

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        "sub_mchid" : "1900000109",
13        "sub_appid" : "wxd678efh567hg6999",
14        "out_trade_no" : "20150806125346",
15        "amount" : {
16          "total_amount" : 10,
17          "currency" : "CNY"
18        },
19        "attach" : "深圳分店",
20        "description" : "Image形象店-深圳腾大-QQ公仔",
21        "goods_tag" : "WXG",
22        "settle_info" : {
23          "profit_sharing" : false
24        }
25      }
26    ],
27    "combine_payer_info" : {
28      "openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o",
29      "sub_openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"
30    },
31    "combine_out_trade_no" : "P20150806125346",
32    "notify_url" : "https://yourapp.com/notify",
33    "combine_mchid" : "1230000109",
34    "scene_info" : {
35      "device_id" : "POS1:1",
36      "payer_client_ip" : "127.0.0.1"
37    }
38  }'
39

应答参数

 prepay_id  必填   string(64)

【预支付交易会话标识】预支付交易会话标识,小程序调起支付时需要使用的参数,有效期为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

商户无权限

请商户联系对接运营申请此接口相关权限,参考:权限申请

403

OUT_TRADE_NO_USED

商户订单号重复

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

403

RULELIMIT

业务规则限制

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

429

FREQUENCY_LIMITED

频率超限

请降低请求接口频率

500

OPENID_MISMATCH

OpenID和AppID不匹配

请确认OpenID和AppID是否匹配,参考:OpenID获取

500

SYSTEMERROR

系统错误

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

 

 

元宝AI
反馈
目录
置顶