HTML启动本地EXE的通用方法

HTML启动本地EXE的通用方法

  • 技术思路

    • 1、在注册表HKEY_CLASSES_ROOT下添加键值。
    • 2、通过调用注册表来启动一个用以启动其他应用的批处理。
    • 3、编写一个可以根据输入的应用程序路径参数,启动应用的批处理程序。
  • 实施示例

    • 修改注册表

      REG 复制代码
      	  Windows Registry Editor Version 5.00
      	  [HKEY_CLASSES_ROOT\LocalAppStarter]
      	  @="URL:LocalAppStarter"
      	  "URL Protocol"=""
      	  
      	  [HKEY_CLASSES_ROOT\LocalAppStarter\DefaultIcon]
      	  @="D:\\Chrome\\Application\\chrome.exe,1"
      	  
      	  [HKEY_CLASSES_ROOT\LocalAppStarter\shell]
      	  
      	  [HKEY_CLASSES_ROOT\LocalAppStarter\shell\open]
      	  
      	  [HKEY_CLASSES_ROOT\LocalAppStarter\shell\open\command]
      	  @="D:\\LocalAppStarter.bat %1"
    • 编写启动本地EXE的批处理脚步LocalAppStarter.bat

      BAT 复制代码
      	  @echo off
      	  echo "启动批处理" %1
      	  echo "路径" %2
      	  set exepath=%2
      	  
      	  setlocal enabledelayedexpansion
      	  #由于是通过URL传过来的参数,路径中的空格会被编码成%20
      	  #将路径中%替换为下划线
      	  set "exepath=!exepath:%%=_!"
      	  #将路径中的_20替换为空格
      	  set "exepath=!exepath:_20= !"
      	  #将路径中的//替换为/
      	  set "exepath=!exepath://=/!"
      	  #使用start 启动本地应用
      	  start "" "!exepath!"
      	  
      	  endlocal
      	  exit
    • 编码HTML启动本地应用

      HTML 复制代码
      	  <html>
      	    <head>
      	      <meta charset="UTF-8">
      	      <title>启动本地应用</title>
      	    </head>
      	    <body>
      	      <a href='LocalAppStarter://WeChat,D://Program Files (x86)//Tencent//WeChat//WeChat.exe'>WeChat</a>
      	      <a href='LocalAppStarter://QQ,D://Program Files (x86)//Tencent//QQ//QQ.exe'>QQ</a>
      	    </body>
      	  </html>  
  • 参考

相关推荐
无限大.5 小时前
前端知识速记:节流与防抖
前端
十八朵郁金香5 小时前
【VUE案例练习】前端vue2+element-ui,后端nodo+express实现‘‘文件上传/删除‘‘功能
前端·javascript·vue.js
学问小小谢5 小时前
第26节课:内容安全策略(CSP)—构建安全网页的防御盾
运维·服务器·前端·网络·学习·安全
LCG元6 小时前
Vue.js组件开发-实现全屏图片文字缩放切换特效
前端·javascript·vue.js
还是鼠鼠7 小时前
图书管理系统 Axios 源码__新增图书
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
还是鼠鼠10 小时前
图书管理系统 Axios 源码 __删除图书功能
前端·javascript·vscode·ajax·前端框架·node.js·bootstrap
轻口味10 小时前
Vue.js `Suspense` 和异步组件加载
前端·javascript·vue.js
m0_zj11 小时前
8.[前端开发-CSS]Day08-图形-字体-字体图标-元素定位
前端·css
还是鼠鼠12 小时前
图书管理系统 Axios 源码__编辑图书
前端·javascript·vscode·ajax·前端框架
北极象12 小时前
vue3中el-input无法获得焦点的问题
前端·javascript·vue.js