微信分享—ios和安卓机制居然不一样!

实际项目中,在做微信分享追踪的时候,遇到了一个百思不得其解的问题。

在加入了用户分享追踪功能之后,页面已经加载完成的情况下,安卓分享功能没有任何问题,ios却总是分享失败。

关于ios和安卓设备的差别

项目需求是,我们需要对用户的分享行为做追踪,对用户从哪个人分享的链接进来的做记录。所以每个用户有一个唯一的分享码。

用户A分享出去,链接上带有他自己的分享码。
用户B点进链接的一瞬间,把当前url上的分享码传给后端做记录,同时替换上自己的分享码。

我使用替换参数的方式是直接修改router的query

this.$router.push({ name: ‘routername‘ //当前路由名称 query: { sharecode: ‘sharecode‘ //修改后的sharecode }})

加上追踪记录之后,却发现安卓设备能够分享成功,也能拿到正确的记录。但是ios总是分享失败,就算切换到其他页面也依然无法分享,只有在刷新页面后才能分享成功。。。

amazing...

如何和后端交互

签名是后端和微信服务器做的事情,我要做的就是把要做签名的url传给后端。

做法很简单,就是监听路由变化(只变化了参数也需要监听),每次变化时给后端传url。

因为不管从什么渠道点入我们的链接,都会有分享码生成并加在路由上,导致一开始页面就会触发两次路由变化;而且,如果用户没有登陆的话微信爸爸还会强行跳转授权,导致页面重载一次,所以如果一个用户没有登陆,那页面会触发4次路由变化!那就需要和后端交互四次。

不能忍!

最后商议的是,默认进入页面的第一次不做记录 ,这样首屏最多只需要交互2次(划重点,后面要考)。

以上故事在告诉我们人为什么要作死

好了我们回到ios分享失败的问题上

解决过程

chorme浏览器调试模式没发现毛病,微信开发者工具也没发现有问题,就是在ios真机上出现了这个bug。(微信开发者工具居然是一个披着ios外衣的android??dev环境是ios,表现行为却和安卓一毛一样)

千辛万苦线上线下调试,最后发现是真机上在用自己的分享码替换别人分享码的这个步骤出现了问题。

安卓设备能够正常替换sharecode参数,但是ios却没有替换成功。后端做签名使用的url是拼接sharecode替换后的链接,所以导致签名和路由匹配不上。

确认使用路由参数替换的方法没有问题,因为安卓环境能够正常替换。所以ios环境该怎么办??

这就引申出了一个问题:vue框架下ios如何在当前页面替换路由参数??

最后是很不优雅的强行重载 - -,相信我会找到解决办法的 > _ <

就这样第一天结束了
——————————时间到了第二天————————————
继续填坑

重载这么恶心的方法当然不行了,不要虚继续干

索性把所有的url都alert出来。

然后,在ios上发现了一个神奇的现象

  1. 点击一个链接,比如http:example.com/a&share=111
  2. ios中弹出当前url没有问题http:example.com/a&share=111,紧接着下一步执行替换分享码操作,将share替换成222,即理论上url会变成http:example.com/a&share=222
  3. 按照昨天的逻辑,share不会被替换,可以弹出url发现,被替换了!当前url的确是http:example.com/a&share=222
  4. 此时再执行分享操作,同时复制当前url。
  5. 分享失败!粘贴刚刚复制的url,share依然是111!wtf !?

ok,紧接着我进行了下一步操作

  1. 我频繁切换的我的路径,跳到c又跳到d,等等,alert出来的url也随着我的切换进行了变化。
  2. 在c或者d页面执行分享操作,同时复制当前url。
  3. 分享失败!粘贴刚刚复制的url,share依然是111!(你没看串行,就是和上面一毛一样)

以上现象可以得出一个结论,在ios环境下(安卓分享正常所以没有测试是不是也有同样的行为),如果签名验证失败,那么不管路由如何变化,不仅分享本身不会成功,而且分享出去的路由永远都是第一次加载时的路由。

后来查阅资料才发现,ios的签名验证机制和安卓不一样。

  • 安卓:对需要分享的每个页面路由做签名,并加载页面分享信息
  • ios: 只需要对第一次进来的页面路由做签名,对每个要分享的页面加载分享信息

这说明了啥,ios环境下,微信只认第一次进来的路由啊!

让我们再把和后端交互部分的重点重复一遍:默认进入页面的第一次不做记录 ,这样首屏最多只需要交互2次

不记录你个大头贴

最后,判断环境是ios的时候,老老实实把第一次的路由给记上。

你问我那ios环境下的首屏最多需要加载4次啦?

认真听讲的小朋友,奖励你一面国旗~

但是!ios只认第一次的路由,我只需要传第一次路由给后端就行,监听路由变化都不用了!

原文地址:https://www.cnblogs.com/wadhf/p/11742947.html

时间: 2024-10-25 18:59:12

微信分享—ios和安卓机制居然不一样!的相关文章

React Native之微信分享(iOS Android)

React Native之微信分享(iOS Android) 在使用React Native开发项目的时候,基本都会使用到微信好友或者微信朋友圈分享功能吧,那么今天我就带大家实现以下RN微信好友以及朋友圈的分享功能. 一,应用申请审核 大家需要去微信开发平台去注册账号并且创建一个移动应用.(地址:https://open.weixin.qq.com),然后根据流程申请即可.但是需要注意的是Android需要获取签名信息: 下载安装上面的签名信息包apk,然后在上面输入android项目的包名,点

微信分享ios设备没有分享图标安卓有分享图标 (分享功能没有问题)

解决方案:去除 var sharedata = { title: $("#shareTitle").val(), desc: $("#shareContent").val(), imgUrl: $("#shareIcon").val(), link: $("#rq1").val() //success: null } wx.onMenuShareAppMessage(sharedata);//分享给朋友 wx.onMenuSh

在Unity3D项目中接入ShareSDK实现安卓平台微信分享功能(可使用ShareSDK默认UI或自定义UI)

最近公司的大厅要重做,我协助主程一起制作新大厅和新框架,前面制作的编辑器也派上了用场.等全部功能做完后我会再写一个复盘,这两天主程在忙于写热更新的功能,所以把接入分享SDK功能的任务交给了我,ShareSDK官网的文档比较分散,而且关于Unity的文档比较简略,所以还是有不少的坑.写篇博客分享一下,并加强理解记忆. 第一步,先去ShareSDK的官网下载最新版本的ShareSDK(完全免费).地址:http://www.mob.com/ 我们选择ShareSDK For Unity3D,页面会直

ios微信分享的兼容性问题

我微信分享采用的是: 页面初始化时动态加载js-sdk, 然后在需要分享的页面进行sdk的分享初始化 app.vue store.vue 这种方法在安卓上完全正常, 好用得令人发指, 但是!!! ios却不是省油灯 ios的分享 参数都没带上来 链接是第一次进入的页面 ! 破案 -> IOS:每次切换路由,SPA的url是不会变的,发起签名请求的url参数必须是当前页面的url就是最初进入页面时的url Android:每次切换路由,SPA的url是会变的,发起签名请求的url参数必须是当前页面

IOS ShareSDK实现分享——微信分享

最近领导让添加ios 微信分享视频的功能,之前做的只有微信分享本地图片的功能. 查看官网并没有找到答案,后来在其官网论坛中http://bbs.mob.com/thread-20938-1-1.html 这里面发现新版的sdk(v3.2.1)中才添加的微信分享本地文件(mp3.mp4.docx.pdf等)的功能.可以支持就好办了.. 使用集成好的第三方框架可以节省许多代码量. 注意:申请shareSdk的apply,还有各个平台的appkey和appsecert(这真是非常麻烦的事情啊) 集成S

【腾讯Bugly干货分享】微信读书iOS性能优化

本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/578c93ca9644bd524bfcabe8 "8小时内拼工作,8小时外拼成长"这是大家共同的理想.除了每天忙于工作外,我们都希望能更多地区吸收领域内的新知识与新技能,从而走向人生巅峰. Dev Club 是一个交流移动开发技术,结交朋友,扩展人脉的社群,成员都是经过审核的移动开发工程师.每周都会举行嘉宾分享,话题讨论等活动. 上一期我们邀请了腾讯SNG工程师&qu

ios与安卓微信浏览器背景底色不同的问题

ios微信内置浏览器默认是白色背景底色:而安卓机微信内置浏览器默认是灰色背景底色.底色不同导致h5页面在不同机型的微信浏览器内打开,显示效果不同.如何兼容? <template> <div class="index" id="index"> ... </div> </template> <script> export default{ data(){ return{} }, mounted(){ docum

iOS 微信分享 朋友圈(2016.3.17) - 王彬分享,越分享,越快乐

一,先配置 1.首先去微信开放平台注册账号(是微信开放平台 不是腾讯开放平台,两者不一样) https://open.weixin.qq.com 注册完成之后记得创建应用,后边会用到.只需要注册就行, 拿到AppID 就行,不用上传app 2.下来我们在 微信开放平台的资源中心中下载sdk 下载完成后 里面有我们需要的工具包 3.接下来我们讲刚才下载的三个工具包拖入我们的项目 拖入后的效果如下: 4.导入我们需要的framwork: 5.接下里 一定记得在 Build Settings->Sea

cocos2d-x集成sharesdk做微信分享android,ios

白白手游专栏http://blog.csdn.net/u010229677 这些天做了一下cocos2d-x的微信分享功能,稍有心得,整理了一下,出了个文档,欢迎大家点击查看 http://download.csdn.net/detail/u010229677/7867383