JSAPI下单并授权
更新时间:2024.09.06商户系统先通过预签约生成token或者用户免密签约后,再调用该接口在微信支付服务后台生成预支付交易单,返回正确的预支付交易会话标识后再按JSAPI方式调起支付。
# 接口说明
支持商户:
【普通服务商】【平台商户】
请求方式:
【POST】/v3/pay/partner/transactions/jsapi-with-contract
请求域名:
【主域名】
https://api.mch.weixin.qq.com
使用该域名将访问就近的接入点【备域名】
https://api2.mch.weixin.qq.com
使用该域名将访问异地的接入点 ,指引点击查看
# 请求参数
- Authorization 必填请参考 签名认证 生成认证信息
- Accept 必填请设置为
application/json
- Content-Type 必填请设置为
application/json
Header HTTP头参数
- sp_appid 必填【服务商应用ID】 由微信生成的应用ID,全局唯一。请求基础下单接口时请注意AppID的应用属性,例如公众号场景下,需使用应用属性为公众号的服务号AppID
- sp_mchid 必填【服务商户号】 服务商户号,由微信支付生成并下发
- sub_appid 选填【子商户/二级商户应用ID】 子商户/二级商户在开放平台申请的应用AppID,全局唯一。请求基础下单接口时请注意AppID的应用属性,例如公众号场景下,需使用应用属性为公众号的APPID
若sub_openid有传的情况下,sub_appid必填,且sub_appid需与sub_openid对应 - sub_mchid 必填【子商户号/二级商户号】 子商户/二级商户的商户号,由微信支付生成并下发。
- description 必填【商品描述】 商品描述
- out_trade_no 必填【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。
- time_expire 选填【交易结束时间】 订单失效时间,遵循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 选填【附加数据】 附加数据,在查询API和支付通知中原样返回,可作为自定义参数使用,实际情况下只有支付完成状态才会返回该字段。
- notify_url 必填【通知地址】 异步接收微信支付结果通知的回调地址,通知URL必须为外网可访问的URL,不能携带参数。 公网域名必须为HTTPS,如果是走专线接入,使用专线NAT IP或者私有回调域名可使用HTTP
- goods_tag 选填【订单优惠标记】 订单优惠标记
- settle_info 选填【结算信息】 结算信息
- 属性
- support_fapiao 选填【电子发票入口开放标识】 传入true时,支付成功消息和支付详情页将出现开票入口。需要在微信支付商户平台或微信公众平台开通电子发票功能,传此字段才可生效。
true:是
false:否 - amount 必填【订单金额】 订单金额信息
- 属性
- payer 必填【支付者 】 支付者信息。
sp_openid 和 sub_openid 两个字段必须要填一个- 属性
- detail 选填【优惠功能】 优惠功能
- 属性
- scene_info 选填【场景信息】 支付场景描述
- 属性
- contract_info 必填【签约授权信息】 扣费服务预签约或免密签约信息
- 属性
Body 包体参数
请求示例
POST
# 应答参数
- prepay_id 必填【预支付交易会话标识】 预支付交易会话标识。用于后续接口调用中使用,该值有效期为2小时
200OK
应答示例
200 OK
# 错误码
# 公共错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|---|---|---|
400 | PARAM_ERROR | 参数错误 | 请根据错误提示正确传入参数 |
400 | INVALID_REQUEST | HTTP 请求不符合微信支付 APIv3 接口规则 | 请参阅 接口规则 |
401 | SIGN_ERROR | 验证不通过 | 请参阅 签名常见问题 |
500 | SYSTEM_ERROR | 系统异常,请稍后重试 | 请稍后重试 |
# 业务错误码
状态码 | 错误码 | 描述 | 解决方案 |
---|
文档是否有帮助