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>  
  • 参考

相关推荐
多看书少吃饭6 分钟前
从Vue到Nuxt.js
前端·javascript·vue.js
前端一小卒17 分钟前
从 v5 到 v6:这次 Ant Design 升级真的香
前端·javascript
前端不太难1 小时前
《Vue 项目路由 + Layout 的最佳实践》
前端·javascript·vue.js
LYFlied1 小时前
【每日算法】 LeetCode 56. 合并区间
前端·算法·leetcode·面试·职场和发展
想学后端的前端工程师2 小时前
【Vue3组合式API实战指南:告别Options API的烦恼】
前端·javascript·vue.js
否子戈2 小时前
WebCut前端视频编辑UI框架一周开源进度
前端·音视频开发·ui kit
昔人'2 小时前
`corepack` 安装pnpm
前端·pnpm·node·corepack
萌萌哒草头将军2 小时前
pnpm + monorepo 才是 AI 协同开发的最佳方案!🚀🚀🚀
前端·react.js·ai编程
hboot3 小时前
💪别再迷茫!一份让你彻底掌控 TypeScript 类型系统的终极指南
前端·typescript
GISer_Jing3 小时前
深入拆解Taro框架多端适配原理
前端·javascript·taro