JS 打开本地应用软件

我们有遇到可以直接打开QQ的跳转链接,也有遇到过直接启动office打开文档。

具体是如何操作的呢?

添加注册表项

首先需要在注册表中添加应用软件的启动地址,操作方式如下

在HKEY_CLASSES_ROOT下,新建JiraUserQuestion及其子节点:

然后,在JiraUserQuestion中,添加URL Protocol = "C:\Program Files (x86)\JiraUserQuestion\JiraUserQuestion.exe"。

- 这里是定义Protocol,后续通过protocol的检测协议,能访问应用地本地路径

在下方节点,command项中添加默认项。可以通过传入参数,启动应用

Js添加访问应用链接

添加前端demo:

复制代码
 1 <!DOCTYPE html>
 2 <html>
 3 <head lang="en">
 4     <meta charset="UTF-8">
 5     <title>Custom Protocol Demo</title>
 6 </head>
 7 <body>
 8     <h1>Click:</h1>
 9     <a href="JiraUserQuestion://Open">Open JiraUserQuestion</a>
10     <script src="protocolcheck.js"></script>
11 </body>
12 </html>
复制代码

protocolcheck.js文件,即protocol协议js,可从网上直接下载。

下载后,将文件放在html文件同一级,方便引用。

点击链接,效果如下:

检测本地是否存在应用

上面的protocolcheck.js文件,已封装了对url判断、加载的逻辑。

如果存在应用,则打开应用;否则有相应的回调可以选择处理事务。

复制代码
1     <script>
2         //测试本地应用是否存在
3         let protocalUrl = `JiraUserQuestion://open`
4         protocolCheck(protocalUrl, () => {
5             alert('检测到,未安装客户端')
6         }, () => {
7             alert('检测到:已安装了客户端')
8         })
9     </script>
复制代码

 如果还想了解详细,可以下载我的Demo查看

 

参考列表:

StackOverFlow解决方案:  https://stackoverflow.com/questions/27489665/approaches-of-detection-of-custom-protocol-in-chrome-and-safari-browsers 

Custom Protocol Detection in Browser源码:   https://github.com/ismailhabib/custom-protocol-detection

Native-App-Protocal-Detection源码地址:https://github.com/evanxuhe/Native-App-Protocal-Detection

js检测客户端是否安装:htps://www.cnblogs.com/damonFeng/p/12095558.html

 

posted @   唐宋元明清2188  阅读(2960)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)
点击右上角即可分享
微信分享提示
剑桥
16:15发布
剑桥
16:15发布
7°
西南风
3级
空气质量
相对湿度
66%
今天
2°/10°
周三
2°/8°
周四
中雨
2°/7°