WEB中调用应用程序(.exe)的方法

目的:实现在浏览器中实现一个url自动启动软件,并执行操作。

   

   

   

要实现这个功能,需要自定义url protocol handler。

   

1.建立注册表。

新建gim.reg文件。写入如下代码:

   

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\GIM]

@="GIMProtocol"

"URL Protocol"="C:\\Users\\kang\\Desktop\\im2_0.6beta\\GIM.exe"

[HKEY_CLASSES_ROOT\GIM\DefaultIcon]

@="C:\\Users\\kang\\Desktop\\im2_0.6beta\\GIM.exe"

[HKEY_CLASSES_ROOT\GIM\shell]

[HKEY_CLASSES_ROOT\GIM\shell\open]

[HKEY_CLASSES_ROOT\GIM\shell\open\command]

@="C:\\Users\\kang\\Desktop\\im2_0.6beta\\GIM.exe"

   

注:1,上面的路径全部是.exe的路径;2,在windows下必须用\,不能用/

   

然后双击运行即可。会在注册表中生成如下结构的注册表:

   

   

   

2.在web中调用。

只需如下代码即可:

   

<a href="GIM://">

   

其中GIM为注册的名字,即[HKEY_CLASSES_ROOT\GIM]。

如果需要传递参数,则在后面添加参数即可,格式如下:

   

<a href="GIM://paramName1:value1&paramName2:value2">

   

当然在写注册表时,也需要指明需要参数。这里虽然传递多个参数,但程序只接收一个字符串,然后再解析各个参数。

   

   

   

参考:

自定义URL Protocol 协议

一些应用软件可以在浏览器中点击一个url后自动启动,并执行操作。这是咋实现的呢?

我在 google了许多也找个博客说明。接照这些文档我也新手试了一下。

通过网站调用可执行程序,主要是修改注册表,注册 URL Protocol 协议。

第一步:按照如下图所示建立注册表

其中 在注册表的 [HKEY_CLASSES_ROOT] 主键下 建立[qiaoker]建。

[qiaoker] 此键可以自定义任意。

第二步:注册表中建立相关键值对。

   

   

注意到上面 command 项的值为 C:\Program Files (x86)\Qiaoker\updater.exe "%1" ,这个"%1"是传递给 updater.exe的参数。

使用时我们会在后面讲到如何使。

   

第三步:编写测试页面

<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

  <head>

      <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  </head>

    <body>

        <div>

            <a href="qiaoker://cid:110&username:xxh">

            执行可执行文件

            </a>

        </div>

    </body>

</html>

说明:QiaokerProtocol: 是注册表中注册的协议名称。

   cid:110&username:xxh 是传入可执行程序的参数。

   程序收到参数据自已去解析字符串中的相关信息。

其它说明:

 我是用 Inno Setup IDE 生成的注册表, 在程序安装时写入注册表,卸载时删除相关注册表信息。

 Inno Setup 写入注册表的代码如下:

 [Registry]

Root: HKCR; SubKey: QiaokerProtocol; ValueData: "Qiaoker Protocol"; ValueType: string; Flags: CreateValueIfDoesntExist UninsDeleteKey;

Root: HKCR; SubKey: QiaokerProtocol; ValueName: "URL Qiaoker Protocol"; Flags: CreateValueIfDoesntExist; ValueType: string;

Root: HKCR; SubKey: QiaokerProtocol\DefaultIcon; ValueData: E:\Client1VNSkia2\bin\debug\updater.exe; Flags: CreateValueIfDoesntExist; ValueType: string;

Root: HKCR; SubKey: QiaokerProtocol\shell\open\command; ValueData: "E:\Client1VNSkia2\bin\debug\updater.exe ""%1"""; Flags: CreateValueIfDoesntExist; ValueType: string;

   

来自 <http://blog.csdn.net/chinahaerbin/article/details/8783024>

   

   

REG基本语法:

   

   

Reg文件内容的基本语法格式如下:

RegistryEditorVersion

空行

[RegistryPath1]

"DataItemName1"="DataType1:DataValue1"

"DataItemName2"="DataType2:DataValue2"

空行

[RegistryPath2]

"DataItemName3"="DataType3:DataValue3"

空行

[RegistryPath3]

"DataItemName4"="DataType4:DataValue4"

   

  • RegistryEditorVersion为Windows注册表编辑器的版本号。在Windows 2000、Windows XP、Windows Server 2003、Windows Vista、Windows 7中,其值为"Windows Registry Editor Version 5.00"。我的系统为Windows 7 Service Pack 1(64位),其值为"Windows Registry Editor Version 5.00"。在Windows 98和Windows NT 4.0中,其值为"REGEDIT4"。Windows 2000、Windows XP和Windows Server 2003可能还兼容"REGEDIT4"。
  • 空行用于分隔多个键路径,每个键路径下可以有多个子键和值项。
  • RegistryPath就是键路径,包含在方括号中,并以反斜杠分隔每个层次结构,例如:

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6]

REG支持递归创建新的键(子键),只要在RegistryPath中加入想创建的键(子键)即可。例如使用如下语句在TCPIP6下创建子键try,并在try下创建子键abc。

Windows Registry Editor Version 5.00

   

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try\abc]

注册表由键(或称"项")、子键(或称"子项")和值项构成。我们来看一下注册表编辑器,浏览至上述键路径所指示的位置:

  • 左侧展开的层次结构就是键路径,可以理解为目录,一个键就是分支中的一个目录,而子键就是这个目录中的子目录。子键同样是一个键,因为子目录下还可以有子目录。下图中的"TCPIP6"和"Linkage"就是键(子键)。
  • 右侧的"名称-类型-数据"就是值项,可以理解为文件,一个键(子键)可以有一个或多个值项,其名称各不相同,如果一个值项的名称为空,则该值项为该键的默认值项。下图中的"DependOnService"就是值项的名称,"REG_MULTI_SZ"是值类型,其值为"Tcpip"。

   

  • DataItemName是值项的名称。如果该值项在注册表中不存在,则创建;如果存在,则覆盖其值。注意,值项的名称要用双引号引起来。
  • DataType、DataValue是值项的值,其中DataType为值类型,DataValue为具体值,DataType和DataItemName之间用"="连接。REG_SZ类型的值需要标明DataType值类型,只需要用双引号引起来,例如"DataItemName1"="Microsoft IPv6 Protocol Driver";其他类型不需要用双引号引起来,但需要添加值类型,值类型和具体值之间用冒号分隔,例如"DataItemName2"=hex(2):73,00,79,00,73,00,74,00,"DataItemName3"=hex(7):5c,00,44,00,65,00,76,00,"DataItemName4"=dword:00000006。

   

如果 不指定dataitemname,即使用

(默认)的话,用@代替dataitemname即可。如@="c:\\xx.exe"

注册表的数据类型主要有以下五种:

显示类型

(在编辑器中)

数据类型

说明

REG_BINARY

二进制数

二进制值,以十六进制显示

REG_DWORD

双字

一个32位的二进制值,显示为8位的十六进制值,也可显示为10位十进制值

REG_SZ

字符串

文本字符串

REG_EXPAND_SZ

可扩充字符串

  

REG_MULTI_SZ

多字符串

含有多个文本值的字符串

此外,注册表还有其他的数据类型,但是均不常用:

REG_DWORD_BIG_ENDIAN

REG_DWORD_LITTLE_ENDIAN

REG_FULL_RESOURCE_DESCRIPTOR

REG_QWORD

REG_FILE_NAME

3.2 删除操作语法

如果要删除一个键(子键),只需要在RegistryPath头部添加字符"-"即可。例如使用如下语句删除上文中创建的子键try和abc,REG是支持递归删除的。

Windows Registry Editor Version 5.00

   

[-HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try]

如果要删除一个值项,只需要在DataItemName后面的等号后添加字符"-" 即可。例如先使用下面第一段语句创建一个值项"valueItem",然后用第二段语句删除该值项。

Windows Registry Editor Version 5.00

   

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try\abc]

"valueItem"="my value"

   

Windows Registry Editor Version 5.00

   

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try\abc]

"valueItem"=-

3.3 重命名操作语法

若要重命名键(子键)或值项,请先将其删除,然后使用新的名称创建一个新的键(子键)或值项。

4. 编辑REG文件

文章一开始已经创建了一个空的REG文件,为了使其发挥作用,还需要编辑其内容。我们右键该文件,选择"编辑"或选择"打开方式->记事本",即可打开REG文件。接着输入内容并保存就OK了。

   

现在以一个例子说明REG文件的使用方法。便如如下内容,保存后运行该REG文件,即可获得下图所示的结果。

Windows Registry Editor Version 5.00

   

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try\abc]

"valueItem1"="my value"

"valueItem2"=dword:00000014

   

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\TCPIP6\try]

"valueItem3"=hex(7):5c,00,44,00,65,00,76,00

   

   

5. 补充知识

注册表有五个分支,下面是这五个分支的名称及作用:

名称

作用

HKEY_CLASSES_ROOT

存储Windows可识别的文档类型的详细列表,以及相关联的程序

HKEY_CURRENT_USER

存储当前用户设置的信息

HKEY_LOCAL_MACHINE

包括安装在计算机上的硬件和软件的信息

HKEY_USERS

包含使用计算机的用户的信息

HKEY_CURRENT_CONFIG

这个分支包含计算机当前的硬件配置信息

   

   

来自 <http://www.cnblogs.com/fczjuever/archive/2013/04/09/3010711.html>

   

   

   

   

posted @ 2014-02-08 14:21  小指  阅读(2872)  评论(0编辑  收藏  举报