- 不定期更新...
背景
许多本地应用(例如vscode、QQ),都支持通过浏览器来启动PC上的本地软件
这个功能够使网页端和客户端联动起来,用户体验还是很好的,实现起来也并不复杂。酷家乐客户端已经支持了这个功能,如下图:
从浏览器启动酷家乐
实现原理
浏览器在解析url的时候,会尝试从系统本地寻找url协议所关联的应用,如果有关联的应用,则尝试打开这个应用
例如VsCode从web端安装插件的时候,实际上是访问了一个vscode
协议的url,从而达到启动用户本地VsCode的目的
具体实现
现在,我们只需要将自定义的协议注册到用户电脑上,就可以实现功能了。用户浏览器里访问带有自定义协议的url,即可启动我们的客户端。
Windows
[Registry]
Root: HKCR; SubKey: Kujiale; ValueData: "KujialeProtocol"; ValueType: string; Flags: createvalueifdoesntexist uninsdeletekey;
Root: HKCR; SubKey: Kujiale; ValueName: "URL Protocol"; ValueData: "{app}\{#appExe}"; ValueType: string; Flags: createvalueifdoesntexist uninsdeletekey;
Root: HKCR; SubKey: Kujiale\DefaultIcon; ValueData: "{app}\{#appExe}"; ValueType: string; Flags: createvalueifdoesntexist uninsdeletekey;
Root: HKCR; SubKey: Kujiale\shell\open\command; ValueData: "{app}\{#appExe} ""%1"""; Flags: createvalueifdoesntexist uninsdeletekey; ValueType: string;
自定义协议注册成功后,注册表里是这样子的
注册协议成功
MacOS
在MacOS系统下面,我们就没有注册表可以写了,所以要换一个实现方法。在这之前,先介绍一些东西
info.plist
info.plistCFBundleURLTypes
修改info.plist文件
在了解了plist文件之后,我们现在只需为App包中info.plist,设置CFBundleURLTypes的值即可。那么如何修改呢,手写吗?nonono,这种事情当然要交给工具来做,不然太low了。
// for mac
options.protocols = [{
name: '钟离',
schemes: ['zhongli', 'test'], // 可以注册多个协议
}];
接收参数
协议注册完毕之后,我们已经可以在浏览器中,通过访问自定义协议url来启动客户端了。
对于url中的不同参数,客户端的行为也是不一样的,例如vscode:extension/ms-python.python
这个url,启动了VsCode的同时也告诉了VsCode:我要安装插件,插件名是ms-phthon.python。
Vscode通过解析url中的参数来实现自定义行为,那么作为客户端如何拿到这个url呢?
Windows
对于windows,参数会通过启动参数的形式传递给应用程序。因此,我们可以很方便的拿到这个参数
// 通过自定义url启动客户端时
console.log(process.argv);
// 打印出
[
'C://your-app.exe', // 启动路径
'kujiale://111', // 启动的自定义url
]
MacOS
// mac下通过kujiale协议启动应用
app.on('open-url', (e, url) => { // eslint-disable-line
parse(url); 解析url
});
最后
本文分了两部分来讲述如何从浏览器启动PC端的应用
-
注册自定义协议,对于所有应用程序都适用
-
接收参数,对使用Electron构建的应用适用