小程序下单

更新时间:2024.12.30

商户系统先调用该接口在微信支付服务后台生成预支付交易单,返回正确的预支付交易会话标识后再按Native、JSAPI、APP等不同场景生成交易串调起支付。

# 接口说明

支持商户:
【电商平台】
请求方式:
【POST】/v3/pay/partner/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 包体参数
  • sp_appid 必填 string(32)
    【服务商应用ID】 由微信生成的应用ID,全局唯一。请求基础下单接口时请注意AppID的应用属性,例如公众号场景下,需使用应用属性为公众号的服务号AppID
  • sp_mchid 必填 string(32)
    【服务商户号】 服务商户号,由微信支付生成并下发
  • sub_appid 选填 string(32)
    【子商户/二级商户应用ID】 子商户/二级商户在开放平台申请的应用AppID,全局唯一。请求基础下单接口时请注意AppID的应用属性,例如公众号场景下,需使用应用属性为公众号的APPID,若sub_openid有传的情况下,sub_appid必填,且sub_appid需与sub_openid对应
  • sub_mchid 必填 string(32)
    【子商户号/二级商户号】 子商户/二级商户的商户号,由微信支付生成并下发。
  • description 必填 string(127)
    【商品描述】 商品描述
  • out_trade_no 必填 string(32)
    【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。
  • time_expire 选填 string(64)
    【交易结束时间】 订单失效时间,遵循rfc3339标准格式,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC8小时,即北京时间)。例如:2015-05-20T13:29:35+08:00表示,北京时间2015年5月20日13点29分35秒。
  • attach 选填 string(128)
    【附加数据】 附加数据,在查询API和支付通知中原样返回,可作为自定义参数使用,实际情况下只有支付完成状态才会返回该字段。
  • notify_url 必填 string(255)
    【通知地址】 异步接收微信支付结果通知的回调地址,通知URL必须为外网可访问的URL,不能携带参数。 公网域名必须为HTTPS,如果是走专线接入,使用专线NAT IP或者私有回调域名可使用HTTP
  • goods_tag 选填 string(32)
    【订单优惠标记】 订单优惠标记
  • settle_info 选填 PartnerSettleInfo
    【结算信息】 结算信息
    • 属性
  • support_fapiao 选填 boolean
    【电子发票入口开放标识】 传入true时,支付成功消息和支付详情页将出现开票入口。需要在微信支付商户平台或微信公众平台开通电子发票功能,传此字段才可生效。
    true:是
    false:否
  • amount 必填 CommReqAmountInfo
    【订单金额】 订单金额信息
    • 属性
  • payer 必填 PartnerJsapiReqPayerInfo
    【支付者 】 支付者信息。
    sp_openid 和 sub_openid 两个字段必须要填一个
    • 属性
  • detail 选填 OrderDetail
    【优惠功能】 优惠功能
    • 属性
  • scene_info 选填 CommReqSceneInfo
    【场景信息】 支付场景描述
    • 属性

请求示例

POST
1curl -X POST \
2 https://api.mch.weixin.qq.com/v3/pay/partner/transactions/jsapi \
3 -H "Authorization: WECHATPAY2-SHA256-RSA2048 mchid=\"1900000001\",..." \
4 -H "Accept: application/json" \
5 -H "Content-Type: application/json" \
6 -d '{
7 "sp_appid" : "wx8888888888888888",
8 "sp_mchid" : "1230000109",
9 "sub_appid" : "wxd678efh567hg6999",
10 "sub_mchid" : "1900000109",
11 "description" : "Image形象店-深圳腾大-QQ公仔",
12 "out_trade_no" : "1217752501201407033233368018",
13 "time_expire" : "2018-06-08T10:34:56+08:00",
14 "attach" : "自定义数据",
15 "notify_url" : " https://www.weixin.qq.com/wxpay/pay.php",
16 "goods_tag" : "WXG",
17 "settle_info" : {
18 "profit_sharing" : true,
19 "subsidy_amount" : 100
20 },
21 "support_fapiao" : true,
22 "amount" : {
23 "total" : 100,
24 "currency" : "CNY"
25 },
26 "payer" : {
27 "sp_openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o\t",
28 "sub_openid" : "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o\t"
29 },
30 "detail" : {
31 "cost_price" : 608800,
32 "invoice_id" : "微信123",
33 "goods_detail" : [
34 {
35 "merchant_goods_id" : "1246464644",
36 "wechatpay_goods_id" : "1001",
37 "goods_name" : "iPhoneX 256G",
38 "quantity" : 1,
39 "unit_price" : 528800
40 }
41 ]
42 },
43 "scene_info" : {
44 "payer_client_ip" : "14.23.150.211",
45 "device_id" : "013467007045764",
46 "store_info" : {
47 "id" : "0001",
48 "name" : "腾讯大厦分店",
49 "area_code" : "440305",
50 "address" : "广东省深圳市南山区科技中一道10000号"
51 }
52 }
53 }'

# 应答参数

    200OK
  • prepay_id 必填 string(64)
    【预支付交易会话标识】 预支付交易会话标识。用于后续接口调用中使用,该值有效期为2小时

应答示例

200 OK
1{
2 "prepay_id" : "wx201410272009395522657a690389285100"
3}

# 错误码

# 公共错误码

状态码 错误码 描述 解决方案
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是否匹配
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 系统错误 系统异常,请用相同参数重新调用
反馈
咨询
目录

您当前查看的是旧版文档,将于 2025年 3 月 31日 进行下线处理。为了获得最新的内容和产品能力,请点击 [这里] 访问新版文档中心