使用官方的C#DEMO,测试刷卡支付、订单退款、下载账单这三项没有问题,签名一致
但是使用订单查询 和 退款查询 总是签名错误,我断点跟踪发现返回的签名和本地的新签名居然不一致
//获取接收到的签名
string return_sign = GetValue("sign").ToString();
//在本地计算新的签名
string cal_sign = MakeSign(signType);
使用微信支付接口签名校验工具,生成的签名内容是一致的,这就不明白了
实在是不知道问题在哪儿?
微信的
result.CheckSign();在碰到userpaying的情况下,拿到的字符串是
appid=123456&err_code=USERPAYING&err_code_des=需要用户输入支付密码&mch_id=123456&nonce_str=7v58MLiFbVdxal51&result_code=FAIL&return_code=SUCCESS&return_msg=OK&key=XXXXXX
值我当然做过修改,之后微信在用以上这一串新的字符在进行验签,第一次的签名所用字符串
appid=123456&auth_code=88888&body=sp&mch_id=123456&nonce_str=d1cba83be4b34cab9d2b50eab5ebe074&out_trade_no=151006070120190829175845699&sign_type=HMAC-SHA256&spbill_create_ip=0.0.0.0&total_fee=1&key=XXXXXX
两次的生签字符串都是不一样的,生成的sign肯定不一样,所以我这里一直在报
WxPayData签名验证错误!
之后我将
//签名验证
result.CheckSign();
这一句换成了
data.CheckSign();
验签支付等全部正常,在下愚钝,不知其解
1) 使用微信的在线签名工具检查签名是否和程序生成的一致
https://pay.weixin.qq.com/wiki/doc/api/micropay.php?chapter=20_1 签名工具用谷歌打开。
选择MD5,XML,然后把请求参数xml放进去,就能校验签名。
2)如果和微信的在线签名工具一致,说明程序没有错误,确定是API密钥错误(被别人改动或者记错了)
在商户平台的账户信息中更改API密钥(账户设置-安全设置-API安全), 15分钟后生效
2.1)统一下单用的是A商户号,也必须是A商户号登陆商户平台设置key才对。
2.2)要注意统一下单请求参数中total_fee参数的类型是int类型。
3) 如果和微信的在线签名工具不一致,说明程序有错误,常见的错误可能是:
3.1) 编码问题,确保所有的都是utf-8的. 如果有中文, 可以先把中文改成英文重新签名,看是否签名错误,如果英文不会错中文才会错,基本肯定是编码问题
3.2:)消息中字段大小写和文档中完全一致
4 )统一下单和调起支付签名类型需要一致。
参数的类型和格式,长度限制需要完全符合文档的要求
DEMO里的total_fee是int时,也是签名错误,我将此参数也当字符串处理,签名正常,现在是刷卡付、订单退款、账单这三项签名正常,就是查询订单,查询退款签名错误.