从昨天到今天微信小程序客户端始终都有这个问题,一直觉得是服务端这里有问题,后面才发现原来微信有个神坑,通常来讲统一下单接口会返回相似以下数据php
{ "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" }
这个时候客户端拿到,就能够拉起微信支付了,因而客户端就这么干了:json
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安全-->密钥设置
)