invalid signature签名错误如何解决

最近在进行微信公众号开发,微信分享签名的时候,时灵时不灵。通过微信debug查看,发现不灵的时候报invalid signature错误,在网上查了各种资料,准备进行问题的排查。
(1)首先看,access_token有没有获取到,jsapi_ticket有没有获取成功,这是一切的基础;(注意这儿需要配置一个7200秒的全局缓存,因为微信设置的每天获取ticket是有次数限制的);
(2)签名算法有没有错误,怎么检测,当然是用http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign页面工具进行校验,拿你通过测试工具拿到的signature值和用签名算法拿到的值进行比对,如果两者一样,则算法没问题,否则算法有问题。当然这个过程中,你要确保以下几点:

确认签名用的noncestr和timestamp与wx.config中的nonceStr和timestamp是否相同;
确认签名用的url是调用JS接口页面的完整URL,包括’http(s)://’部分,以及’?’后面的GET参数部分,但不包括’#’hash后面的部分;如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去’#’hash部分的链接(可用location.href.split(‘#’)[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败;
确认 config 中的 appid 与用来获取 jsapi_ticket 的 appid 一致;
出于安全考虑,必须在服务器端实现签名的逻辑。

看到这儿,想必应该就可以解决你的问题了。

你可能感兴趣的:(前端,微信开发)