VUE解决微信签名及SPA微信invalid signature问题(完美处理)


Posted in Javascript onMarch 29, 2019
前端小菜鸟,因为项目要对接微信的jssdk,对接就需要签名认证,但是无奈安卓和IOS各有各的坑,本篇文章只讨论签名,和一个分享的坑,希望大家有所收获,能够解决问题,如果解决不到,请麻烦在评论区留言,本文综合了所有的回答,才调试出来坑

需求: 使用微信的功能

原因:

1. 项目基于vue,在微信上的web应用

2. 要使用上传功能(不同系统的兼容真的很多BUG,最后只能使用微信方案),支付功能,定位....

3. 签名一直存在bug和问题,那么后面的功能都会唤不起(偶尔也可以)

签名

1. 流程详细请看文档,反正能力有限,没看出什么名堂,总结一句话,要使用先签名

2. 开启填坑之路,由于微信使用会区分IOS和安卓系列,不同系列产生不一样的问题

(公司项目第一版的时候就给微信大坑过,所以本次重构的时候,就格外注意这一点)

安利一个在微信下能检测内核的判断:window.__wxjs_is_wkwebview(是否为webview内核),如果是的情况下就变成true

因为SPA应用下,会有一定的问题,路由采用的是history模式(不带#号)。因为在页面每次进入到路由之后才去获取签名授权,所以将方法公用写在路由的模块下

VUE解决微信签名及SPA微信invalid signature问题(完美处理)

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);
 }
})
  • window.entryUrl这个是什么鬼?这个是自己定义的全局属性,就是为了获取IOS第一次进入页面的时候存储起来的,如果IOS的签名的路径不是第一次进入的页面,那么就一定会失败,所以这个路由第一次进入就要储存起来
  • 为什么要写在router.afterEach,因为页面进入了再去做申请和签名,如果在beforeEach,会导致页面申请签名的时候还是上一个页面,但是到了新页面却没有注册签名,或者因为签名的路径不同,导致invalid signature
  • 为什么安卓的时候要增加一个延时器,因为安卓会存在一些情况,就是即便签名成功,但是还是会唤不起功能,这个貌似是一个比较稳妥的解决办法,
看完路由模式了,就来进入逻辑部门,来看看如何处理

VUE解决微信签名及SPA微信invalid signature问题(完美处理)

有同学疑惑这个encodeURIComponent是干嘛用的,其实具体很简单,就是因为我们在微信分享的时候,会自动给我们带上参数(记得告诉后端的伙伴要decodeURIComponent),切记只要带参数就一定要转码!

对于IOS系统会自动增加如下参数:

  • 朋友圈 from=timeline&isappinstalled=0
  • 微信群 from=groupmessage&isappinstalled=0
  • 好友分享 from=singlemessage&isappinstalled=0

对于安卓系统会自动添加如下参数:

  • 朋友圈 from=timeline
  • 微信群 from=groupmessage
  • 好友分享 from=singlemessage

然后就直接去请求签名,写法就不深究,getWeChat是封装的axios,只是为了统一管理才这么写,大家可以写成正常的请求axios('xxxx.com/get-wx',obj).then()这样的写法,一样的效果

VUE解决微信签名及SPA微信invalid signature问题(完美处理)

到了这一步就基本上是请求签名成功,但是有同学疑惑,那么IOS每次分享的时候会不会是进去的第一个路由,我的回答是会的(需要稍加处理)

VUE解决微信签名及SPA微信invalid signature问题(完美处理)

重点关注再与这个link,需要在每次分享的时候记录当前的路由,如果直接读location.href在IOS端的时候会是第一次进入的页面。安卓则没有问题,所以我统一采用我记录的这个参数,这个参数可以直接在方法传递过来,路由afterEach的to.fullpage,然后再加上自己的域名就OK了最后写几句话,希望大家都能顺便解决一下BUG,也希望能对大家有所帮助,如果遇到一些其他的问题,欢迎评论区留言,只要有时间就会及时跟大家交流探讨!也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 鼠标滚轮事件
Apr 09 Javascript
Jquery Ajax.ashx 高效分页实现代码
Oct 20 Javascript
5个javascript的数字格式化函数分享
Dec 07 Javascript
理解Javascript闭包
Nov 01 Javascript
javascript常用的正则表达式实例
May 15 Javascript
自定义Angular指令与jQuery实现的Bootstrap风格数据双向绑定的单选与多选下拉框
Dec 12 Javascript
jquery+ajax+text文本框实现智能提示完整实例
Jul 09 Javascript
详解为Angular.js内置$http服务添加拦截器的方法
Dec 20 Javascript
基于angular2 的 http服务封装的实例代码
Jun 29 Javascript
使用InstantClick.js让页面提前加载200ms
Sep 12 Javascript
angular异步验证防抖踩坑实录
Dec 01 Javascript
vantUI 获得piker选中值的自定义ID操作
Nov 04 Javascript
微信小程序生成分享海报方法(附带二维码生成)
Mar 29 #Javascript
微信小程序学习笔记之文件上传、下载操作图文详解
Mar 29 #Javascript
微信小程序生成二维码的示例代码
Mar 29 #Javascript
微信小程序学习笔记之登录API与获取用户信息操作图文详解
Mar 29 #Javascript
JavaScript实现无限级递归树的示例代码
Mar 29 #Javascript
使用weixin-java-miniapp配置进行单个小程序的配置详解
Mar 29 #Javascript
详解a标签添加onclick事件的几种方式
Mar 29 #Javascript
You might like
日本因肺炎疫情影响,这几部动漫推延播放!
2020/03/03 日漫
PHP的FTP学习(一)[转自奥索]
2006/10/09 PHP
使用Apache的htaccess防止图片被盗链的解决方法
2013/04/27 PHP
php管理nginx虚拟主机shell脚本实例
2014/11/19 PHP
jquery中动态效果小结
2010/12/16 Javascript
jQuery初学:find()方法及children方法的区别分析
2011/01/31 Javascript
纯js写的分页表格数据为json串
2014/02/18 Javascript
JavaScript中的small()方法使用详解
2015/06/08 Javascript
JS DOM实现鼠标滑动图片效果
2020/09/17 Javascript
javascript原型继承工作原理和实例详解
2016/04/07 Javascript
JQuery插件Marquee.js实现无缝滚动效果
2016/04/26 Javascript
基于vue2的table分页组件实现方法
2017/03/20 Javascript
JS中LocalStorage与SessionStorage五种循序渐进的使用方法
2017/07/12 Javascript
JS实现简单短信验证码界面
2017/08/07 Javascript
简单理解Vue中的nextTick方法
2018/01/30 Javascript
vue自定义指令的创建和使用方法实例分析
2018/12/04 Javascript
JavaScript实现打砖块游戏
2020/02/25 Javascript
JavaScript实现点击图片换背景
2020/11/20 Javascript
在 Django/Flask 开发服务器上使用 HTTPS
2014/07/03 Python
python中正则表达式 re.findall 用法
2018/10/23 Python
PyCharm设置护眼背景色的方法
2018/10/29 Python
python实现创建新列表和新字典,并使元素及键值对全部变成小写
2019/01/15 Python
Tornado实现多进程/多线程的HTTP服务详解
2019/07/25 Python
Python编程中类与类的关系详解
2019/08/08 Python
Python对象的属性访问过程详解
2020/03/05 Python
PyCharm MySQL可视化Database配置过程图解
2020/06/09 Python
Selenium之模拟登录铁路12306的示例代码
2020/07/31 Python
解决pycharm不能自动保存在远程linux中的问题
2021/02/06 Python
如何在Canvas上的图形/图像绑定事件监听的实现
2020/09/16 HTML / CSS
Vans(范斯)德国官网:美国南加州的原创极限运动潮牌
2017/05/02 全球购物
美术第二课堂活动总结
2014/07/08 职场文书
捐书倡议书
2014/08/29 职场文书
教师四风自我剖析材料
2014/09/30 职场文书
2014年施工员工作总结
2014/11/18 职场文书
2014年人事行政工作总结
2014/12/03 职场文书
学困生转化工作总结
2015/08/13 职场文书