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

相关推荐
喝拿铁写前端8 分钟前
Vue 组件通信的两种世界观:`.sync` 与普通 `props` 到底有什么不同?
前端·vue.js·前端框架
美酒没故事°24 分钟前
npm源管理器:nrm
前端·npm·npm源
用户221520442780025 分钟前
vue3组件间的通讯方式
前端·vue.js
三十_A42 分钟前
【实录】使用 patch-package 修复第三方 npm 包中的 Bug
前端·npm·bug
下位子1 小时前
『AI 编程』用 Claude Code 从零到一开发全栈减脂追踪应用
前端·ai编程·claude
tyro曹仓舒1 小时前
Vue单文件组件到底需不需要写name
前端·vue.js
用户47949283569151 小时前
面试官:讲讲2FA 双因素认证原理
前端·后端·安全
乐影1 小时前
TS 模板字符串类型:从基础到进阶的类型编程魔法
前端·typescript
龙在天1 小时前
CSS 属性值的计算与过程
前端
云鹤_1 小时前
【Amis源码阅读】组件注册方法远比预想的多!
前端·低代码