小程序拉起支付

更新时间:2025.01.07

商户通过在小程序内调用wx.requestPayment(OBJECT)发起微信支付。


1. 接口说明

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

2. 接口定义

小程序调起支付数据签名字段列表

参数名

变量

类型[长度限制]

必填

描述

小程序id

appId

string[1,32]

商户注册小程序成功后即可获得
示例值:wx8888888888888888

时间戳

timeStamp

string[1,32]

当前的时间,其他详见时间戳规则
示例值:1414561699

随机字符串

nonceStr

string[1,32]

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

订单详情扩展字符串

package

string[1,128]

JSAPI下单接口返回的prepay_id参数值,提交格式如:prepay_id=***
示例值:prepay_id=wx201410272009395522657a690389285100

3. paySign生成规则

3.1.构造签名串

签名串一共有四行,每一行为一个参数。行尾以\n(换行符,ASCII编码值为0x0A)结束,包括最后一行。 如果参数本身以\n结束,也需要附加一个\n

参与签名字段及格式:

1   公众号id
2   时间戳
3   随机字符串
4   订单详情扩展字符串

待签名串举例:

1   wx8888888888888888
2   1414561699
3   5K8264ILTKch16CQ2502SI8ZNMTM67VS
4   prepay_id=123456789

3.2. 计算签名值:

绝大多数编程语言提供的签名函数支持对签名数据 进行签名。强烈建议商户调用该类函数,使用商户私钥对待签名串进行SHA256 with RSA签名,并对签名结果进行Base64编码得到签名值。

下面我们使用命令行演示如何生成签名。

1$ echo -n -e \
2"wx8888888888888888\n1414561699\n5K8264ILTKCH16CQ2502SI8ZNMTM67VS\nprepay_id=wx201410272009395522657a690389285100\n" \
3  | openssl dgst -sha256 -sign apiclient_key.pem \
4  | openssl base64 -A
5  uOVRnA4qG/MNnYzdQxJanN+zU+lTgIcnU9BxGw5dKjK+VdEUz2FeIoC+D5sB/LN+nGzX3hfZg6r5wT1pl2ZobmIc6p0ldN7J6yDgUzbX8Uk3sD4a4eZVPTBvqNDoUqcYMlZ9uuDdCvNv4TM3c1WzsXUrExwVkI1XO5jCNbgDJ25nkT/c1gIFvqoogl7MdSFGc4W4xZsqCItnqbypR3RuGIlR9h9vlRsy7zJR9PBI83X8alLDIfR1ukt1P7tMnmogZ0cuDY8cZsd8ZlCgLadmvej58SLsIkVxFJ8XyUgx9FmutKSYTmYtWBZ0+tNvfGmbXU7cob8H/4nLBiCwIUFluw==

注意

signType参数不参与签名,但需要传递,默认值为“RSA”,生成的签名需要通过字段paySign传递。

4. 商户通过在小程序内调用wx.requestPayment(OBJECT)发起微信支付

接口名称: wx.requestPayment,详见小程序API文档

Object参数说明:

参数名

变量

类型[长度限制]

必填

描述

时间戳

timeStamp

string[1,32]

当前的时间,其他详见时间戳规则
示例值:1414561699

随机字符串

nonceStr

string[1,32]

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

订单详情扩展字符串

package

string[1,128]

JSAPI下单接口返回的prepay_id参数值,提交格式如:prepay_id=***
示例值:prepay_id=wx201410272009395522657a690389285100

签名方式

signType

string[1,32]

签名类型,默认为RSA,该参数不参与签名
示例值:RSA

签名

paySign

string[1,64]

签名,使用字段appId、timeStamp、nonceStr、package计算得出的签名值
示例值:C380BEC2BFD727A4B6845133519F3AD6

回调结果

回调类型

errMsg

说明

success

requestPayment:ok

调用支付成功

fail

requestPayment:fail cancel

用户取消支付

fail

requestPayment:fail (detail message)

调用支付失败,其中 detail message 为后台返回的详细失败原因

示例代码如下:

示例

1wx.requestPayment
2(
3	{
4		"timeStamp": "1414561699",
5		"nonceStr": "5K8264ILTKCH16CQ2502SI8ZNMTM67VS",
6		"package": "prepay_id=wx201410272009395522657a690389285100",
7		"signType": "RSA",
8		"paySign": "oR9d8PuhnIc+YZ8cBHFCwfgpaK9gd7vaRvkYD7rthRAZ\/X+QBhcCYL21N7cHCTUxbQ+EAt6Uy+lwSN22f5YZvI45MLko8Pfso0jm46v5hqcVwrk6uddkGuT+Cdvu4WBqDzaDjnNa5UK3GfE1Wfl2gHxIIY5lLdUgWFts17D4WuolLLkiFZV+JSHMvH7eaLdT9N5GBovBwu5yYKUR7skR8Fu+LozcSqQixnlEZUfyE55feLOQTUYzLmR9pNtPbPsu6WVhbNHMS3Ss2+AehHvz+n64GDmXxbX++IOBvm2olHu3PsOUGRwhudhVf7UcGcunXt8cqNjKNqZLhLw4jq\/xDg==",
9		"success":function(res){},
10		"fail":function(res){},
11		"complete":function(res){}
12	}
13)

 

 

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.