评论

微信支付接口报【签名错误】,看这一篇就够了

此文章致力解决在开发微信支付相关接口报【签名错误】,并不断升级更新

此文章致力解决在开发微信支付相关接口报【签名错误】,并不断升级更新

文章demo以’普通商户版’-‘JSAPI支付’作为案例(JSAPI支付文档)

先讲一下开发步骤和经验,文章后半部分讲排错经验

开发步骤

设置支付目录文档链接

支付目录,一定要设置实际支付页面的路径以 / 结尾,如果提示<当前页面URL未注册>,请检查自己实际支付页面的路径是否填写正确

发起支付的业务流程,我们做的操作应该是这样的:用户选择支付金额和其他参数–>用户点击支付–>前端向后台发起请求获取签名等参数–>后台调用统一下单接口,返回给前端需要的签名参数–>前端调用WeixinJSBridge.invoke–>用户填写密码–>支付成功–>微信发送通知给统一下单填写的回调方法。详细业务流程点我查看

后台调用统一下单接口文档链接

此接口参数非常多,第一次开发的时候,建议开发者仔仔细细对每个参数进行比对。遇到签名错误的同学,大部分人的原因是因为参数填写错误导致的

后台在给前端准备参数的时候,是要进行两次签名的:第一次是发送统一下单请求之前,对发送给微信的所有参数进行签名;第二次是微信返回预支付交易会话标识后,对传给前端的所有参数进行签名。

请注意,第一次签名和第二次签名的时候,参数是不一样的,第二次签名的时候,签名需要哪些参数呢?签名的参数是WeixinJSBridge.invoke需要用到的参数,和第一次签名需要的参数是不一样的!

对于参数package我第一次粗心大意,没有拼接字符串‘prepay_id=’希望大家也注意一些,前后台都需要拼接这个字符串‘prepay_id=’

这是我刚刚花费10分钱获取的统一下单截图

只有result_code和return_code都为SUCCESS的时候,说明调用成功,成功拿到预支付的id

前端获取参数后拉起微信支付文档链接

其实完整坐下来,微信支付就这么点东西,只是大家可能有些不熟悉,对于大家遇到的签名错误问题,绝大部分是参数没有认真进行参数比对,参数不能多,也不能少。如果还报错,建议从下面一些方式进行排查

排错经验

· 首先排查签名方法是否正确(签名效验工具),如果自己写的签名方法和工具展示出来的结果一模一样,说明你签名的工具方法写的没有问题,那么就剩下参数的问题了!

· 然后进行参数比对,根据开发文档,进行比对,一个字母都不能差

· 第一次签名和第二次签名的APPID ,后台签名的i是小写,前端调用的是大写

· 后端第二次签名,参数package一定不要忘记拼接prepay_id

· 请再三确认appid和mch_id是否正确,如果同时进行多个公众号支付开发,一定不要弄混

· 第二次签名参数timeStamp时间差距太大(你服务器时间要尽量准确,好像误差不能超过10分钟)

· 中文参数错误,英文参数没有问题的,本文以MD5加密为例,请在加密的时候,指定编码格式为UTF-8

对于企业付款到零钱/银行卡

· 尝试在商户平台的账户信息中更改API密钥(账户设置-安全设置-API安全), 15分钟后生效

· 还是参数,参数,参数

终极杀器·缓存

作者开发语言是java,之前缓存无处不在,myeclipse(开发者工具)的缓存,本地编译缓存,服务器tomcat的缓存,如果你觉得我就是对的,什么都排查过了,没有问题,OK,建议清理缓存(先删除tomcat里边的项目,再添加然后重新编译项目;服务器tomcat缓存,清理tomcat文件夹下work-catalina文件夹的内容)。实在不行,重启本地电脑。重启服务器server。

请各位同学一定要先自行排查问题,如果还无法解决问题,或者你遇到过其他bug情况,欢迎留言,我会及时更新到文章,以便帮助更多人解决签名错误的问题。ღ( ´・ᴗ・` )比心

------------------分割线-------------------

签名方式是否真的正确?

----------2019年12月2日更新,感谢斌斌反馈----------

由于作者做支付是在2016年,辛辛苦苦整理了一份demo,一直沿用至今,忘记当时是否有官方sdk了,如果大家用的是官方sdkDemo,以上bug排查完,还是报签名错误,请检查签名方式,实际是MD5还是HMACSHA256。具体情况可以看这篇提问【JSAPI第二次签名到底什么机制?】

最后一次编辑于  2021-03-18  
点赞 14
收藏
评论

15 个评论

  • Longfei _w@ng
    Longfei _w@ng
    2020-12-22

    大佬,我的appid在外部浏览器能拿到,但是在微信内置浏览器拿不到,这是为什么

    2020-12-22
    赞同
    回复
  • Derek_沉默中的努力🤔
    Derek_沉默中的努力🤔
    2020-12-18

    我一直搞不懂第二次簽名,怎么个第二次签名???异步回调的时候第二次签名吗?

    2020-12-18
    赞同
    回复
  • VBit
    VBit
    2020-08-01

    追加,如果用官方的demo记得各项签名时的参数,排查一下,是否签名前是否所有额字符串拼接都正确,特别是key,记得一定要根据官方的demo重写自己的支付,验证签名逻辑

    2020-08-01
    赞同
    回复
  • 浪淘沙
    浪淘沙
    2020-03-28

    https://developers.weixin.qq.com/community/pay/doc/0002e21bfdcc98b5e91a1ba1d56400

    麻烦帮我看看这个问题

    2020-03-28
    赞同
    回复
  • 希文
    希文
    2019-12-08

    你好,java后台二次验证的数据如下

    将上述数据放在微信工具下验证是通过的如下

    两次验证的appid的i都必须小写,验证过。

    缓存也请了

    公众号支付还是报“支付验证签名失败”

    请您帮忙看一下

    2019-12-08
    赞同
    回复 12
    • 王浩Hanks🇨🇳
      王浩Hanks🇨🇳
      2019-12-08
      谢谢你指出i大小写的问题,文章中我已经改了,后台的签名,都是小写。根据你提供的,我看不出什么,只能说明,你签名的方法是没有问题的,重点就是参数了,你可以看下我文章末尾链接的那个问题,你是不是因为这个的问题呢?
      2019-12-08
      回复
    • 希文
      希文
      2019-12-09回复王浩Hanks🇨🇳
      现在代码签名跟工具签名一致,可是页面还是报“支付验证签名失败”
      2019-12-09
      回复
    • 王浩Hanks🇨🇳
      王浩Hanks🇨🇳
      2019-12-09回复希文
      仔细比对参数,参数
      2019-12-09
      回复
    • 王浩Hanks🇨🇳
      王浩Hanks🇨🇳
      2019-12-09回复希文
      根据官方文档比对
      2019-12-09
      回复
    • 希文
      希文
      2019-12-09回复王浩Hanks🇨🇳
      又重新复制了一遍
      2019-12-09
      回复
    查看更多(7)

正在加载...

登录 后发表内容