web网页调用本地客户端程序的方法

web网页调用本地客户端程序的方法,第1张

1.使用记事本(或其他文本编辑器)创建一个protocal.reg文件(.reg后缀的执行文件),并写入以下内容

Windows Registry Editor Version5.00[HKEY_CLASSES_ROOT\myWebshell]

@="URL:myWebshell Protocol Handler""URL Protocol"=""[HKEY_CLASSES_ROOT\myWebshell\DefaultIcon]

@="D:\\Program Files (x86)\\Tencent\\TIM\\Bin\\QQScLauncher.exe"[HKEY_CLASSES_ROOT\myWebshell\shell]

[HKEY_CLASSES_ROOT\myWebshell\shell\open]

[HKEY_CLASSES_ROOT\myWebshell\shell\open\command]

@="\"D:\\Program Files (x86)\\Tencent\\TIM\\Bin\\QQScLauncher.exe\" \"%1\""

2. 修改参数

使用记事本打开文件后,按照下图说明修改相关参数

2.1修改连接名称

修改红框内名称自定义即可,全部使用英文字符(该名称即为调用时的href),共六处

2.2修改可执行文件路径

修改红框内可执行文件路径,共两处,需注意: 文件路径中使用//分割

3. 执行protocal.reg文件

4. 创建调用连接

连接地址为 步骤1中所命名的链接名称,后面加://hello,(hello为传递参数,可任意添加)

5.查看效果

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邮箱快速登录使用的方式;

方案一成本较高,需要加多一层代理层,并且需要想办法生成一个唯一标识来标记当前浏览器;方案二没有唯一标识的问题,但需要提前对端口号进行约定,并且有可能出现端口号被占用的情况。最终基于成本和端口被占用的概率考虑,我选择了方案二,虽然不算完美,但也算是能够满足大多数用户的需求了。

这是浏览器考虑到用户安全,访问网页非法访问用户本地文件导致用户被“偷窥”的事情发生而做的限制。

但是个人做网页开发有时确实需要访问本地文件。首先彻底关系浏览器,注意仅仅关闭还不行,应该使用Command+Q彻底关闭,或者在docker中右击浏览器点击Force Quit。然后打开终端,输入一下命令打开浏览器Chrome: open -a “Google Chrome” --args --disable-web-security --user-data-dir。

在新打开的浏览器中,应该会有以下如图所示的提示(Chrome为例),证明已经成功禁用了web安全,此时再打开网页,发现就可以成功运行本地js了或者访问本地其他文件了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7788290.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存