手机报错:config:invalid signature问题;网页开发工具报错:config:fali,Error:系统错误,错误码:63002,invalidsignature问题

折腾了几天发现是(java老哥单词少了一个字母)

官方建议: invalid signature签名错误。建议按如下顺序检查:

  • 1.确认签名算法正确,可用http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign
    页面工具进行校验。

  • 2.确认config中nonceStr(js中驼峰标准大写S), timestamp与用以签名中的对应noncestr, timestamp一致。

  • 3.确认url是页面完整的url(请在当前页面alert(location.href.split(’#’)[0])确认),包括’http(s)/‘部分,以及’?‘后面的GET参数部分,但不包括’#'hash后面的部分。

  • 4.确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致。

  • 5.确保一定缓存access_token和jsapi_ticket。

  • 6.确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中php的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去’#‘hash部分的链接(可用location.href.split(’#’)[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。

个人建议:

  • 1.检查appId和js接口安全域名配置是否正确
  • 2.检查IP白名单设置
  • 3.核查前端和后端appid是否一致

测试经历
因为以前做好多次这个,所以一开始以为很快能解决,无非是appid,js域名问题。结果。。,一星期之久。

开始一直认为是我前端代码问题,我自己也认为url#hash#部分可能有问题。(因为后台接口参数通过页面工具进行校验,发现正确,最匪夷所思的地方)

所以一直是我在疯狂尝试,什么const url = window.location.href.split(’#’)[0]、const url = window.location.href、Base64.encode(url)、encodeURIComponent(url),未果,冷静分析,我就怀疑这绝不对不是前端问题,一定是后端或者公众平台配置问题。

开始验证,我直接调用其他项目getConfig接口,以确定bug出在前端还是后端(一个公众号多个项目公用appid),配置wx.config()测试发现可以使用。确定bug出在后端和公众平台

公众平台配置:产品核对一遍,java核对一遍,我核对一遍。

于是乎配合后台,我写了demo,还是不行,遂建议java老哥完完全全复制另一个项目代码写接口,老哥说那个接口就是他写的,这也是不可能有问题(往往都是以为不会错的地方出错,才最为致命,我们根本不会去排查他),我也跟着他过了一遍java代码,确实一样(此时仍然是旧代码,一定不能偷懒)。

而后,建议直接摆脱项目从A项目复制代码,重写接口给我测试。我说单词会不会写错,或者吃饭误碰到了多了东西。然后。。。发现java代码中少写一个字母。

你可能感兴趣的:(微信公众号)