已成功通过统一支付接口获取到prepay_id,使用和统一下单同样的小程序appId和对应的商户API key对appId,nonceStr,package,signType,timeStamp这几个参数进行md5加密,参数传到小程序后调起支付时报支付验证签名失败。
相关代码:
public Map throws Exception { Map Map signData.put( "appId" , this .config.getAppID()); signData.put( "timeStamp" , String.valueOf(WXPayUtil.getCurrentTimestamp())); signData.put( "nonceStr" , WXPayUtil.generateNonceStr()); signData.put( "package" , "prepay_id=" + unifiedOrder.get( "prepay_id" )); signData.put( "signType" , WXPayConstants.MD5); Map returnData.put( "timeStamp" , signData.get( "timeStamp" )); returnData.put( "nonceStr" , signData.get( "nonceStr" )); returnData.put( "package" , signData.get( "package" )); returnData.put( "signType" , signData.get( "signType" )); returnData.put( "paySign" , WXPayUtil.generateSignature(signData, this .config.getKey())); return returnData; } |
md5加密前的串是这样的:
appId=****&nonceStr=2f3c978b0e91435dab8b0f0045665158&package=prepay_id=wx201707141513256189b0503e0006016925&signType=MD5&timeStamp=1500016405&key=****
签名前有加key,签名时的appId和key和统一下单的appId和key是相同的。
md5加密算法没有问题,用微信签名校验工具也核对过了,参数名称检查了很多遍和文档上是一样的。
小程序代码:
var timeStamp = res.payInfo.timeStamp; var nonceStr = res.payInfo.nonceStr; var packageInfo = res.payInfo.package; var signType = res.payInfo.signType; var paySign = res.payInfo.paySign; wx.requestPayment({ 'timeStamp' : timeStamp, 'nonceStr' : nonceStr, 'package' : packageInfo, 'signType' : signType, 'paySign' : paySign, 'success' : function (res) { console.log(res); }, 'fail' : function (res) { console.log(res); } }) |
到底哪里有问题啊,求助!!!
我也被坑了n久,完全一样的问题。weixin支付SDK真心不如支付宝支付SDK好用
说一下我的情况,开始绑定商户号时绑错了,绑了一个有效的但没在使用的商户号,因为不能解绑,所以最终我的小程序绑了两个微信支付商户,而wx.requestPayment文档说明里面交没有要求传appId(当然我就没传),就总是出现签名错误,很让人崩溃,后来看大家的评论试着加上appId后就好了。我猜是不是只绑一个商户号的可以不用传appId,所以文档里没写上,而如果小程序对应多个微信支付商户的话,就最好写上了。
签名和调起支付时间戳要一样才行
为什么小程序支付的签名跟微信App支付的签名, 大家参数名称都差不多, 为什么非要有一个大小写, 一个全小写..
我日,签名appId写成了appid郁闷了好几天
从昨天开始,有客户反映在小程序支付时出现“签名验证失败”,老客户都没有问题,首次关注客户(苹果手机上),为此我们内部找了好多手机测试都没发现这个问题,怎么办?有没有人也出现这种情况。。。 ---我们的作业模式是从微信服务号跳转到小程序进行购物下单支付的。
java SKD 中的坑, 就是这个问题. NND的. 网页支付的时候就被这个问题坑了, 不过当时我是把 wxpay.isPayResultNotifySignatureValid 的校验默认修改成了HMAC-SHA256 加密算法了. 想不到再接入小程序微信支付的时候, 统一下单能成功, 但是扫描二维码后一直提示签名验证失败!! 你说这bug我找谁理论去. 还好今天一早查了下社区. 发现原来不只我入坑~ 兄台早就踩过了. 哈哈哈. 现在按照你的解决方案, 把统一下单也修改成MD5, 校验也修改成MD5了 就好了.
@杨木
md5加密完是有转大写的
@Tooko
刚刚直接用你的代码试了下在前端签名,但调起支付同样是弹的支付验证签名失败 ,我用同样的参数在后台md5签名结果与前台签名相同,说明签名方法应该没问题,签名参数在前台签名时都是直接用的你的说明签名参数应该也没问题。
按理说我能用小程序的appId和对应商户的API key调成功统一下单接口,那appId和key应该没有问题啊,为什么用相同的appId和key进行二次签名会出现签名失败呢,我真的不知道该怎么办了。。。。
我也是统一下单成功,可是小程序端调用的时候返回签名错误,你解决了吗?
我以前自己试接口的时候前台的生成签名。你用这个和你自己的签名的对比一下哪不一样吧。肯定哪个熟悉不匹配才验证不通过的
function paySign(appid, nonceStr, prepay_id, timestamp, key) {
var sign = ''
//签名顺序按照ASCII字典序排序
var signA = "appId=" + appid + "&nonceStr=" + nonceStr + "&package=prepay_id=" + prepay_id + "&signType=MD5&timeStamp=" + timestamp
var signB = signA + "&key=" + key
// console.log(signB)
sign = MD5Util.MD5(signB).toUpperCase()
return sign
}
function getTimestamp() {
var timestamp = Date.parse(new Date()) / 1000
return timestamp
}
function getNonceStr(len) {
len = len || 32
var $chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678'
var maxPos = $chars.length
var str = ''
for (var i = 0; i < len; i++) {
str += $chars.charAt(Math.floor(Math.random() * maxPos))
}
return str
}
function requestPayment(prepay_id) {
var timestamp = getTimestamp()
var nonceStr = getNonceStr(32)
var paysign = paySign(app.globalData.appId, nonceStr, prepay_id, timestamp, app.globalData.api_key)
// console.log(paysign)
wx.requestPayment({
'timeStamp': timestamp.toString(),
'nonceStr': nonceStr,
'package': 'prepay_id=' + prepay_id,
'signType': 'MD5',
'paySign': paysign,
'success': function (res) {
wx.showToast({ title: '支付成功' })
},
'fail': function (res) {
}
})
}
是不是一定要转成大写