资讯专栏INFORMATION COLUMN

浏览器唤起qq进行聊天的一些坑和解决方案 - 小裂变

shiina / 1829人阅读

摘要:在手机端浏览器中也会存在类似于中的情况网页内嵌到自开发的中,需要唤起时也会出现类似与的情况。由于浏览器在苹果手机端使用率很高,应业务需求,就不得不为它找一种另外的方式。

小裂变-微信生态用户裂变增长专家
小裂变官网:www.xiaoliebian.com
首创微信生态一体化裂变运营,公众号裂变、小程序裂变、社群裂变、个人号裂变
说明

从浏览器唤起QQ进行聊天,是很多公司或者企业会用到的一种客服方式,然而很多时候,一些手机端浏览器并不支持直接跳转到QQ,或者不支持从App内嵌的网页中跳转到QQ页面。

正文

针对跳转唤起QQ,QQ推广的官方网站http://shang.qq.com/v3/index....,只需要扫描登录需要被唤起的QQ号,就可以生成一段代码如下所示:



这里的数字“123456789”就是需要被唤起的QQ号码。

应用这种方式,可以在大部分的浏览器中唤起QQ客户端,并定位到聊天页面,只是以下几种情况中这种方式会失效:

苹果手机自带的 Safari 浏览器会提示是否在AppStore中打开链接,如果选择是就会直接跳转到App Store 中,然后才能跳转到QQ,但是两次跳转会丢失参数,导致不能打开需要聊天的对象。

在手机端Google浏览器中也会存在类似于 1 中的情况

网页内嵌到自开发的App中,需要唤起QQ时也会出现类似与 1 的情况。

由于Safari浏览器在苹果手机端使用率很高,应业务需求,就不得不为它找一种另外的方式。

通过了解,发现app之间的联系可以通过一种叫做深度链接的技术解决,所谓的深度链接就是绕过网站的首页直接链接道分页的一种链接技术,具体想要了解的可以看看LinkedMe上的一片博文https://www.linkedme.cc/blog/...。

深度链接中的一个解决方案就是定义一个新的URL Scheme ,这个URL Scheme可以通过特定的URI方式传递参数给另一个APP,从而改变App之间独立不通信的局面。

多带带说倒唤起QQ,或者解决Safari浏览器不能唤起QQ的问题,可以使用如下的URI:

mqqwpa://im/chat?chat_type=wpa&uin=123456789&version=1&src_type=web&web_src=oicqzone.com

其中数字“123456789”同样的是需要被唤起的QQ。


 123456789

通过多次测试,我整理出如下手机端浏览器唤起QQ的各种不同情况(其中no代表测试不成功,ok代表测试成功):

这里需要提到一点,将URL Scheme 的方案用于电脑的各种浏览器从而去唤起QQ是不起任何效果,因为URL Scheme是专门为解决APP之间孤立的情况而提出来的,并不适用于电脑应用,但是在电脑端可以使用QQ推广给出的的方案。

知道了如何解决App跳转到QQ的方法,但是很多时候我们希望有一种通用的办法可以解决上述几种情况,保证在大多数浏览器(包括电脑浏览器)只需要一套代码就可以解决问题。

我个人通过判断浏览器的userAgent区分手机端浏览器还是电脑端浏览器,然后为它们分别提供不同的方案:

HTML代码

111111111111

JavaScript代码

window.onload = function () {

    var as = document.getElementsByTagName("a");

    var kefu101 = "http://wpa.qq.com/msgrd?v=3&uin=381232999&site=oicqzone.com&menu=yes";
    var kefu102 = "mqqwpa://im/chat?chat_type=wpa&uin=381232999&version=1&src_type=web&web_src=oicqzone.com";

    for (var i = 0, len = a.length; i < len; i++) {

        if (as[i].hasAttribute("data-qq")) {

            as[i].onclick = (function (i) {

                return function (e) {

                    var kefu = e.target ? e.target.getAttribute("data-qq") : e.srcElement.getAttribute("data-qq");

                    if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent) || /(Android)/i.test(navigator.userAgent)) {

                        window.open(kefu102);
                    }else {
window.open(kefu101);
                    }
                }
            })(i);
        }
    }
};

这套方案中,手机端使用URL Scheme,电脑端使用QQ推广的方案。

个人微信:zmx119966(欢迎来交流)

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/87942.html

相关文章

  • 览器唤起qq进行聊天一些坑和解决方案 - 裂变

    摘要:在手机端浏览器中也会存在类似于中的情况网页内嵌到自开发的中,需要唤起时也会出现类似与的情况。由于浏览器在苹果手机端使用率很高,应业务需求,就不得不为它找一种另外的方式。 小裂变-微信生态用户裂变增长专家 小裂变官网:www.xiaoliebian.com 首创微信生态一体化裂变运营,公众号裂变、小程序裂变、社群裂变、个人号裂变 说明 从浏览器唤起QQ进行聊天,是很多公司或者企业会用到的...

    Charles 评论0 收藏0
  • js在微信、微博、QQ、Safari唤起App解决方案

    摘要:之前,下的微信支持这种唤起方式,但是从年月日之后,微信把这个给屏蔽了不管微信基于什么原因,把下这种最便捷的唤起方式屏蔽,我们能做的只能是适应了。微博微博目前还支持唤起,我们只需要考虑未下载的情况。 背景 最近在做微信、QQ、微博中使用js唤起App,之前也做过类似的功能,不过比较粗糙,考虑的情况不太全,而且那已经是很久之前的事情了,很多技术都已过时,现在有体验更好,功能更加完善的唤起技...

    oliverhuang 评论0 收藏0
  • js在微信、微博、QQ、Safari唤起App解决方案

    摘要:之前,下的微信支持这种唤起方式,但是从年月日之后,微信把这个给屏蔽了不管微信基于什么原因,把下这种最便捷的唤起方式屏蔽,我们能做的只能是适应了。微博微博目前还支持唤起,我们只需要考虑未下载的情况。 背景 最近在做微信、QQ、微博中使用js唤起App,之前也做过类似的功能,不过比较粗糙,考虑的情况不太全,而且那已经是很久之前的事情了,很多技术都已过时,现在有体验更好,功能更加完善的唤起技...

    tuantuan 评论0 收藏0
  • 浅析微信支付:商户平台开通现金红包、指定用户发放、红包记录查询

    摘要:本文是浅析微信支付系列文章的第十三篇,主要讲解在如何开通商户平台的红包功能和为用户发放红包,以及查询发送红包记录。操作路径登录微信支付商户平台产品中心现金红包开通。 本文是【浅析微信支付】系列文章的第十三篇,主要讲解在如何开通商户平台的红包功能和为用户发放红包,以及查询发送红包记录。 浅析微信支付系列已经更新十三篇了哟~,没有看过的朋友们可以看一下哦。 浅析微信支付:(余额提现)企业...

    fizz 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<