小程序支付下单
更新时间:2024.11.18商户系统先调用该接口在微信支付服务后台生成预支付交易单,返回正确的预支付交易会话标识后再按Native、JSAPI、APP等不同场景生成交易串调起支付。
接口说明
支持商户:【普通服务商】
请求方式:【POST】/v3/pay/partner/transactions/miniprogram
请求域名:【主域名】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 包体参数
sp_appid 选填 string(32)
【合作伙伴小程序AppID】 用户在合作伙伴的小程序内选购并付款的微信小程序AppID。与特约商户小程序AppID(sub_appid)二选一必填。
支付过程中将基于该ID验证对应的用户标识(OpenID)。
sp_mchid 必填 string(32)
【合作伙伴商户号】 合作伙伴商户号,由微信支付生成并下发。
sub_appid 选填 string(32)
【特约商户小程序AppID】 用户在特约商户的小程序内选购并付款的微信小程序AppID。与合作伙伴小程序AppID(sp_appid)二选一必填。
支付过程中将基于该ID验证对应的用户标识(OpenID)。
sub_mchid 必填 string(32)
【特约商户号】 特约商户号,由微信支付生成并下发。
description 必填 string(127)
【商品描述】 商品描述。
out_trade_no 必填 string(32)
【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。
time_expire 选填 string(64)
【支付结束时间】
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分钟作为支付结束时间。
传递的支付结束时间需在下单时间的15天以内,如超过15天,微信支付会自动将该时间调整为下单时间后的第15天。
attach 选填 string(128)
【附加数据】 附加数据,在查询API和支付通知中原样返回,可作为自定义参数使用,实际情况下只有支付完成状态才会返回该字段。
notify_url 选填 string(255)
【通知地址】 异步接收微信支付结果通知的回调地址,通知URL必须为通过公网可访问的HTTPS协议域名,且不能携带参数。
goods_tag 选填 string(32)
【订单优惠标记】 订单优惠标记。
support_fapiao 选填 boolean
【电子发票入口开放标识】 传入true时,支付成功消息和支付详情页将出现开票入口。需要在微信支付商户平台或微信公众平台开通电子发票功能,传此字段才可生效。
true:是
false:否
amount 必填 object
【订单金额】 订单金额信息。
| 属性 | |
total 必填 integer 【总金额】 订单总金额,单位为分,只能为整数,详见交易金额。 currency 选填 string(32) 【货币类型】 符合 ISO 4217 标准的三位字母代码,目前 只支持人民币:CNY。 |
payer 必填 object
【支付者 】 支付者信息。
| 属性 | |
sp_openid 选填 string(128) 【用户标识】 用户在合作伙伴小程序AppID的唯一标识。与用户子标识(sub_openid)二选一必填。 sub_openid 选填 string(128) 【用户子标识】 用户在特约商户小程序AppID的唯一标识。与用户标识(sp_openid)二选一必填。 |
detail 选填 object
【优惠功能】 优惠功能。
| 属性 | |||||
cost_price 选填 integer 【订单原价】 1.商户侧一张小票订单可能被分多次支付,订单原价用 于记录整张小票的交易金额。 2.当订单原价与支付金额不相等,则不享受优惠。 3.该字段主要用于防止同一张小票分多次支付,以享受 多次优惠的情况,正常支付订单不必上传此参数。 invoice_id 选填 string(32) 【商品小票 ID】 商家小票 ID。 goods_detail 选填 array[object] 【单品列表】 单品列表。
|
scene_info 选填 object
【场景信息】 若在门店使用小程序支付,可主动上报交易实际门店信息,支持填写商户自定义门店编号或微信支付分配的门店编号。
| 属性 | |||||
payer_client_ip 选填 string(45) 【用户终端IP】 用户终端IP。 device_id 选填 string(32) 【商户端设备号】 商户端设备号。 store_info 选填 object 【商户门店信息】 商户门店信息。
|
settle_info 选填 object
【结算信息】 结算信息。
| 属性 | |
profit_sharing 选填 boolean 【是否指定分账】 是否指定分账,枚举值:true:是false:否。 |
请求示例
POST
应答参数
200 OK
prepay_id 必填 string(64)
【预支付交易会话标识】 预支付交易会话标识。用于后续接口调用中使用,该值有效期为2小时
应答示例
200 OK
错误码
公共错误码
状态码 | 错误码 | 描述 | 解决方案 |
|---|---|---|---|
400 | PARAM_ERROR | 参数错误 | 请根据错误提示正确传入参数 |
400 | INVALID_REQUEST | HTTP 请求不符合微信支付 APIv3 接口规则 | 请参阅 接口规则 |
401 | SIGN_ERROR | 验证不通过 | 请参阅 签名常见问题 |
500 | SYSTEM_ERROR | 系统异常,请稍后重试 | 请稍后重试 |

