如何通过自定义协议在html中调起本地程序

由于业务需要,项目中同时存在B/S架构(web应用)和C/S架构(桌面应用)。

最近一次产品迭代中,我们通过自定义协议实现了在web端增加了一个可以调起桌面应用的入口,简单又便捷。

自定义协议

浏览器允许我们通过使用 protocol://url 的形式进行调用本地程序。

假如你电脑安装了迅雷,那你应该很熟悉这种体验,甚至你可以直接在url栏键入thunder://ed2k://magnet://来调起本地的迅雷程序

背后的原理是,软件在安装的同时修改了本机电脑的注册表,分别注册了以上协议来调起程序。因此我们也可以利用这个机制,通过修改本地注册表来按需添加自定义协议。

关于注册表

Windows注册表是Windows操作系统的核心数据库,它存储了系统和应用程序的所有配置信息。注册表的主要功能包括存储系统和软件的设置、记录安装的应用程序和硬件列表、控制用户账户和安全选项、设置系统选项和个性化功能、保存网络设置和配置。注册表采用树形结构组织数据,由主键、子键和值组成,其中主键位于最顶层,子键位于主键下,用于进一步分类,每个子键下的具体数据包括名称、类型和内容。

自定义协议主要是在注册表中的HKEY_CLASSES_ROOT根键下增加CLSID,并将它分配给对应程序作为系统内的连接。

注册表总共有5个根键分别对应系统内不同配置内容,自定义协议可按照以下方式实现。

其余配置在本内容中不涉及,其余部分配置较为敏感,可能影响计算机运行,建议备份后修改。

添加自定义协议:方法1

方法一:通过编写注册表脚本REG文件,双击后可将数据注入到注册表中。

新建记事本写好对应添加的配置项目,然后将文件后缀名改为.reg后双击运行。

js 复制代码
Windows Registry Editor Version 5.00  
  
[HKEY_CLASSES_ROOT\CallChrome]  
 
"URL Protocol"="C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe"
  
@="CallChrome"  
  
[HKEY_CLASSES_ROOT\CallChrome\DefaultIcon]  
  
@="C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe,1"  
  
[HKEY_CLASSES_ROOT\CallChrome\shell]  
  
[HKEY_CLASSES_ROOT\CallChrome\shell\open]  
  
[HKEY_CLASSES_ROOT\CallChrome\shell\open\command]  
  
@="\"C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe\" \"%1\""  

简单介绍下脚本内容:第 3,9,13,15,17 行是对注册表的树状节点进行修改,增加自定义协议CallChrome节点和该节点下的必要节点,第 5,7 行是对协议的描述,内容似乎对结果影响不大,第 11, 19 行是对应程序的目录地址,其中%1表示传参,可以支持CallChrome://hello方式传参。

添加自定义协议:方法2

方法二:通过修改注册表编辑器增加自定义协议,具体步骤和注册脚本内容一致。

custom-protocol-check

自定义协议是否可用是根据浏览器的宿主环境决定的,但是各家浏览器并未提供统一的方法让我们去判断。

github上有个500+stars的工具库帮我们统一了协议可用的判断方法: github: custom-protocol-detection

同时也有基于该库维护的npm包: npm:custom-protocol-check

虽然github项目上声明已停止维护,但是经测试最新chrome、edge、firefox均可用。

相关推荐
IT_陈寒3 小时前
SpringBoot这个自动配置坑我跳了三次
前端·人工智能·后端
kyriewen3 小时前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher3 小时前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式
默_笙3 小时前
🃏 JS 只有 8 种数据类型,但我花了 2 天才搞懂 null 和 undefined 的区别
javascript
牧艺3 小时前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
jump_jump4 小时前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
红尘散仙4 小时前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
袋鼠云数栈UED团队5 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端5 小时前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream5 小时前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端