# 配置支付参数文件
- 1、打开
cloudfunctions/common/uni-config-center/uni-pay/config.js
(没有则新建) - 复制下方代码到
uni-pay/config.js
注意
- 配置文件是
.js
文件,不是.json
文件 - 配置文件是
.js
文件,不是.json
文件 - 配置文件是
.js
文件,不是.json
文件
# 完整的支付配置示例
注意:就算你只使用部分支付功能,如微信小程序支付,也需保留其他支付配置(其他支付配置不填即可,但不要直接删除其他配置,包括支付宝空白证书也不要删除)
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 原理:插件会自动获取当前运行的空间的 SpaceID,然后在 notifyUrl 配置里找对应匹配的SpaceID后面的回调地址
*/
"notifyUrl": {
// 测试环境服务空间
"mp-33d35e24-c2f3-47b4-80fc-7b23a6010e11": "https://fc-mp-33d35e24-c2f3-47b4-80fc-7b23a6010e11.next.bspapp.com/http/vk-pay",
// 线上环境服务空间(如果只有一个服务空间,则只需要配置线上环境服务空间即可)
"mp-5761d885-11b8-21b2-9122-22afeadcf669": "https://fc-mp-5761d885-11b8-21b2-9122-22afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
// 是否使用当面付接口来代替支付宝app支付(可免去申请支付宝APP支付的接口)
"alipayAppPayToH5Pay": false,
/**
* 微信支付官方商户配置
* 公共参数说明
* appId 微信后台的appId
* secret 微信后台的secret
* mchId 微信支付的商户id
* key 微信支付V2版本的api密钥
* pfx 微信支付V2版本的p12证书(apiclient_cert.p12)(退款需要)配置示例:"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'),
* v3Key 微信支付V3版本的api密钥
* appCertPath 微信支付V3版本需要用到的证书(apiclient_cert.pem)配置示例:"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
* appPrivateKeyPath 微信支付V3版本需要用到的证书(apiclient_key.pem)配置示例:"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
* version 启用支付的版本 2代表v2版本 3 代表v3版本,默认是2
* 特别注意: 因node18不支持v2版本的.p12证书,故建议使用v3版本
*/
"wxpay": {
// 微信 - 小程序支付(微信支付申请JSAPI支付)
"mp-weixin": {
"appId": "", // 小程序的appid
"secret": "", // 小程序的secret
"mchId": "", // 微信支付的商户id
"key": "", // v2的api key
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // v2需要用到的证书
"v3Key": "", // v3的api key
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - APP支付(微信支付申请APP支付)
"app-plus": {
"appId": "", // 微信开放平台下的移动应用的appid
"secret": "", // 微信开放平台下的移动应用的secret
"mchId": "", // 微信支付的商户id
"key": "", // v2的api key
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // v2需要用到的证书
"v3Key": "", // v3的api key
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - H5电脑网站二维码支付(微信支付申请Native支付)
"h5": {
"appId": "", // 可以是小程序或公众号或app开放平台下的应用的任意一个appid
"secret": "", // secret
"mchId": "", // 微信支付的商户id
"key": "", // v2的api key
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // v2需要用到的证书
"v3Key": "", // v3的api key
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 公众号支付(微信支付申请JSAPI支付)
"h5-weixin": {
"appId": "", // 公众号的appid
"secret": "", // 公众号的secret
"mchId": "", // 微信支付的商户id
"key": "", // v2的api key
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // v2需要用到的证书
"v3Key": "", // v3的api key
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 手机外部浏览器H5支付(微信支付申请H5支付)
"mweb": {
"appId": "", // 可以是小程序或公众号或app开放平台下的应用的任意一个appid
"secret": "", // secret
"mchId": "", // 微信支付的商户id
"key": "", // v2的api key
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // v2需要用到的证书
"v3Key": "", // v3的api key
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
// 场景信息,必填
"sceneInfo": {
"h5_info": {
"type": "Wap", // 此值固定Wap
"wap_url": "https://www.xxxxxx.com", // 你的H5首页地址,必须和你发起支付的页面的域名一致。
"wap_name": "网站名称", // 你的H5网站名称
}
},
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 转账到零钱(固定v3版本)(微信支付申请企业转账到零钱API)
"transfer": {
"appId": "", // 可以是小程序或公众号或app开放平台下的应用的任意一个appid
"mchId": "", // 微信支付的商户id
"v3Key": "", // api v3密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 商家应用证书
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 商家私钥证书
"wxpayPublicCertSn": "", // 微信支付公钥证书的序列号 参数获取教程:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/transfer3.html#参数的获取方式
"wxpayPublicCertContent": "", // 微信支付公钥内容 参数获取教程:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/transfer3.html#参数的获取方式
}
},
/**
* 支付宝官方商户配置
* 公共参数说明
* appId 支付宝开放平台的应用appId
* privateKey 应用私钥(支付宝商户私钥)
* alipayPublicCertPath [证书模式] 支付宝公钥证书路径地址 与之对应的 alipayPublicCertContent 为支付宝公钥证书内容(值可以是字符串也可以是Buffer)
* alipayRootCertPath [证书模式] 支付宝根证书路径地址 与之对应的 alipayRootCertContent 为支付宝根证书内容(值可以是字符串也可以是Buffer)
* appCertPath [证书模式] 应用证书路径地址 与之对应的 appCertPathContent 为应用证书内容(值可以是字符串也可以是Buffer)
* alipayPublicKey [密钥模式] 支付宝公钥(证书模式3个参数,密钥模式1个参数,选一种模式即可,密钥模式不支持转账到支付宝)
* sandbox 是否沙箱模式 true 沙箱模式 false 正常模式
*/
"alipay": {
// 支付宝 - 小程序支付配置(由于uni-id目前只支持密钥模式,所以小程序支付的配置默认也是密钥模式的配置)
"mp-alipay": {
"appId": "", // 支付宝小程序appid
"privateKey": "", // 支付宝商户私钥
"alipayPublicKey": "", // 支付宝公钥字符串
"sandbox": false
},
// 支付宝 - APP支付配置
"app-plus": {
"appId": "", // 支付宝开放平台的应用appId
"privateKey": "", // 支付宝商户私钥
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'), // 支付宝公钥路径
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'), // 支付宝根证书路径
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'), // 支付宝商户公钥路径
"sandbox": false
},
// 支付宝 - H5支付配置(包含:网站二维码、手机H5,需申请支付宝当面付接口权限)
"h5": {
"appId": "", // 支付宝开放平台的应用appId
"privateKey": "", // 支付宝商户私钥
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'), // 支付宝公钥路径
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'), // 支付宝根证书路径
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'), // 支付宝商户公钥路径
"sandbox": false
},
// 支付宝 - 转账到支付宝等资金转出接口,其中 appCertSn 和 alipayRootCertSn 通过工具获取,工具地址:https://vkunicloud.fsq.pub/getCertSn/
"transfer": {
"appId": "", // 支付宝开放平台的应用appId
"privateKey": "", // 支付宝商户私钥
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'), // 支付宝商户公钥路径
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'), // 支付宝根证书路径
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'), // 支付宝商户公钥路径
"sandbox": false
}
},
// ios内购相关
"appleiap": {
// ios内购支付
"app-plus": {
"password": "", // App 专用共享密钥,App 专用共享密钥是用于接收此 App 自动续期订阅收据的唯一代码。如果您要将此 App 转让给其他开发者或不想公开主共享密钥,建议使用 App 专用共享密钥。非自动续订场景不需要此参数
"timeout": 10000, // 请求超时时间,单位:毫秒
"receiptExpiresIn": 86400, // ios内购凭据有效期,单位:秒 86400 = 24小时 3600 = 1小时
"sandbox": true, // 是否是沙箱环境(正式上线时必须配置为false)
}
},
// 微信虚拟支付
"wxpay-virtual": {
// 微信 - 小程序支付
"mp-weixin": {
"appId": "", // 小程序的appid
"secret": "", // 小程序的secret
"mchId": "", // 商户id
"offerId": "", // 支付应用ID
"appKey": "", // 现网AppKey(正式环境)
"sandboxAppKey": "", // 沙箱AppKey
"rate": 100, // 代币兑换比例,比如1元兑换100代币,那么这里就是100,建议设置为100(需要开通虚拟支付的时候也设置成 1 人民币 = 100 代币)
"token": "", // 微信小程序通信的token,在开发 - 开发管理 - 消息推送 - Token(令牌)
"encodingAESKey": "", // 必须43位,微信小程序消息加密密钥,在开发 - 开发管理 - 消息推送 - EncodingAESKey(消息加解密密钥)
"sandbox": false, // 是否是沙箱环境(注意:沙箱环境异步回调可能有延迟,建议直接正式环境测试)
}
},
/**
* VksPay商户支付配置
* 支持个人无需营业执照即可签约开户,正规通道,非市面上的挂机免签。(同时也支持企业签约)
* 消费者付款资金直接进入您签约的支付宝、微信支付商户号里,支付资金由支付宝、微信支付官方结算,避免二次清算。
* 开户联系QQ:370725567
*/
"vkspay": {
"mchId": "", // 商户号
"key": "" // 商户key
},
// 抖音支付
"douyin": {
// 抖音小程序支付,请在支付配置信息中配置URL(服务器地址)为 https://vk-pay的url化地址/vk-pay-notify/
"mp-toutiao": {
"appId": "", // 抖音小程序的appId
"secret": "", // 抖音小程序的secret
"mchId": "", // 商户id(商户号)
"salt": "", // SALT,从支付信息 - 支付设置中获取
"token": "", // Token(令牌),从支付信息 - 支付设置中获取
"sandbox": false, // 是否是沙箱环境
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
# 分渠道支付配置示例
# 支付宝
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
// 是否使用当面付接口来代替支付宝app支付(可免去申请支付宝APP支付的接口)
"alipayAppPayToH5Pay": false,
/**
* 支付宝官方商户配置
* 公共参数说明
* appId 支付宝开放平台的应用appId
* privateKey 应用私钥
* alipayPublicCertPath [证书模式] 支付宝公钥证书路径地址 与之对应的 alipayPublicCertContent 为支付宝公钥证书内容(值可以是字符串也可以是Buffer)
* alipayRootCertPath [证书模式] 支付宝根证书路径地址 与之对应的 alipayRootCertContent 为支付宝根证书内容(值可以是字符串也可以是Buffer)
* appCertPath [证书模式] 应用证书路径地址 与之对应的 appCertPathContent 为应用证书内容(值可以是字符串也可以是Buffer)
* alipayPublicKey [密钥模式] 支付宝公钥(证书模式3个参数,密钥模式1个参数,选一种模式即可,密钥模式不支持转账到支付宝)
* sandbox 是否沙箱模式 true 沙箱模式 false 正常模式
*/
"alipay": {
// 支付宝 - 小程序支付配置(由于uni-id目前只支持密钥模式,所以小程序支付的配置默认也是密钥模式的配置)
"mp-alipay": {
"appId": "", // 支付宝小程序appid
"privateKey": "", // 支付宝商户私钥
"alipayPublicKey": "", // 支付宝公钥字符串
"sandbox": false
},
// 支付宝 - APP支付配置
"app-plus": {
"appId": "",
"privateKey": "",
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'),
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'),
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'),
"sandbox": false
},
// 支付宝 - H5支付配置(包含:网站二维码、手机H5,需申请支付宝当面付接口权限)
"h5": {
"appId": "",
"privateKey": "",
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'),
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'),
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'),
"sandbox": false
},
// 支付宝 - 转账到支付宝等资金转出接口
"transfer": {
"appId": "",
"privateKey": "",
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'),
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'),
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'),
"sandbox": false
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
# 微信支付
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
/**
* 微信支付官方商户配置
* 公共参数说明
* appId 微信后台的appId
* secret 微信后台的secret
* mchId 微信支付的商户id
* key 微信支付V2版本的api密钥
* pfx 微信支付V2版本的p12证书(apiclient_cert.p12)(退款需要)配置示例:"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'),
* v3Key 微信支付V3版本的api密钥
* appCertPath 微信支付V3版本需要用到的证书(apiclient_cert.pem)配置示例:"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // v3需要用到的证书
* appPrivateKeyPath 微信支付V3版本需要用到的证书(apiclient_key.pem)配置示例:"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // v3需要用到的证书
* version 启用支付的版本 2代表v2版本 3 代表v3版本,默认是2
* 特别注意: 因node18不支持v2版本的.p12证书,故建议使用v3版本
*/
"wxpay": {
// 微信 - 小程序支付
"mp-weixin": {
"appId": "", // 微信小程序的appId
"secret": "", // 微信小程序的secret(需要填写)
"mchId": "", // 微信支付的商户id
"key": "", // 微信支付V2版本的api密钥
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // 微信支付V2版本的api密钥
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - APP支付
"app-plus": {
"appId": "", // 微信开放平台下app的appId
"secret": "", // 微信开放平台下app的secret(app可不填此项)
"mchId": "", // 微信支付的商户id
"key": "", // 微信支付V2版本的api密钥
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // 微信支付V2版本的api密钥
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - H5网站二维码支付
"h5": {
"appId": "", // 微信公众号或小程序或app的appId(任意都可)
"secret": "", // 微信后台与之对应的secret(可不填此项)
"mchId": "", // 微信支付的商户id
"key": "", // 微信支付V2版本的api密钥
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // 微信支付V2版本的api密钥
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 公众号支付
"h5-weixin": {
"appId": "", // 微信公众号下app的appId
"secret": "", // 微信公众号的secret(需要填写)
"mchId": "", // 微信支付的商户id
"key": "", // 微信支付V2版本的api密钥
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // 微信支付V2版本的api密钥
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 手机外部浏览器H5支付
"mweb": {
"appId": "", // 微信公众号或小程序或app的appId(任意都可)
"secret": "", // 微信后台与之对应的secret(可不填此项)
"mchId": "", // 微信支付的商户id
"key": "", // 微信支付V2版本的api密钥
"pfx": fs.readFileSync(__dirname + '/wxpay/apiclient_cert.p12'), // 微信支付V2版本的api密钥
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
// 场景信息,必填
"sceneInfo": {
"h5_info": {
"type": "Wap", // 此值固定Wap
"wap_url": "https://www.xxxxxx.com", // 你的H5首页地址,必须和你发起支付的页面的域名一致。
"wap_name": "网站名称" // 你的H5网站名称
}
},
"version": 3, // 启用支付的版本 2代表v2版本 3 代表v3版本(因node18不支持v2版本的.p12证书,故建议使用v3版本)
},
// 微信 - 转账到零钱 v3版本
"transfer": {
"appId": "", // 微信公众号或小程序或app的appId(任意都可)
"mchId": "", // 微信支付的商户id
"v3Key": "", // 微信支付V3版本的api密钥
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'), // 微信支付V3版本需要用到的证书(apiclient_cert.pem)
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'), // 微信支付V3版本需要用到的证书(apiclient_key.pem)
"wxpayPublicCertSn": "", // 微信平台证书序列号,详见:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/transfer3.html#_7-2%E3%80%81%E6%89%B9%E9%87%8F%E6%A8%A1%E5%BC%8F
"wxpayPublicCertContent": "" // 微信平台证书内容,详见:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/transfer3.html#_7-2%E3%80%81%E6%89%B9%E9%87%8F%E6%A8%A1%E5%BC%8F
},
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# ios内购支付
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
// ios内购相关
"appleiap": {
// ios内购支付
"app-plus": {
"password": "", // 非自动续订场景不需要此参数
"timeout": 10000, // 请求超时时间,单位:毫秒
"receiptExpiresIn": 86400, // ios内购凭据有效期,单位:秒 86400 = 24小时 3600 = 1小时
"sandbox": true, // 是否是沙箱环境(正式上线时必须配置为false)
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# VksPay个人支付
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
/**
* VksPay商户支付配置
* 支持个人无需营业执照即可签约开户,正规通道,非市面上的挂机免签。(同时也支持企业签约)
* 消费者付款资金直接进入您签约的支付宝、微信支付商户号里,支付资金由支付宝、微信支付官方结算,避免二次清算。
* 开户联系QQ:370725567
*/
"vkspay": {
"mchId": "", // 商户号
"key": "" // 商户key
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# 微信小程序虚拟支付
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
// 微信虚拟支付
"wxpay-virtual": {
// 微信 - 小程序支付
"mp-weixin": {
"appId": "", // 小程序的appid
"secret": "", // 小程序的secret
"mchId": "", // 商户id
"offerId": "", // 支付应用ID
"appKey": "", // 现网AppKey(正式环境)
"sandboxAppKey": "", // 沙箱AppKey
"rate": 100, // 代币兑换比例,比如1元兑换100代币,那么这里就是100,建议设置为100(需要开通虚拟支付的时候也设置成 1 人民币 = 100 代币)
"token": "", // 微信小程序通信的token,在开发 - 开发管理 - 消息推送 - Token(令牌)
"encodingAESKey": "", // 必须43位,微信小程序消息加密密钥,在开发 - 开发管理 - 消息推送 - EncodingAESKey(消息加解密密钥)
"sandbox": false, // 是否是沙箱环境(注意:沙箱环境异步回调可能有延迟,建议直接正式环境测试)
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# 抖音支付
const fs = require('fs');
const path = require('path');
module.exports = {
/**
* 统一支付回调地址,格式为 "服务空间SpaceID":"URL化完整地址"
* 这里的本地开发并不是指 http://localhost:8080/ 的地址,而是另外一个服务空间的ULR化地址(如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可)
* 回调的云函数地址,建议填 /http/vk-pay,因为vk-pay云函数已经写好了回调处理的逻辑,否则你需要自己写全部的回调逻辑。
* 其中vk-pay是可以改名的,只需要修改 uniCloud/cloudfunctions/vk-pay/package.json 文件中的 "path": "/http/vk-pay", 把 /http/vk-pay 改成 /http/xxxx 即可(需要重新上传云函数vk-pay)。
*/
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
// 此密钥主要用于跨云函数回调或回调java、php等外部系统时的通信密码(建议修改成自己的,最好64位以上,更加安全)
// 详细介绍:https://vkdoc.fsq.pub/vk-uni-pay/uniCloud/pay-notify.html#特别注意
"notifyKey": "5fb2cd73c7b53918728417c50762e6d45fb2cd73c7b53918728417c50762e6d4",
// 自动删除N天前的订单(未付款的订单),若此值设为0,则代表不删除未付款订单,如果你的支付统计需要统计需要统计未付款订单数据,则此处可以填0
"autoDeleteExpiredOrders": 0, // 0代表永不删除,3代表3天(单位:天)
// 抖音支付
"douyin": {
// 抖音小程序支付,请在支付配置信息中配置URL(服务器地址)为 https://vk-pay的url化地址/vk-pay-notify/
"mp-toutiao": {
"appId": "", // 抖音小程序的appId
"secret": "", // 抖音小程序的secret
"mchId": "", // 商户id(商户号)
"salt": "", // SALT,从支付信息 - 支付设置中获取
"token": "", // Token(令牌),从支付信息 - 支付设置中获取
"sandbox": false, // 是否是沙箱环境
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# 证书存放目录
如果你的证书名字不是图上的名字,则改名成图上对应的名字即可。
目前只有支付宝和微信支付需要证书
- 蓝色框内是支付宝证书(3个)
- 绿色框内是微信支付证书(3个)
# 支付宝支付证书生成教程
支付宝支付证书生成教程 (opens new window)
# 微信支付证书生成教程
# 设置异步回调notifyUrl
上图中在 notifyUrl
属性内配置支付回调
格式为:"服务空间SpaceID":"URL化完整地址"
如果你有多个空间绑定(如本地和线上环境分开,则需要配置多个回调地址)
如
"notifyUrl": {
// 本地开发环境,如果你本地开发和线上环境共用同一个服务空间则只需要填线上环境的即可
"mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22": "https://fc-mp-22d55e33-c2f3-22b4-55fc-7b33a6144e22.next.bspapp.com/http/vk-pay",
// 线上正式环境
"mp-6666d886-00b6-22b2-9156-84afeadcf669": "https://fc-mp-6666d886-00b6-22b2-9156-84afeadcf669.next.bspapp.com/http/vk-pay"
},
1
2
3
4
5
6
2
3
4
5
6
服务空间SpaceID获取方式(即:的左边部分)
URL化完整地址获取方式(即:的右边部分)
进入服务空间详情
复制vk-pay支付回调函数的URL路径
配置完记得上传公共模块 uni-config-center
(每当修改配置后都要上传一次)
支付宝证书生成指南:点击查看 (opens new window)
# 支付宝支付使用密钥模式
支付宝官方推荐使用证书模式,默认已使用证书模式,但由于目前uni-id的支付宝小程序登录仅支持密钥模式,因为vk-pay也支持密钥模式,只需要更改配置如下
"alipay": {
// 支付宝 - 小程序支付配置
"mp-alipay": {
"appId": "", // 支付宝小程序appid
"privateKey": "", // 应用私钥字符串
"alipayPublicKey": "", // 支付宝公钥字符串
},
}
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 特别注意
# 注意一
- 支付宝H5网站扫码支付需签约 支付宝当面付(非PC网站支付)
- 支付宝H5移动支付需签约 支付宝当面付(非移动网站支付)
# 注意二
- 每次修改了支付参数后,需要重新上传公共模块
uni-config-center
# 注意三
- 如果提示找不到
xxx
模块,如uni-id
模块,则 - 1、在
uniCloud/cloudfunctions/common/vk-uni-pay
目录右键选择管理公共模块依赖
菜单,引入这2个模块uni-config-center
、uni-pay
- 2、在需要引入支付API的云函数(如:vk-pay)右键选择
管理公共模块依赖
菜单,至少引入这2个模块uni-config-center
、vk-uni-pay
- 3、重新上传公共模块
vk-uni-pay
- 4、重新上传云函数
vk-pay
# 1.9.0以下的版本注意事项
支付宝
1.9.0之前,支付宝转账配置如下
"transfer": {
"appId": "",
"privateKey": "",
"appCertSn": "", // 应用证书的序列号
"alipayRootCertSn": "", // 支付宝根证书的序列号
"sandbox": false
}
1
2
3
4
5
6
7
2
3
4
5
6
7
appCertSn
和 alipayRootCertSn
参数获取方式
而1.9.0之后去掉了 appCertSn
和 alipayRootCertSn
,直接使用证书代替。
// 支付宝 - 转账到支付宝等资金转出接口
"transfer": {
"appId": "",
"privateKey": "",
"alipayPublicCertPath": path.join(__dirname, 'alipay/alipayCertPublicKey_RSA2.crt'),
"alipayRootCertPath": path.join(__dirname, 'alipay/alipayRootCert.crt'),
"appCertPath": path.join(__dirname, 'alipay/appCertPublicKey.crt'),
"sandbox": false
}
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
微信
1.9.0之前,微信转账配置如下
"transfer": {
"appId": "",
"mchId": "",
"apiV3key": "", // api v3密钥
"appCertSn":"", // 商家应用证书的序列号
"privateKey":"", // 商家私钥
"wxpayPublicCertSn":"", // 微信支付公钥证书的序列号
"wxpayPublicCertContent": "", // 微信支付公钥内容
}
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
- appCertSn 商家应用证书的序列号:可以直接在微信支付后台查看到证书的序列号
- privateKey 商家私钥:从
apiclient_key.pem
这个证书的内容复制过来即可。需保持一行。
传送门 - 证书转换成一行 (opens new window)
而1.9.0之后
"transfer": {
"appId": "",
"mchId": "",
"v3Key": "",
"appCertPath": path.join(__dirname, 'wxpay/apiclient_cert.pem'),
"appPrivateKeyPath": path.join(__dirname, 'wxpay/apiclient_key.pem'),
"wxpayPublicCertSn": "",
"wxpayPublicCertContent": ""
},
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
← 快速上手 - 安装步骤 示例项目运行教程 →