小程序合单下单
更新时间:2025.01.16用户在服务商/子商户小程序端选择微信支付后,服务商需调用该接口在微信支付下单,生成用于调起支付的预支付交易会话标识(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)
【合单服务商APPID】服务商(合单发起方)的APPID。APPID是微信开放平台(移动应用)或微信公众平台(小程序、公众号)为开发者的应用程序提供的唯一标识。此处请填写小程序类型的APPID,并确保该combine_appid与combine_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) 【商品单商户号】 此处请填写服务商(合单发起方)的商户号 attach 必填 string(128) 【商户数据包】服务商在创建订单时可传入自定义数据包,该数据对用户不可见,用于存储订单相关的服务商自定义信息,其总长度限制在128字符以内。支付成功后查询合单订单API和合单订单支付成功回调通知均会将此字段返回给服务商,并且该字段还会体现在交易账单。 amount 必填 object 【商品单金额信息】 商品单收款金额信息。
out_trade_no 必填 string(32) 【商品单商户订单号】 服务商系统内部订单号,要求6~32个字符内,只能是数字、大小写字母_-|*,且在同一个合单服务商商户号 sub_mchid 必填 string(32) 【子商户号(也叫特约商户号)】 商品单参与方,由服务商为子商户进件后获取,具体请参考服务商模式开发必要参数说明。 description 必填 string(127) 【商品描述】商品信息描述,用户微信账单的商品字段中可见(可参考小程序合单支付模式介绍-5、账单示意图),商户需传递能真实代表商品信息的描述,不能超过127个字符。 settle_info 选填 object 【结算信息】 结算信息。
sub_appid 选填 string(32) 【子商户APPID】是子商户在微信开放平台(移动应用)或公众平台(公众号/小程序)上申请的一个唯一标识。此处请填写小程序类型的APPID(只允许一笔商品单填写该参数),并确保该 goods_tag 选填 string(32) 【订单优惠标记】代金券在创建时可以配置多个订单优惠标记,标记的内容由创券商户自定义设置。详细参考:创建代金券批次API。 示例: |
combine_payer_info 必填 object
【合单支付者信息】 合单支付者信息,openid和sub_openid二选一必填。
| 属性 | |
openid 选填 string(128) 【用户服务商标识】 用户在合单服务商商户号绑定的 sub_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、若未指定支付结束时间,系统默认以下单时间为起始点计算时效;超过 7 天未支付的订单,无法再支付。
4、注意事项:
若当前实际时间已超过订单设置的支付结束时间(time_expire),建议先使用关单接口关闭订单,再使用新的商户订单号重新下单,生成全新订单供用户支付。
支付结束时间不能早于下单时间后1分钟,若设置的支付结束时间早于该时间,系统将自动调整为下单时间后1分钟作为支付结束时间。
传递的支付结束时间需在下单时间的7天以内,如超过7天,微信支付会自动将该时间调整为下单时间后的第7天。
notify_url 选填 string(255)
【商户回调地址】服务商接收合单订单支付成功回调通知的地址,需按照notify_url填写注意事项规范填写。
请求示例
POST
合单支付-JSAPI合单下单-请求示例
应答参数
prepay_id 必填 string(64)
【预支付交易会话标识】预支付交易会话标识,小程序调起支付时需要使用的参数,有效期为2小时,失效后需要重新请求该接口以获取新的prepay_id。
应答示例
200 OK
错误码
公共错误码
状态码 | 错误码 | 描述 | 解决方案 |
|---|---|---|---|
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 | 系统错误 | 系统异常,请用相同参数重新调用 |

