js通过游览器启动本地的绿色软件

需求:开发一个页面,页面的导航栏需要启动本地下载好的绿色软件

问题1: 如何调用本地软件?

答:这个很简单只需要调用window.location.href = "应用名称://"即可,有同学就会问了这个应用名称是什么?应用名称为应用安装时在注册表里面注册的名称,以微信为例,看下图:

启动本地的微信,调用window.location.href = "weixin://"就可以了,也可直接在游览器地址栏输入weixin://进行调用

问题2:绿色软件无需进行安装,注册表里面没有对应注册的名称,怎么办?

答:从上一个问题中,我们可以看出来,本地的软件的调用,是游览器通过注册表中的名称进行调用的。所以最简单的方式就是在注册表中添加一个对应应用的名称和地址。可考虑到我们这边是可以调用多个绿色软件的,并减少客户使用的难度,我给他自定义了一个操作程序,看下图:

js 复制代码
Windows Registry Editor Version 5.00
 
[HKEY_CLASSES_ROOT\NSRTool]
@="NSRTool Protocol"
"URL Protocol"= ""
 
[HKEY_CLASSES_ROOT\NSRTool\DefaultIcon]
@="E:\\arptools-smg_R2.03_20240530_prj\\bin\\NSRTools.exe"

[HKEY_CLASSES_ROOT\NSRTool\shell\open\command]
@="E:\\arptools-smg_R2.03_20240530_prj\\bin\\NSRTools.exe"

[HKEY_CLASSES_ROOT\NARIConfiguration]
@="NARIConfiguration Protocol"
"URL Protocol"= ""
 
[HKEY_CLASSES_ROOT\NARIConfiguration\DefaultIcon]
@="E:\\NARIConfigTool_V1.47\\NARI Configuration Tool.exe"
 
[HKEY_CLASSES_ROOT\NARIConfiguration\shell\open\command]
@="\"E:\\NARIConfigTool_V1.47\\NARI Configuration Tool.exe\""

建一个后缀为reg的文件,按照要求输入以上内容,多个应用则依次追加。 保存成功后,双击运行即可。也可去注册表中查看相应应用名称是否注册成功。

OK,以上就是绿色软件正常的调用。大家是不是觉得就没有问题了,可我这边还发现了一个很头疼的问题,希望大家没有遇到,看问题3

问题3:游览器调用的软件,出现中文乱码,怎么办?

答:刚开始我们都以为是软件的兼容问题,然后下载了最新版本的,还是不行。然后找各种资料,有的说是电脑的编码问题,有的说游览器编码问题,我就不具体说了,网上都有。反正我都试了都不行,而且操作流程比较复杂,不符合客户需求。后来我发现通过应用程序打开和cmd进行打开都没有问题,我就想能不能通过cmd来进行应用程序的调用,然后我就将调用cmd启动程序代码放到了注册表里面了,解决方式如下:

js 复制代码
Windows Registry Editor Version 5.00
 
[HKEY_CLASSES_ROOT\NSRTool]
@="NSRTool Protocol"
"URL Protocol"= ""
 
[HKEY_CLASSES_ROOT\NSRTool\DefaultIcon]
@="E:\\arptools-smg_R2.03_20240530_prj\\bin\\NSRTools.exe"

[HKEY_CLASSES_ROOT\NSRTool\shell\open\command]
@="cmd /c \"cd /d E:\\arptools-smg_R2.03_20240530_prj\\bin\\ && start \"\" NSRTools.exe\""

OK,以上就是我本地调用绿色软件的遇到的一些问题。大家可以参考以下

相关推荐
MyhEhud1 分钟前
Kotlin 中 let 方法的作用和使用场景
前端·javascript·kotlin
LTPP2 分钟前
Hyperlane:轻量、高效、安全的 Rust Web 框架新选择
前端·后端·github
战场小包9 分钟前
Vite 配置文件解析全流程|源码解读
前端·vite
IT、木易11 分钟前
大白话解释 React 中高阶组件(HOC)的概念和应用场景,并实现一个简单的 HOC。
前端·javascript·react.js
骆驼Lara14 分钟前
Vue3.5 企业级管理系统实战(九):菜单组件
前端·vue.js
October_CanYang15 分钟前
uni-app+vue3+js+vite解决跨域后报错TypeError: Failed to fetch dynamically imported modul
前端·vue.js·vite
勘察加熊人1 小时前
fastapi+angular外卖系统
前端·fastapi·angular.js
一 乐1 小时前
农业电商|基于SprinBoot+vue的农业电商服务系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·农业电商
mysusheng1 小时前
Chrome 浏览器的很多扩展不能用了
前端·chrome
yeyuningzi1 小时前
关于软航OFFICE文档控件软件在Chrome 133版本上提示扩展已停用的原因及处理办法
前端·扩展程序·manifest v3·ntko office控件·manifest v2·chrome 扩展机制变化