web端唤醒本地应用并检测是否唤醒成功

如题所述

第1个回答  2022-07-09
web端可以通过自定义URL Protocol来调用本地的应用程序。我们只需要通过一个链接如: <a href="tencent://">打开QQ</a> 或者直接在浏览器中输tencent://(tencent://为QQ的自定义URL Protocol)就能够使得浏览器去寻找 注册表 并打开对应的本地应用程序。

关于上面提到的 注册表 和为什么通过自定义URL Protocol就可以调用本地的应用程序的介绍在网上已经有很多相关的博客了,我会将一些我觉得比较详细和清晰的文章贴出来,就不详细介绍其中的原理了。
通过自定义URL协议在Web网页中启动本地应用程序
前端网页如何打开一个PC本地应用

但是,上面说到的这些都不是今天的重点,今天的重点是我们如何得知我们有没有成功唤醒本地应用。

如果你曾经再网上搜索过这个问题,那么你得到的最终解决方案大概率是他—— protocolcheck.js
protocolcheck.js根据各种浏览器在通过自定义协议调用本地应用的不同反应,整理了各个浏览器对应的hacks,并通过检测用户所使用的浏览器来调用对应的hacks来检测浏览器是否有成功唤醒应用:

虽然protocolcheck. js已经将刚刚浏览器对应的检测方法封装起来,但这些方法毕竟大多数都是hacks,并且已经有三四年没有进行更新了,随着浏览器的更新肯定会逐渐暴露出许多问题(亲测最新版的chrome和Firefox都已失效)。

显然这不是一个很好的解决方案,正当我想和产品经理去探讨这个需求的可行性时,我想到了百度网盘似乎也有类似的功能,那么百度网盘是怎么实现的呢?

通过百度网盘web端的唤醒功能一段时间的研究,我发现在唤醒过程中他会不断发送同一个请求,在唤醒成功后便不在发送,查看该请求的响应我们可以看到该请求返回了errno,request_id,status三个字段,其中,在唤醒成功时,除了唤醒成功前的最后一个请求的status为1之外,其他请求的status均为2。

而在唤醒失败时,则所有请求的status均为2。

不难判断出,百度云盘是通过web端和客户端直接通讯来判断出是否唤醒成功,但他们是如何进行通讯的呢?这个问题我们先按下不表,但这种方式又让我联想到了EN和QQ邮箱的快速登录功能,当我们启动了 QQ客户端,再去访问 QQ 邮箱登录页,页面会提示我们已经登录了的 QQ,点击即可登录。

响应内容

这个请求返回了登录信息,并且是通过向127.0.0.1:4301获得的,那么问题来了,这个服务是谁提供的呢?

真相大白!由上面的信息我们可以判断出是QQ的客户端开启了一个HTTP Server,当浏览器打开页面时,会向这个Server发起请求来判断用户是否已经登录并返回对应的用户信息。

前提:要唤醒的本地应用是自家开发的。
通过百度云盘和快速登录的案例,我们可以得到唤醒本地应用的最终方案:

问题看似被解决了,但我们其实还需要解决web端与本地应用的HTTP Server的跨域问题:
方案一:通过后台代理,这是百度云盘使用的方式;
方案二:通过jsonp,这是qq邮箱快速登录使用的方式;
方案一成本较高,需要加多一层代理层,并且需要想办法生成一个唯一标识来标记当前浏览器;方案二没有唯一标识的问题,但需要提前对端口号进行约定,并且有可能出现端口号被占用的情况。最终基于成本和端口被占用的概率考虑,我选择了方案二,虽然不算完美,但也算是能够满足大多数用户的需求了。

web端唤醒本地应用并检测是否唤醒成功
通过百度网盘web端的唤醒功能一段时间的研究,我发现在唤醒过程中他会不断发送同一个请求,在唤醒成功后便不在发送,查看该请求的响应我们可以看到该请求返回了errno,request_id,status三个字段,其中,在唤醒成功时,除了唤醒成功前的最后一个请求的status为1之外,其他请求的status均为2。而在唤醒失败...

从网页web上检测本地应用程序是否存在?
通过web遍历你的电脑是否含有某个应用程序(可以是文件夹或者某个配置文件什么的)

如何在WEB端,调用本地程序
目前在Internet上的应用均采用客户服务器模型,客户提出请求,服务器作出应答,即所谓请求应答模式,使用最广的是客户端为浏览器的B/S模式。通常,浏览器中是禁止运行本地可执行程序的。但不允许浏览器运行,客观上限制了浏览器的用途和作用。要解决此问题,必须安全扩展浏览器的功能。扩充浏览器的功能,...

PC端和web端是一回事吗?
pc端和web端不是一回事。PC端是和移动终端相对应的名词,就是指网络世界里可以连接到电脑主机的那个端口,是基于电脑的界面体系,它有别于移动端的手机界面体系。PC端和Web端的区别:1、PC端是指基于计算机硬件设备的应用程序,需要在本地安装后才能使用。而Web端是指基于互联网的应用程序,用户只需要...

web端是什么意思?
相比于传统的本地应用程序,Web端的应用程序不需要在用户设备上安装,而是通过互联网直接提供服务。这使得Web端应用程序的更新和维护更加方便,用户可以享受到实时的功能更新和改进。Web端应用程序的性能和功能可能会受到网络连接质量和浏览器兼容性的影响。此外,一些高度复杂和计算密集的任务可能需要本地应用...

web端是什么意思
4、网络环境,App还有不同网络环境,2G、3G、4G、wifi、断网。5、App有横屏和竖屏之分、溢屏、触屏和手势。Web直接连接服务器,app的取值方式可能是服务器、接口或本地缓存。6、升级、更新,Web更新无提示,直接进入浏览器就是最新,app是需要自己进行更新才能获取最新数据。7、web登录需要密码,除非...

web端是指什么?
然后通过客户端与服务器进行交互。这种模式通常提供更丰富的功能和更好的用户体验,但需要在本地设备上安装额外的软件。总的来说,Web端就是通过浏览器访问互联网,提供网页形式的在线服务,而C\/S模式则涉及客户端应用与服务器之间的直接通信。两者都是现代网络服务的重要组成部分。

pc端和web端什么意思
PC端与Web端是两种不同的计算机访问方式,各有其特点和应用场景。PC端,即个人电脑端,是基于桌面设备的,提供丰富的本地计算能力和功能,适合处理复杂任务,如专业设计、软件开发和大数据分析。它的优点在于性能强大,但缺点是移动性和灵活性较差,用户需要固定在特定位置操作。Web端,又称互联网端,主要...

web端和客户端的区别
1、资源利用的区别:客户端产品可以充分利用硬件本地的资源和特点,能实现更多的效果,而网页版由于不能充分利用硬件本地化的资源,效果和交互逊于客户端版本(现在随着html5的应用,利用终端机来实现更好的效果和交互的梦想不遥远了)。2、配置要求的区别:客户端产品需要根据不同硬件、系统进行定制,而...

pc端和web端的区别
除了手指操作外还可以配合传感器完成摇一摇、陀悬仪感应灯操作方式,操作方式更加的丰富,通过这些丰富的操作可设计不同新颖吸引人的交互互动设计。2、设备不同:PC端基于计算机硬件设备的应用程序,需要在本地安装后才能使用。Web端基于互联网的应用程序,用户只需要通过浏览器访问即可使用。

相似回答
大家正在搜