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 相关文章推荐
js function使用心得
May 10 Javascript
jquery dialog键盘事件代码
Aug 01 Javascript
JSONP 跨域访问代理API-yahooapis实现代码
Dec 02 Javascript
c#+jquery实现获取radio和checkbox的值
Sep 12 Javascript
详解AngularJS中的http拦截
Feb 09 Javascript
JavaScript必知必会(五) eval 的使用
Jun 08 Javascript
Bootstrap 表单验证formValidation 实现远程验证功能
May 17 Javascript
bootstrap3中container与container_fluid外层容器的区别讲解
Dec 04 Javascript
微信小程序loading组件显示载入动画用法示例【附源码下载】
Dec 09 Javascript
jQuery NProgress.js加载进度插件的简单使用方法
Jan 31 jQuery
vue2.0父子组件间传递数据的方法
Aug 16 Javascript
JavaScript检测浏览器是否支持CSS变量代码实例
Apr 03 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
PHP关联数组的10个操作技巧
2013/01/21 PHP
PHP通过加锁实现并发情况下抢码功能
2016/08/10 PHP
javascript 密码强弱度检测万能插件
2009/02/25 Javascript
打印json对象的内容及JSON.stringify函数应用
2013/03/29 Javascript
Jquery带搜索框的下拉菜单
2013/05/06 Javascript
javaScript函数中执行C#代码中的函数方法总结
2013/08/07 Javascript
原始XMLHttpRequest方法详情回顾
2013/11/28 Javascript
js整数字符串转换为金额类型数据(示例代码)
2013/12/26 Javascript
JavaScript实现基于十进制的四舍五入实例
2015/07/17 Javascript
Bootstrap导航条学习使用(二)
2017/02/08 Javascript
JS模拟实现ECMAScript5新增的数组方法
2017/03/20 Javascript
ES5学习教程之Array对象
2017/04/01 Javascript
jQuery 循环遍历改变a标签的href(实例讲解)
2017/07/12 jQuery
使用react实现手机号的数据同步显示功能的示例代码
2018/04/03 Javascript
[14:57]DOTA2 HEROS教学视频教你分分钟做大人-幽鬼
2014/06/13 DOTA
[02:36]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Magma 选手采访
2021/03/11 DOTA
python装饰器-限制函数调用次数的方法(10s调用一次)
2018/04/21 Python
Python利用openpyxl库遍历Sheet的实例
2018/05/03 Python
如何安装多版本python python2和python3共存以及pip共存
2018/09/18 Python
python爬取酷狗音乐排行榜
2019/02/20 Python
大专生的学习自我评价
2013/12/04 职场文书
教育专业自荐书范文
2013/12/17 职场文书
服装设计专业自荐书范文
2013/12/30 职场文书
经理管理专业自荐信范文
2013/12/31 职场文书
乐观大学生的自我评价
2014/01/10 职场文书
九年级家长会邀请函
2014/01/15 职场文书
七年级数学教学反思
2014/01/22 职场文书
元旦晚会感言
2014/03/12 职场文书
授权委托书格式范文
2014/08/02 职场文书
房屋产权共有协议书范本
2014/11/03 职场文书
节水倡议书
2015/01/19 职场文书
工作岗位职责范本
2015/02/15 职场文书
慈善募捐倡议书
2015/04/27 职场文书
Redis分布式锁Redlock的实现
2021/08/07 Redis
Unicode中的CJK(中日韩统一表意文字)字符小结
2021/12/06 HTML / CSS
室外天线与收音机天线杆接合方法
2022/04/05 无线电