[贝聊科技]网页端「应用跳转」技术实现演变

本文作者:Mr.Luo ,贝聊前端经理。本文同时发布于作者 个人博客 。

由于网页传播的便捷性,从网页向APP导流几乎是所有APP厂商都会采用的推广手段,具体来说就是在网页上提供一些触发点(例如按钮、链接),用于跳转到APP。

应用跳转

01.URL Scheme

早期的应用跳转只能通过「URL Scheme」实现。例如通过下面这个「URL Scheme」,就可以跳转到「贝聊APP」:

ibeiliao://

在网页中调用「URL Scheme」也有多种方法:

<!-- 方案一:链接跳转 -->
<a href="ibeiliao://">打开贝聊</a><!-- 方案二:JS跳转 -->
<a href="javascript:location.href='ibeiliao://'">打开贝聊</a><!-- 方案三:iframe调用 -->
<span id="open-ibeiliao">打开贝聊</span>
<script>
document.getElementById('open-ibeiliao').onclick = function() {var iframe = document.createElement('iframe');iframe.src = 'ibeiliao://';iframe.style.display = 'none';document.body.appendChild(iframe);setTimeout(function(){document.body.removeChild(iframe);}, 3000);
};
</script>

原本「方案三」是最受欢迎的,因为在没有安装对应APP的情况下,另外两个方案在iOS Safari下都会出现「浏览器无法打开网页」的弹框。

没有安装APP时的弹框

然而,「方案三」是最先“阵亡”的,最早是在iOS 9中的Safari失效,后来在某些安卓机的浏览器也不行了,所以目前只能用「方案一」和「方案二」,而iOS Safari下的那个弹框也就无法避免了。

理论上,「URL Scheme」可以在任何浏览器以及APP中的WebView使用,但实际上却是被大量APP封杀,几乎是只能在浏览器类的APP中使用。因为大部分厂商都不希望用户离开自己的APP。

02.打开还是下载?

前文提到了一个问题,万一设备上没有安装要跳转的APP,那怎么办呢?正常来说,应该要跳到该APP的下载页。然而,这里面最大的难题是:网页端基本上无法获知当前设备是否已安装某个APP(之所以加上“基本”二字,是因为网页在微信内运行时,可通过调用微信内部的JS API实现此功能,但该API只对腾讯的“关系户”开放)。

后来,人们想出了一种解决方案:在使用「URL Scheme」跳转的同时,通过定时器在一定时间之后跳转到下载页。倘若设备上有安装APP,就会跳到APP,否则在一定时间后就会跳到下载页。

<span id="open-ibeiliao">打开贝聊</span>
<script>
document.getElementById('open-ibeiliao').onclick = function() {window.location.href = 'ibeiliao://';setTimeout(function() {window.location.href = 'https://mobile.ibeiliao.com/download';}, 1000);
};
</script>

这么做基本上是达到了目的,但是有两处体验问题仍然无法解决:

  • 即便已经安装APP,浏览器也会跳到下载页。用户从APP返回浏览器时会发现莫名其妙地出现了下载页。
  • 在没有安装APP的情况下,iOS Safari的弹框还是无法避免,但是跳到下载页之后会消失。

03.应对封杀

前文有提及,「URL Scheme」被大量APP封杀,其中就包括常用的QQ和微信,但是没有谁会放弃这两个重要渠道,所以还是得想辙。

最无奈的解决方案就是提示用户「用浏览器打开网页」,继而让用户在浏览器中打开APP。然而,这对非IT人士来说,操作起来还是有一点繁杂的。

提示用户用浏览器打开

另一种好一点的做法是,先跳转到腾讯的「应用宝」,「应用宝」会根据设备是否已装APP去执行打开或者下载操作。当然,这种做法需要把APP传到「应用宝」,而且只对腾讯系的APP有效;对于其他APP,仍然只能提示「用浏览器打开网页」。

应用宝

最后一个解决方案就是下文要讲述的「Universal Links」。

04.Universal Links

「Universal links」,中文翻译为「通用链接」,从iOS 9开始支持,仅通过普通的https请求就能跳转到指定的应用。

开发者可以把应用的下载页地址配置为一条通用链接,这样,用户在进入下载页时:

  • 如果设备上已安装APP,则进入APP;
  • 如果设备上没有安装APP,则进入下载页,再也没有那个烦人的弹框了。

最重要的是,通过「通用链接」,即使在微信、QQ内,也能如丝般顺滑地跳到自家APP。大家都以为这是系统级别的处理,无法被任何APP封杀,直到不久前的一天,它在微信下跪了。。。根据某大神的分析,苹果还是给「通用链接」留下了“后门”可以让其失效。

而在Android系统下,也有类似的技术,即App Links,从Android M开始支持。但由于国内安卓版本碎片化比较严重,所以应用还不怎么广泛。

05.小结

讲到这,先小结一下应用跳转的实现方案。

  • Android:
    • 微信、QQ:「URL Scheme」不可用,可通过「应用宝」中转。
    • 浏览器:「URL Scheme」可用。
    • 其他APP:提示用浏览器打开。
  • iOS>=9(支持「Universal Links」):
    • 微信:「URL Scheme」和「Universal Links」均不可用,通过「应用宝」中转。
    • QQ:「Universal Links」尚且可用。
    • QQ浏览器:「Universal Links」不可用,但「URL Scheme」可用。
    • 其他APP:「Universal Links」可用。
  • iOS<9(不支持「Universal Links」):
    • 微信、QQ:「URL Scheme」不可用,提示用浏览器打开。
    • 各浏览器:「URL Scheme」可用。
    • 其他APP:提示用浏览器打开。

要注意的是,所谓的「其他APP」是无法准确检测的,只能根据APP在User Agent中增加的特殊关键字(例如新浪微博的「Weibo」)逐个判断。

06.打开APP的指定页

需求是无止境的,能从网页进入APP只是开始,下一步就是跳转到指定页面。这里所说的指定页面,可能是原生的页面,也可能是某个网页。这个过程的关键在于打开APP时如何把页面路径传过去。

先从「URL Scheme」说起。我们可以给「URL Scheme」加上路径和参数,例如:

my-app://open?url=https:/%2Fcn.bing.com/

APP端只要解析参数,继而打开对应的页面即可。对于「Universal Links」来说,也是同理:

https://my-app.com/download?url=https://cn.bing.com/

正如上文所说,「URL Scheme」和「Universal Links」都被微信封杀了。如果通过「应用宝」中转,上述url参数是无法传到APP的。在这种情况下,就得寻找一个微信WebView和APP都可以共同读写的空间来传递数据,例如剪贴板。下面这个JS函数可以实现对剪贴板的写入:

function copyToClipboard(content) {var textarea = document.createElement('textarea');textarea.style.position = 'absolute';textarea.style.left = '-1000px';textarea.style.top = '-1000px';textarea.value = content;textarea.readOnly = true;document.body.appendChild(textarea);textarea.select();textarea.setSelectionRange(0, textarea.value.length);var result = false;try {result = document.execCommand('copy');} catch (e) {}document.body.removeChild(textarea);textarea = null;return result;
}

跳转到APP的应用宝地址之前,把要打开的页面地址以约定好的格式写入剪贴板:

copyToClipboard('my-app:open?url=https://cn.bing.com/');
location.href = 'my-app的应用宝地址';

通过「应用宝」打开APP后,APP端按照约定格式解析剪贴板内容打开对应的页面即可。

这里有一个细节:为什么不直接以完整的「my-app://open?url=」写入剪贴板,而要特意去掉「//」?这是因为在Android系统下,某些浏览器APP会把剪贴板中的「URL Scheme」识别为网址,然后提示用户是否打开。对于用户来说,点击「打开APP」出现这个提示,就有点莫名其妙了。

当然,「剪贴板方案」也存在一些问题:

  • 会覆盖用户的剪贴板内容。
  • 部分Android系统的原生浏览器不支持通过JS访问剪贴板,不过这不是问题,因为在浏览器中大可以用「URL Scheme」。

如果不想用「剪贴板方案」,还是可以提示用户用浏览器打开页面的。具体如何取舍,就看各自产品经理的决定了。


更多专业前端知识,请上 【猿2048】www.mk2048.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/366391.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux服务器配置---安装vsftpd

安装vsftpd 大多数Linux系统都使用vsftpd&#xff0c;因此这里我们也安装vsftpd 1、安装vsftpd [rootlocalhost phpMyAdmin]# yum install -y vsftpd Loaded plugins: fastestmirror, refresh-packagekit, security Installed: vsftpd.i686 0:2.2.2-11.el6_4.1 …

mysql怎么制作柱状图_从数据库中取出最近三十天的数据并生成柱状图

在终端用cd 命令进入文件目录说明&#xff1a;此处例子我是拿项目中的一个例子讲解的。1、新建一个项目 &#xff1a;用终端输入&#xff1a;zf create project Airline 格式&#xff1a;zf create action project project-name 备注&#xff1a;这些格式可以在终端输入zf 查看…

关于ES6的Promise

JavaScript的异步处理 提到JavaScript的异步处理&#xff0c;也许很多人和我一样想到利用回调函数。 例如&#xff1a; firstAsync(function(data){//处理得到的 data 数据//....secondAsync(function(data2){//处理得到的 data2 数据//....thirdAsync(function(data3){//处…

[转]我是如何走进黑客世界的?

*本文原创作者&#xff1a;MyselfExplorer&#xff1b;翻译编辑&#xff1a;楼兰&#xff0c;本文属FreeBuf原创奖励计划&#xff0c;未经许可禁止转载 我想给你一把打开这扇门的钥匙&#xff0c;而你要做的便是静静的聆听接下来的故事。挖掘 0day 一般需要掌握fuzzing&#xf…

Socket.io 深入理解

最近在做项目优化工作时&#xff0c;用到了Socket.io , Socket.io 文档比较少&#xff0c; 结合官网介绍以及自己在项目开发中的摸索&#xff0c;总结如下内容&#xff1b; Socket.io将Websocket和轮询 &#xff08;Polling&#xff09;机制以及其它的实时通信方式封装成了通用…

python填表_小Python填表得到d

我正在尝试使用Scrapy从网站自动下载数据。在我要做的是&#xff1a;使用我的凭据登录网站通过在“RIC”行中写入代码并选择感兴趣的时段来选择我想要的数据单击“获取数据”后&#xff0c;将生成.csv文件&#xff0c;我可以从“下载/”url下载该文件&#xff0c;其中我的所有文…

我理解中的“大前端”/“大无线”

本文内容较长&#xff0c;大概需要15分钟时间阅读。 内容包含五部分&#xff1a;前言&#xff0c;NodeJS职能变化&#xff0c;ReactNative的大规模应用&#xff0c;专门的架构组职能&#xff0c;总结。主要是介绍我所在团队最近的一些变化和思考。 更多信息可以加入我的小密圈关…

Dirichlet分布

1.预备知识 Beta分布函数是一种定义在实数区间[0,1]的特殊函数&#xff0c;它是二项式分布的共轭分布&#xff1b;与Beta分布相同&#xff0c;Dirichlet分布也是定义在实数区间[0,1]的概率度量函数&#xff0c;Dirichlet分布是多项式分布的共轭分布&#xff0c;Dirichlet分布的…

布局定位

布局与定位 摆放元素 1&#xff0c;使用流 流实际上就是浏览器在页面上摆放HTML元素所用的方法。浏览器从HTML文件最上面开始&#xff0c;从上到下沿着元素流逐个显示所遇到的各个元素。 每个块元素会按它在HTML标记中出现的顺序放置在页面上。每个新的块元素会带来一个换行。并…

python语言精通_Python语言基础从入门到精通

1、python关键字False await else import passNone break except in raiseTrue class finally is returnand continue for lambda tryas def from nonlocal whileassert del global not withasync elif if or yield2、命令行参数williamdeMBP-2:~ william$ python -c "imp…

FreeNAS:创建 CIFS 共享(权限)

第一部分&#xff1a;新建账户与指定数据集权限 简单起见&#xff0c;本教程主要介绍带基本身份验证的 CIFS 共享&#xff0c;即只有输入正确的用户名和密码才可以访问共享目录。关于创建匿名共享、多用户权限管理以及域控制器相关内容&#xff0c;我们会另外发布教程专门介绍。…

oracle日记账单据编号未生成_商管财务数据平台Oracle与共享未付池差异如何核对、解决?...

‍‍近期&#xff0c;总部新上线财务数据平台啦&#xff01;各个系统间的差异异常数据清晰可见&#xff0c;随时可查&#xff0c;今天就和小伙伴们一起分享一下Oracle与共享未付池差异如何核对、解决。首先&#xff0c;将Oracle与共享未付池差异数据导出。由于导出的数据包括本…

android paint 圆角 绘制_[BOT] 一种android中实现“圆角矩形”的方法

内容简介文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式&#xff0c;四个角可以分别指定为圆角。思路是利用“Xfermode Path”来进行Bitmap的裁剪。背景圆角矩形实现的方法应该很多&#xff0c;网上一大堆。很怀疑为啥安卓的控件不内置这样的属…

Cisco TrustSec(理解)

1、Cisco TrustSec的限制当指定了无效的设备ID时&#xff0c;受保护的访问凭据&#xff08;Protected access credential&#xff0c;PAC&#xff09;设置将失败并保持挂起状态。 即使在清除PAC并配置正确的设备ID和密码后&#xff0c;PAC仍然会失败。作为解决方法&#xff0c;…

Java 8仍然需要LINQ吗? 还是比LINQ更好?

长期以来&#xff0c; LINQ是.NET软件工程生态系统中发生的最好的事情之一。 通过在Visual Studio 2008中引入lambda表达式和monads &#xff0c;它使C&#xff03;语言比Java&#xff08;当时的版本6&#xff09;更先进&#xff0c;并且仍在讨论泛型类型擦除的优缺点。 这项成…

web前端(12)—— 页面布局2

本篇博文&#xff0c;主要就讲定位的问题&#xff0c;也就是页面布局里最重要的&#xff0c;本篇博文不出意外的话&#xff0c;也是css的最后一篇博文了 定位&#xff0c;position属性 定位有三种&#xff1a; 相对定位绝对定位固定定位 相对定位&#xff0c;position&#x…

python pyplot中axis_Python Pyplot xaxis未显示在图形上

pyplot未在图形上显示x轴&#xff1a;import pandas as pdimport matplotlib.pyplot as pltdf pd.read_csv(sitka_weather_2014.csv)df[AKST] pd.to_datetime(df.AKST)df[Dates] df[AKST].dt.strftime(%b %d, %Y)df.set_index("Dates", inplace True)# Plot Dataf…

web前端入门学习(纯干货)

web前端怎么样才能入门&#xff0c;首先我们要从什么是初级web前端工程师说起&#xff1a; 按照我的想法&#xff0c;我把前端工程师分为了入门、初级、中级、高级这四个级别&#xff0c; 入门级别指的是了解什么是前端&#xff08;前端到底是什么其实很多人还是不清楚的&…

[校内模拟题2]

水题 但是原地螺旋炸裂 都不好意思贴代码了QWQ enc 【问题背景】 zhx 和他的妹子聊天。 【问题描述】 考虑一种简单的加密算法。假定所有句子都由小写英文字母构成&#xff0c; 对于每一个字母&#xff0c; 我们将它唯一地映射到另一个字母。 例如考虑映射规则&#xff1a;a-&g…

AJAX初识(原生JS版AJAX和Jquery版AJAX)

一、什么是JSON 1.介绍JSON独立于语言&#xff0c;是一种与语言无关的数据格式。JSON指的是JavaScript对象表示法&#xff08;JavaScript Object Notation&#xff09;JSON是轻量级的文本数据交换格式JSON具有自我描述性&#xff0c;更易理解JSON使用JavaScript语法来描述数据对…