2019独角兽企业重金招聘Python工程师标准>>>
从昨天到今天微信小程序客户端始终都有这个问题,一直以为是服务端这里有问题,后面才发现原来微信有个神坑,一般来说统一下单接口会返回类似如下数据
{
"return_code": "SUCCESS",
"return_msg": "OK",
"appid": "wxc123456789",
"mch_id": "12345678",
"nonce_str": "tlI5Oy3QigCQHQQM",
"sign": "8EAB94045E948AD7D126937ED7EF9032",
"result_code": "SUCCESS",
"prepay_id": "wx221639448194778a79a9510a2883548319",
"trade_type": "JSAPI"
}
这个时候客户端拿到,就可以拉起微信支付了,于是客户端就这么干了:
wx.requestPayment({
timeStamp: timestamp,
nonceStr: res.data.nonce_str,
package: 'prepay_id=' + res.data.prepay_id,//这里也要注意去拼接这个prepay_id=,略坑,但是很容易搜到解决办法
signType: 'MD5',
paySign: res.data.sign,//这里是刚才请求统一下单接口拿到的sign,放这里直接用是错误的,坑就在这里,巨坑
success(res) {
console.log(res)
},
fail(res) {
console.log(res)
}
})
然后就会报错 支付验证签名失败,那么这个paySign到底应该咋获取呢,这里有文档,很多人都不知道要在微信小程序客户端再做一次这个加密过程动作:
- 把
wx.requestPayment
将要准备发起请求的参数中的:'appId' 'timeStamp' 'nonceStr' 'package' 'signType' 等字段进行字典序排序,然后拼接上API安全key(key设置路径:微信商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置
) - 然后就可以获取到正确的paySign了