前端小菜鸟,由于项目要对接微信的jssdk,对接就须要签名认证,可是无奈安卓和IOS各有各的坑,本篇文章只讨论签名,和一个分享的坑,但愿你们有所收获,可以解决问题,若是解决不到,请麻烦在评论区留言,本文综合了全部的回答,才调试出来坑
缘由:前端
1. 项目基于vue,在微信上的web应用 2. 要使用上传功能(不一样系统的兼容真的不少BUG,最后只能使用微信方案),支付功能,定位.... 3. 签名一直存在bug和问题,那么后面的功能都会唤不起(偶尔也能够)
1. 流程详细请看文档,反正能力有限,没看出什么名堂,总结一句话,要使用先签名 2. 开启填坑之路,因为微信使用会区分IOS和安卓系列,不一样系列产生不同的问题 (公司项目初版的时候就给微信大坑过,因此本次重构的时候,就格外注意这一点)
router.afterEach((to, from) => { // 伸手党福利 // window.__wxjs_is_wkwebview // true 时 为 IOS 设备 // false时 为 安卓 设备 if (window.__wxjs_is_wkwebview) { // IOS if (window.entryUrl == '' || window.entryUrl == undefined) { var url = `${FRONT_BASE}${to.fullPath}` window.entryUrl = url // 将后面的参数去除 } getWxAuth(to.fullPath,"ios") }else { // 安卓 setTimeout(function () { getWxAuth(to.fullPath,"android") }, 500); } })
看完路由模式了,就来进入逻辑部门,来看看如何处理
有同窗疑惑这个encodeURIComponent是干吗用的,其实具体很简单,就是由于咱们在微信分享的时候,会自动给咱们带上参数(记得告诉后端的伙伴要decodeURIComponent),切记只要带参数就必定要转码!vue
对于IOS系统会自动增长以下参数: 朋友圈 from=timeline&isappinstalled=0 微信群 from=groupmessage&isappinstalled=0 好友分享 from=singlemessage&isappinstalled=0 对于安卓系统会自动添加以下参数: 朋友圈 from=timeline 微信群 from=groupmessage 好友分享 from=singlemessage
到了这一步就基本上是请求签名成功,可是有同窗疑惑,那么IOS每次分享的时候会不会是进去的第一个路由,个人回答是会的(须要稍加处理)