vue 微信分享回调iOS和安卓回调出现错误的解决


Posted in Javascript onSeptember 07, 2020

产品需求:在微信内分享需要手动配置的分享地址、分享图片与内容描述,引导用户分享,并在微信分享成功回调内进行相应的操作。

首先需要在项目中引入微信jsSDk包,然后通过接口获取后台签名。

vue 微信分享回调iOS和安卓回调出现错误的解决

封装函数获取微信分享必填参数

vue 微信分享回调iOS和安卓回调出现错误的解决

其中的jsApiList中填的是需要使用的微信分享js接口的列表,参数URL默认是location.href,即分享当前页面的URL。

在需要分享的页面引入封装的函数

vue 微信分享回调iOS和安卓回调出现错误的解决

然后通过wxShare方法将URL和配置的参数传入,link参数是分享出去的链接,必须与当前页面的对应js安全域名一致;

vue 微信分享回调iOS和安卓回调出现错误的解决

...shareData就是在函数内传对象,进行解构赋值es6写法

vue 微信分享回调iOS和安卓回调出现错误的解决

但是在测试过程中发现:

1.同一套程序,andriod分享正常,ios分享报签名不正确,主要原因是微信的ios和安卓处理方式不一样,ios不会刷新当前的页面地址,使用的是history的记录地址,所以每次分享出来的链接,都是第一个进入系统页面的链接,当跳转到子页面的时候,系统就会识别打开的url和签名的url不一致导致签名不正确

2.由于单页面的hash模式会自带#号,但是分享的时候会将#号后面的参数变成无效,导致想传参数都传不过去,可以做一个页面没有#号的,然后统一带参数分享到这个页面然后再重定向到指定的vue页面

解决方法:在向后台发送请求获取微信签名的时候将传给后台的URL的#后面的参数截去,后台根据截取完的URL生成签名就能实现安卓和iOS分享回调成功的问题。

vue 微信分享回调iOS和安卓回调出现错误的解决

补充知识:使用Vue全家桶进行微信分享时出现的错误

使用vue.js进行微信H5页面开发,开发过程中先进行oAuth身份验证。后使用JSSDK,进行微信分享。分享时会出现不调用自定义分享界面的情况,但是在刷新后可以正常显示,

如下:

正常进入分享:

vue 微信分享回调iOS和安卓回调出现错误的解决

刷新后分享:

vue 微信分享回调iOS和安卓回调出现错误的解决

由于Vue和微信调试环境的问题,在经过几次痛苦的尝试后,我们发现了一个现象,那就是,如果此时点击使用Safari打开,会出现:

vue 微信分享回调iOS和安卓回调出现错误的解决

这是我们在使用oAuth认证时跳转的中间界面(从oauth回调的页面),但是在使用微信调试工具的时候,显示的url为正确页面,既为从回调页面跳转的页面。

我们知道,在使用JSSDK进行微信认证的时候,需要使用当前url调用wxcofig,那会不会有一种可能,当vue进行页面跳转的时候,微信浏览器仍然认为当前页面在原页面,所以导致传递的url和微信认为你的url不一致,所以导致认证错误。

于是在尝试给wxconfig传递url的时候,使用了跳转前中间结果的url(既,保持传递给认证的url和使用Safari打开的url一致),结果居然就行了。。。

行吧,算是微信在兼容vue的时候的一个坑,但愿大家以后能尽早跳出来。。。

以上这篇vue 微信分享回调iOS和安卓回调出现错误的解决就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
提高代码性能技巧谈—以创建千行表格为例
Jul 01 Javascript
不错的一个日期输入 动态
Nov 06 Javascript
基于jquery打造的百分比动态色彩条插件
Sep 19 Javascript
javascript中的作用域和上下文使用简要概述
Dec 05 Javascript
jQuery中siblings()方法用法实例
Jan 08 Javascript
JS使用ajax方法获取指定url的head信息中指定字段值的方法
Mar 24 Javascript
深入学习jQuery中的data()
Dec 22 Javascript
BootStrap实现带关闭按钮功能
Feb 15 Javascript
Angular5中提取公共组件之radio list的实例代码
Jul 10 Javascript
JavaScript代理模式原理与用法实例详解
Mar 10 Javascript
vue 如何从单页应用改造成多页应用
Oct 23 Javascript
vue如何使用rem适配
Feb 06 Vue.js
一篇文章带你从零快速上手Rollup
Sep 07 #Javascript
基于vue hash模式微信分享#号的解决
Sep 07 #Javascript
在项目vue中使用echarts的操作步骤
Sep 07 #Javascript
解决vue加scoped后就无法修改vant的UI组件的样式问题
Sep 07 #Javascript
Vue.js原理分析之nextTick实现详解
Sep 07 #Javascript
小程序实现可拖动的悬浮按钮
Sep 07 #Javascript
vue 修改 data 数据问题并实时显示操作
Sep 07 #Javascript
You might like
Optimizer与Debugger兼容性问题的解决方法
2008/12/01 PHP
PHP详解ASCII码对照表与字符转换
2011/12/05 PHP
Codeigniter框架实现获取分页数据和总条数的方法
2014/12/05 PHP
浅谈PHP接收POST数据方式
2015/06/05 PHP
JS对象转换为Jquery对象示例
2014/01/26 Javascript
关于img的href和src取变量及赋值的方法
2014/04/28 Javascript
js取得html iframe中的元素和变量值
2014/06/30 Javascript
在NodeJS中启用ECMAScript 6小结(windos以及Linux)
2014/07/15 NodeJs
js清空表单数据的两种方式(遍历+reset)
2014/07/18 Javascript
深入理解JavaScript系列(36):设计模式之中介者模式详解
2015/03/04 Javascript
jquery实现TAB选项卡鼠标经过带延迟效果的方法
2015/07/27 Javascript
javascript日期处理函数,性能优化批处理
2015/09/06 Javascript
微信小程序 WXML、WXSS 和JS介绍及详解
2016/10/08 Javascript
jquery文字填写自动高度的实现方法
2016/11/07 Javascript
bootstrap时间插件daterangepicker使用详解
2017/10/19 Javascript
JavaScript实现二叉树定义、遍历及查找的方法详解
2017/12/20 Javascript
vue.js实现简单的计算器功能
2020/02/22 Javascript
用VsCode编辑TypeScript的实现方法
2020/05/07 Javascript
python中的代码编码格式转换问题
2015/06/10 Python
python自定义异常实例详解
2017/07/11 Python
Python cookbook(数据结构与算法)字典相关计算问题示例
2018/02/18 Python
用tensorflow搭建CNN的方法
2018/03/05 Python
Python使用combinations实现排列组合的方法
2018/11/13 Python
matplotlib实现区域颜色填充
2019/03/18 Python
Python3.7 pyodbc完美配置访问access数据库
2019/10/03 Python
PyCharm如何导入python项目的方法
2020/02/06 Python
处理HTML5新标签的浏览器兼容版问题
2017/03/13 HTML / CSS
贝玲妃美国官方网站:Benefit美国
2016/08/28 全球购物
世界上最大的字体市场:MyFonts
2020/01/10 全球购物
机修工工作职责
2014/02/21 职场文书
检查机关党的群众路线个人整改措施
2014/10/04 职场文书
幼儿园庆六一主持词
2015/06/30 职场文书
2019最新版试用期劳动合同模板!
2019/07/04 职场文书
Python用tkinter实现自定义记事本的方法详解
2022/03/31 Python
正则表达式基础与常用验证表达式
2022/06/16 Javascript
js前端设计模式优化50%表单校验代码示例
2022/06/21 Javascript