小程序
小游戏
企业微信
微信支付
扫描小程序码分享
errMsg:"requestPayment:fail"
err_code:2
err_desc:"支付验证签名失败"
微信小程序 吊起支付的时候返回支付验证签名失败,在经过签名工具的时候签名是一样的。
还有什么问题是导致错误呢
14 个回答
加粗
标红
插入代码
插入链接
插入图片
上传视频
在验签工具上验签成功,但是在手机微信上支付时就是返回验签失败。检查了所有字母得大小写,又重新复制了一遍。还是这个错误,怎么解决得?
你好,麻烦通过点击下方“反馈信息”按钮,提供出现问题的。
1、appId 的是大写的I,是 nonceStr 而不是 ‘nonce_str’
2、小程序调用时的取值,要跟 服务端的值相同,timeStamp、nonceStr
3、总结:这一步的经验,是下一步的坑····
【已解决】
android sdk提示:支付验证签名失败
原因:统一下单返回的sign位数,跟下发给app的sign位数要一样!
也就是说:签名类型要相同。
ps:被坑了好久~【详情 https://www.jianshu.com/p/fa756ff471fc】
楼主解决了吗 我这边大小写检查了没问题 就是返回和你一样的错误
您好,请参考:
1.统一下单的时候,接口要传的appid是小写,但是二次签名的时候要求appId是大写,请注意。
2.如下图:
请求添加你微信了,昵称 Hope 通过下
这么多年了,开发文档还是写的还是依托答辩,想找个东西,找半天找不到,能不能学一下隔壁某宝
有没有和我一样,傻了吧唧wx.requestPayment用JSAPI签名的
给大家同步一下我这边的方案,2022年03月24日:
最终解决方案是:让后台返回所有需要的字段,客户端拿着数据,直接请求服务器,即可吊起微信支付。
示例:
PayReq request = new PayReq(); // 应用ID (可本地写死,也可服务器返回) request.appId = PayConstants.WX_APP_ID; // 商户号 (可本地写死,也可服务器返回) request.partnerId = PayConstants.WX_APP_MICID; // 预支付交易会话ID, 微信返回的支付交易会话ID request.prepayId = mPayOrderBean.getPrepay_id(); // 扩展字段, 固定值:Sign=WXPay, (可本地写死,也可服务器返回) request.packageValue = "Sign=WXPay"; // 随机字符串, 随机生成 随机字符串,不长于32位。推荐随机数生成算法,服务器生成 (最好是 32 位,如果是 低于 12 位,可能有问题) request.nonceStr = mPayOrderBean.getNonceStr(); // 时间戳,一定是服务器的时间戳 (最好是服务器的时间戳) request.timeStamp = mPayOrderBean.getTimestamp(); // 签名 (这个签名是后端根据证书签名的,一定不要自己写哦,要不然调试好久都没结果) request.sign = mPayOrderBean.getSign(); // 这个字段可有可无。建议还是带上。 request.extData = "app data"; mIWXAPI.sendReq(request);
简单描述:
{ "return_code": "SUCCESS", "return_msg": "OK", "appid": "APPID", "mch_id": "商户号", "nonce_str": "随机字符串", "sign": "081675D3A89B1A735613CF2D777E6F06", "prepay_id": "wx201706052018103dd047b0880123350695", "result_code": "FAIL", "err_code": "ORDERPAID", "err_code_des": "该订单已支付" }
2 其中比较关键是: sign。 这个返回客户端也不行,需要服务器做二次加密。
具体是:
"appid=" + appid + "&noncestr=" + nonce_str + "&package=Sign=WXPay" + "&partnerid=" + mch_id + "&prepayid=" + prepayid + "×tamp=" + timeStamp + "&key=" + key;
一定要注意:这里的key为商户的key,而不是AppSecret;timestamp为当前的时间戳
3 最后返回的字段:
{ "appid": "第1步的APPID", "mch_id": "第1步的mch_id", "prepay_id": "第1步的prepay_id", "nonce_str": "第1步的nonce_str", "sign": "第3步的签名,不是第1步的签名", "timestamp":"第3步的时间戳" }
4 注意查看我上面的注释,错一个,就会提示签名失败。
参见:
折腾了一下午和一晚上终于解决了。我这边的问题是:我们之前已经对接 过app的微信支付,后台直接返回了{ "package": "Sign=WXPay", "appid": "wx666", "sign": "7E9360EE36", "partnerid": "1116401", "prepayid": "wx66000", "noncestr": "345332", "timestamp": "1625620895" } 这样的数据各式我当时的做法是拿着后台返回的这些参数 格式化后直接去调用微信支付。
{ "package": "Sign=WXPay", "appid": "wx666", "sign": "7E9360EE36", "partnerid": "1116401", "prepayid": "wx66000", "noncestr": "345332", "timestamp": "1625620895" } 这样的数据各式
但是注意注意,JSAPI加密sign的方法和app不一样, sign不能混用,它是是 需要把appId , timeStamp, nonceStr,package, signType 5个参数拼接key 以后 再使用md5加密
我的是支付密钥错了,开发工具正常生成了支付二维码,扫描报的支付签名认证失败,换了密钥好了
正在加载...
关注后,可在微信内接收相应的重要提醒。
请使用微信扫描二维码关注 “微信开放社区” 公众号
在验签工具上验签成功,但是在手机微信上支付时就是返回验签失败。检查了所有字母得大小写,又重新复制了一遍。还是这个错误,怎么解决得?
1、appId 的是大写的I,是 nonceStr 而不是 ‘nonce_str’
2、小程序调用时的取值,要跟 服务端的值相同,timeStamp、nonceStr
3、总结:这一步的经验,是下一步的坑····
【已解决】
android sdk提示:支付验证签名失败
原因:统一下单返回的sign位数,跟下发给app的sign位数要一样!
也就是说:签名类型要相同。
ps:被坑了好久~【详情 https://www.jianshu.com/p/fa756ff471fc】
统一下单返回的sign是HMAC-SHA256,下发给App的也要采用HMAC-SHA256签。
楼主解决了吗 我这边大小写检查了没问题 就是返回和你一样的错误
您好,请参考:
1.统一下单的时候,接口要传的appid是小写,但是二次签名的时候要求appId是大写,请注意。
2.如下图:
请求添加你微信了,昵称 Hope 通过下
这么多年了,开发文档还是写的还是依托答辩,想找个东西,找半天找不到,能不能学一下隔壁某宝
有没有和我一样,傻了吧唧wx.requestPayment用JSAPI签名的
给大家同步一下我这边的方案,2022年03月24日:
最终解决方案是:让后台返回所有需要的字段,客户端拿着数据,直接请求服务器,即可吊起微信支付。
示例:
PayReq request = new PayReq(); // 应用ID (可本地写死,也可服务器返回) request.appId = PayConstants.WX_APP_ID; // 商户号 (可本地写死,也可服务器返回) request.partnerId = PayConstants.WX_APP_MICID; // 预支付交易会话ID, 微信返回的支付交易会话ID request.prepayId = mPayOrderBean.getPrepay_id(); // 扩展字段, 固定值:Sign=WXPay, (可本地写死,也可服务器返回) request.packageValue = "Sign=WXPay"; // 随机字符串, 随机生成 随机字符串,不长于32位。推荐随机数生成算法,服务器生成 (最好是 32 位,如果是 低于 12 位,可能有问题) request.nonceStr = mPayOrderBean.getNonceStr(); // 时间戳,一定是服务器的时间戳 (最好是服务器的时间戳) request.timeStamp = mPayOrderBean.getTimestamp(); // 签名 (这个签名是后端根据证书签名的,一定不要自己写哦,要不然调试好久都没结果) request.sign = mPayOrderBean.getSign(); // 这个字段可有可无。建议还是带上。 request.extData = "app data"; mIWXAPI.sendReq(request);
简单描述:
{ "return_code": "SUCCESS", "return_msg": "OK", "appid": "APPID", "mch_id": "商户号", "nonce_str": "随机字符串", "sign": "081675D3A89B1A735613CF2D777E6F06", "prepay_id": "wx201706052018103dd047b0880123350695", "result_code": "FAIL", "err_code": "ORDERPAID", "err_code_des": "该订单已支付" }
2 其中比较关键是: sign。 这个返回客户端也不行,需要服务器做二次加密。
具体是:
"appid=" + appid + "&noncestr=" + nonce_str + "&package=Sign=WXPay" + "&partnerid=" + mch_id + "&prepayid=" + prepayid + "×tamp=" + timeStamp + "&key=" + key;
一定要注意:这里的key为商户的key,而不是AppSecret;timestamp为当前的时间戳
3 最后返回的字段:
{ "appid": "第1步的APPID", "mch_id": "第1步的mch_id", "prepay_id": "第1步的prepay_id", "nonce_str": "第1步的nonce_str", "sign": "第3步的签名,不是第1步的签名", "timestamp":"第3步的时间戳" }
4 注意查看我上面的注释,错一个,就会提示签名失败。
参见:
折腾了一下午和一晚上终于解决了。我这边的问题是:我们之前已经对接 过app的微信支付,后台直接返回了
{ "package": "Sign=WXPay", "appid": "wx666", "sign": "7E9360EE36", "partnerid": "1116401", "prepayid": "wx66000", "noncestr": "345332", "timestamp": "1625620895" } 这样的数据各式
我当时的做法是拿着后台返回的这些参数 格式化后直接去调用微信支付。但是注意注意,JSAPI加密sign的方法和app不一样, sign不能混用,它是是 需要把appId , timeStamp, nonceStr,package, signType 5个参数拼接key 以后 再使用md5加密
我的是支付密钥错了,开发工具正常生成了支付二维码,扫描报的支付签名认证失败,换了密钥好了