统一下单

更新时间:2025.03.21

H5支付是指商户在微信客户端外的移动端网页展示商品或服务,用户在前述页面确认使用微信支付时,商户发起本服务呼起微信客户端进行支付。
主要用于触屏版的手机浏览器请求微信支付的场景。可以方便的从外部浏览器唤起微信支付。

注意:

H5支付不建议在APP端使用,如需要在APP中使用微信支付,请接APP支付,文档详见APP支付

接口说明

适用对象: 直连模式 机构模式

请求URL: https://apihk.mch.weixin.qq.com/pay/unifiedorder

请求方式: POST

是否需要证书:

输入参数

参数名

变量名

类型

必填

描述

公众账号ID

appid

String(32)

微信分配的公众账号ID
示例值:wx8888888888888888

商户号

mch_id

String(32)

微信支付分配的商户号
示例值:1230000109

子商户号

sub_mch_id

String(32)

微信支付分配的子商户号
注意:仅适用于机构模式
示例值:1900000109

设备号

device_info

String(32)

终端设备号(门店号或收银设备ID),注意:PC网页或公众号内支付请传"WEB"
示例值:013467007045764

随机字符串

nonce_str

String(32)

随机字符串,不长于32位。推荐随机数生成算法
示例值:5K8264ILTKCH16CQ2502SI8ZNMTM67VS

签名

sign

String(64)

签名,详见签名生成算法
示例值:C380BEC2BFD727A4B6845133519F3AD6

签名类型

sign_type

String(32)

签名类型,目前支持HMAC-SHA256和MD5,默认为MD5
示例值:HMAC-SHA256

商品描述

body

String(127)

请按以下规范上传body 字段:
使用场景| 支付模式| 商品字段规则| 样例| 备注
PC 网站| 扫码支付| 浏览器打开的网站 主页title 名-实际商品名称| 腾讯充值 中心-QQ 会员充值|
微信浏览器| 公众号支付| 商家名称-销 售商品类目| 罗辑思维-图书| 线上电 商,商家名称必须为实际销售商品的商 家
门店扫码| 公众号支付| 店名-销售商品 类目| 天虹南山店-超市| 线下门店支付
门店扫码| 扫码支付| 店名-销售商品类 目| 天虹南山店-超市| 线下门店支付
门店刷卡| 刷卡支付| 店名-销售商品类 目| 天虹南山店-超市| 线下门店支付
第三方手机浏览器| H5 支付| 浏览器打 开的移动网页的主页title 名-实际商品 名称| 腾讯充值中心-QQ 会员充值|
第三方APP | APP 支付| 应用市场上的 APP 名字-实际商品名称| 天天爱消除- 游戏充值
示例值:Ipad mini 16G 白色

商品详情

detail

String(6000)

商品详情

附加数据

attach

String(127)

附加数据,在查询API和支付通知中原样返回,该字段主要用于商户携带订单的自定义数据
示例值:说明

商户订单号

out_trade_no

String(32)

商户系统内部订单号,要求32个字符内,只能是数字、大小写字母_-|*且在同一个商户号下唯一。 其他说明见商户订单号
示例值:1217752501201407033233368018

标价币种

fee_type

String(8)

符合ISO 4217标准的三位字母代码,列表详见货币类型
示例值:USD

标价金额

total_fee

int

订单总金额,只能为整数,详见标价金额
示例值:888

终端IP

spbill_create_ip

String(64)

支持IPV4和IPV6两种格式的IP地址,H5支付场景下为实际支付用户端的IP,获取用户端IP请参考获取用户IP指引
示例值:8.8.8.8

交易起始时间

time_start

String(14)

订单生成时间,格式为yyyyMMddHHmmss,如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则
示例值:20091225091010

交易结束时间

time_expire

String(14)

订单失效时间,格式为yyyyMMddHHmmss,如2009年12月27日9点10分10秒表示为20091227091010。
示例值:20091227091010

商品标记

goods_tag

String(32)

商品标记,该字段不能随便填,不使用请填空
示例值:goods_tag

通知地址

notify_url

String(256)

接收微信支付异步通知回调地址
示例值:http://www.weixin.qq.com/

交易类型

trade_type

String(16)

取值:MWEB,详细说明见参数规定
示例值:MWEB

限定支付方式

limit_pay

String(32)

商户限定支付方式: no_credit--指定不能使用信用卡支付
示例值:no_credit

场景信息

scene_info

string(256)

该字段用于统一下单时上报场景信息,目前支持上报实际门店信息。
{
"store_id": "", //门店唯一标识,选填,string(32)
"store_name":"”//门店名称,选填,string(64)
}
示例值:{ "store_id": "SZT10000", "store_name":"腾讯大厦腾大餐厅" }

举例如下:

XML
1<xml>
2   <appid>wxce926ea78004260e</appid>
3   <body>An apple</body>
4   <device_info>123001</device_info>
5   <fee_type>USD</fee_type>
6   <mch_id>1900012291</mch_id>
7   <nonce_str>f6868b9b16bf4893958afd4a46d73422</nonce_str>
8   <notify_url>https://localhost/api/apm/notify/wechat</notify_url>
9   <out_trade_no>1678371718207331</out_trade_no>
10   <spbill_create_ip>14.23.150.211</spbill_create_ip>
11   <sign>FA5B2EA0A6FD392DBE322A54F3902C00</sign>
12   <sub_mch_id>11611403</sub_mch_id>
13   <total_fee>1</total_fee>
14   <trade_type>MWEB</trade_type>
15</xml>

注:参数值用XML转义即可,CDATA标签用于说明数据不被XML解析器解析。

返回结果

字段名

变量名

类型

必填

描述

返回状态码

return_code

string(16)

SUCCESS/FAIL
此字段是通信标识,非交易标识,交易是否成功需要查看result_code来判断
示例值:SUCCESS

返回信息

return_msg

String(128)

返回信息,如非空,为错误原因
签名失败
参数格式校验错误
示例值:签名失败

以下字段在return_code为SUCCESS的时候有返回

字段名

变量名

类型

必填

描述

公众账号ID

appid

String(32)

微信分配的公众账号ID
示例值:wx8888888888888888

商户号

mch_id

String(32)

微信支付分配的商户号
示例值:1900000109

子商户号

sub_mch_id

String(32)

微信支付分配的子商户号
注意:仅适用于机构模式
示例值:1900000109

设备号

device_info

String(32)

调用接口提交的终端设备号。
示例值:013467007045764

随机字符串

nonce_str

String(32)

微信返回的随机字符串
示例值:5K8264ILTKCH16CQ2502SI8ZNMTM67VS

签名

sign

String(64)

微信返回的签名,详见签名算法
示例值:C380BEC2BFD727A4B6845133519F3AD6

业务结果

result_code

String(16)

SUCCESS/FAIL
示例值:SUCCESS

错误代码

err_code

String(32)

详细参见错误列表
示例值:SYSTEMERROR

错误代码描述

err_code_des

String(128)

错误返回的信息描述
示例值:系统错误

以下字段在return_code 和result_code都为SUCCESS的时候有返回

字段名

变量名

类型

必填

描述

交易类型

trade_type

string(16)

调用接口提交的交易类型,详细说明见参数规定
示例值:MWEB

预支付交易会话标识

prepay_id

String(64)

微信生成的预支付会话标识,用于后续接口调用中使用,该值有效期为2小时
示例值:wx201410272009395522657a690389285100

支付跳转链接

mweb_url

String(512)

mweb_url 为拉起微信支付收银台的目标url,可通过访问此url 来拉起微信支付收银台。
示例值:https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx2016121516420242444321ca0631331346&package=1405458241

举例如下:

XML
1<xml>
2   <return_code><![CDATA[SUCCESS]]></return_code>
3   <return_msg><![CDATA[OK]]></return_msg>
4   <appid><![CDATA[wx2421b1c4370ec43b]]></appid>
5   <mch_id><![CDATA[10000100]]></mch_id>
6   <nonce_str><![CDATA[IITRi8Iabbblz1Jc]]></nonce_str>
7   <sign><![CDATA[7921E432F65EB8ED0CE9755F0E86D72F]]></sign>
8   <result_code><![CDATA[SUCCESS]]></result_code>
9   <prepay_id><![CDATA[wx201411101639507cbf6ffd8b0779950874]]></prepay_id>
10   <trade_type><![CDATA[MWEB]]></trade_type>
11   <mweb_url><![CDATA[https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx2016121516420242444321ca0631331346&package=1405458241]]></mweb_url>
12</xml>

错误码

名称

描述

原因

解决方案

INVALID_REQUEST

参数错误

参数格式有误或者未按规则上传

订单重入时,要求参数值与原请求一致,请确认参数问题

NOAUTH

商户无此接口权限

商户未开通此接口权限

请商户前往申请此接口权限

NOTENOUGH

余额不足

用户账号余额不足

用户账号余额不足,请用户充值或更换支付卡后再支付

ORDERPAID

商户订单已支付

商户订单已支付,无需重复操作

商户订单已支付,无需更多操作

ORDERCLOSED

订单已关闭

当前订单已关闭,无法支付

当前订单已关闭,请重新下单

SYSTEMERROR

系统错误

系统超时

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

APPID_NOT_EXIST

APPID不存在

参数中缺少APPID

请检查APPID是否正确

MCHID_NOT_EXIST

MCHID不存在

参数中缺少MCHID

请检查MCHID是否正确

APPID_MCHID_NOT_MATCH

appid和mch_id不匹配

appid和mch_id不匹配

请确认appid和mch_id是否匹配

LACK_PARAMS

缺少参数

缺少必要的请求参数

请检查参数是否齐全

OUT_TRADE_NO_USED

商户订单号重复

同一笔交易不能多次提交

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

SIGNERROR

签名错误

参数签名结果不正确

请检查签名参数和方法是否都符合签名算法要求

XML_FORMAT_ERROR

XML格式错误

XML格式错误

请检查XML参数格式是否正确

REQUIRE_POST_METHOD

请使用post方法

未使用post传递参数 

请检查请求参数是否通过post方法提交

POST_DATA_EMPTY

post数据为空

post数据不能为空

请检查post数据是否为空

NOT_UTF8

编码格式错误

未使用指定编码格式

请使用UTF-8编码格式

 

 

About  WeChat  Pay

Powered By Tencent & Tenpay Copyright©

2005-2025 Tenpay All Rights Reserved.

Contact Us
Wechat Pay Global

WeChat Pay Global

Contact Us

Customer Service Tel

+86 571 95017

9:00-18:00 Monday-Friday GMT+8

Business Development

wxpayglobal@tencent.com

Developer Support

wepayTS@tencent.com

Wechat Pay Global

About Tenpay
Powered By Tencent & Tenpay Copyright© 2005-2025 Tenpay All Rights Reserved.