微信jssdk踩坑之签名错误invalid signature
最近做公众号网页开发,使用微信 jssdk
页面签名时 IOS
中一直报错,这才刚开始就被这只拦路虎拦住了,报错如下
Android
和开发者工具中好得很,没有任何问题
既然提示 签名非法
,那就是签名有问题咯,同样的接口,为什么Android没问题?是真是假还是用官方的签名校验工具验证下
生成的签名完全没有问题,这就奇怪了,按照网上说的 url
改成如下方式也不行
url = window.location.href.split('#')[0]
突然看到网上有人说是因为 SPA
的原因,经过几番测试,问题锁定在了 SPA
。先来解释下为什么会这样,我们使用 Vue Router
切换页面时,底层使用的是 pushState
技术,这是 H5
的一个新特性,虽然表面上看页面的 path
变了,内容也换了,页面是没有刷新的。
现在知道问题出在哪里,再来实际确认一下。进入项目的首页,地址是 https://.abc./weixin/quan?rr=234wfwf
,然后点击进入我们要分享的页面,这时候会提示 invalid signature
,这时jssdk是配置失败的,分享出去的就是原始的页面链接,问题出现了
分享后的链接仍然是首页进入的链接,这是微信的BUG啊,原来在微信的网页中不支持 pushState
,这就导致我们在jssdk从配置时传入的 url
( window.location.href
得到)和微信识别到的不一样,这时候在分享的页面刷新一下,配置就会正常。
后面再看官方文档时也提到了这一点
我的Android没这个问题,iOS反而出现了这个问题(IOS版本13.3.1,微信版本7.0.9,jssdk 1.6)
如何解决
在跳转到要分享的页面时,不用 pushState
,在 Vue router
中就是不用 push
方式跳转,方式如下
window.location.href = 要跳转的链接 // _this.$router.push({ // … // })
既然 SPA
在微信中只认第一个页面的 path
,那我们就在第一次进入页面时记录下 path
,其他页面用这个 path
。我们在 App.vue
或者 main.js
中记录下这个 path
window.sessionStorage.setItem('firstEntryUrl', window.location.href)
然后在需要分享的页面,使用这个 path
let url = window.location.href.split('#')[0] if (utils.isIOS() && window.sessionStorage.getItem('firstEntryUrl')) { url = window.sessionStorage.getItem('firstEntryUrl').split('#')[0] }
经测试,上述两种方法都能完美解决。
到此这篇关于微信jssdk踩坑之签名错误invalid signature的文章就介绍到这了,更多相关微信jssdk 签名错误 内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南