URLProtocol (url scheme)网页调用本地程序(Windows下浏览器全兼容)

用网页调用本地应用程序的思路是,先进行注册表注册自定义一个URL Protocol协议,再利用URL Protocol实现网页调用本地应用程序。

  1. 先写一个注册表文件,将其保存为.reg后缀的注册表执行文件:

Windows Registry Editor Version 5.00
[HKEY_CLASSES_ROOT\PWFileVersion]
"URL Protocol"="C:\\Program Files (x86)\\PWFileVersion\\FileVersion.exe"
@="FileVersionProtocol"
[HKEY_CLASSES_ROOT\PWFileVersion\DefaultIcon]
@="C:\\Program Files (x86)\\PWFileVersion\\FileVersion.exe,1"
[HKEY_CLASSES_ROOT\PWFileVersion\shell]
[HKEY_CLASSES_ROOT\PWFileVersion\shell\open]
[HKEY_CLASSES_ROOT\PWFileVersion\shell\open\command]
@="\"C:\\Program Files (x86)\\PWFileVersion\\FileVersion.exe\" \"%1\""

 

  1. 一行行来解释:
    Windows Registry Editor Version 5.00
    (1)表示注册表工具的版本信息;

    [HKEY_CLASSES_ROOT\PWFileVersion]
    (2)PWFileVersion表示的时注册表的HKEY_CLASSES_ROOT下新增一个PWFileVersion树(理解为在HKEY_CLASSES_ROOT下新增一个文件夹就可以了)

    "URL Protocol"="C:\Program Files (x86)\PWFileVersion\FileVersion.exe"
    (3)你在网页中要调用打开的程序绝对路径,记得一定要是exe文件

    @="FileVersionProtocol"
    (4)协议名称,可以是任意字符串,后面不会用到

    [HKEY_CLASSES_ROOT\PWFileVersion\DefaultIcon]
    (5)在PWFileVersion下新增一个分支,不用管

    @="C:\Program Files (x86)\PWFileVersion\FileVersion.exe,1"
    (6)地址和(3)中保持一致,1照抄

    [HKEY_CLASSES_ROOT\PWFileVersion\shell]
    [HKEY_CLASSES_ROOT\PWFileVersion\shell\open]
    [HKEY_CLASSES_ROOT\PWFileVersion\shell\open\command]
    (7)(8)(9)和(5)一样,新增分支而已

    @=""C:\Program Files (x86)\PWFileVersion\FileVersion.exe" "%1""
    (10)向要调用的程序内传递参数。前面的地址与(3)保持一致,后面的%1表示参数。敲黑板,这里面的/千万不要有所遗漏!本人在这个坑上蹲了很久- -;

  2. 运行reg文件,进行注册表注册。

    这时候在浏览器输入:

    pwfileversion://即可调用该程序

    pwfileversion://argument随便什么字符串,即可将参数传入该程序

  3. 细节

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\WebGoExe]
@="URL: WebGoExe Protocol Handler"
"URL Protocol"=""

[HKEY_CLASSES_ROOT\WebGoExe\DefaultIcon]
@="C:\\Program Files\\Losng\\WebGoExe.EXE"

[HKEY_CLASSES_ROOT\WebGoExe\Shell]

[HKEY_CLASSES_ROOT\WebGoExe\Shell\Open]

[HKEY_CLASSES_ROOT\WebGoExe\Shell\Open\Command]
@="C:\\Program Files\\Losng\\WebGoExe.EXE \"%1\""

在Windows下,按照网上找到的例子实现自己的Url Protocol,但是发现一直启动不了指定的Exe,浏览器一直提示未找到指定文件,通过测试发现这个Protocol起名字不能有"_",比如定义成My_Protocol就会启动不了,但是定义成MyProtocol就可以。 

4、在写链接的时候自定义参数,程序会把整个链接都获取到,自己在进行解析 :

比如:

<a href="myprotocol://123">

会获取到

"myprotocol://123"

5、代码实现方式

如果你电脑中装有QQ,在IE地址栏输入:“tencent://Message/?menu=yes&exe=&uin=13231462”然后[回车],
立即可以与我的QQ建立临时会话,Skype也有类似的功能。到底是如何实现的呢?看MSDN中有这么一段话: 
 The IURLSearchHook interface is used by the browser to translate the address of an unknown URL protocol.
 When attempting to browse to a URL address that does not contain a protocol, 
 the browser will first attempt to determine the correct protocol from the address. 
 If this is not successful, the browser will create URL Search Hook objects and call each object's
 Translate method until the address is translated or all of the hooks have been queried.   
 IURLSearchHook接口被浏览器用来转换一个未知的URL协议地址。
 当浏览器企图去打开一个未知协议的URL地址时,浏览器首先尝试从这个地址得到当前的协议,如果不成功,
 浏览器将创建在系统中注册的URL Search Hook对象并调用每一个对象的Translate方法,直到地址被转换或所有的URL Search Hook都尝试过。  
 也就是说,我们可以注册一种目前不存在的协议(类似HTTP),当浏览器遇到新的协议时会自动调用Translate方法来翻译我们的协议,
 甚至激活我们自己的程序。以下源代码将实现注册一个新的自定义的Web协议: 
  注册自定义的Web协议
//return : ------------------------------------------------------------------------//  
 0    -    失败//        1    -    成功//        2    -    已经存在//
int RegWebProtocol ( LPCTSTR lpszProtocolName, LPCTSTR lpszAssociatedApp, int nIconIndex/*=0*/ )
{    
	if ( !lpszProtocolName || lstrlen(lpszProtocolName) < 1 || !lpszAssociatedApp ||  lstrlen(lpszAssociatedApp) < 1 )          
		return 0;    
		
	CString csSubKey;   
	DWORD dwBufSize = 0;    
	// 该协议已经存在    
	HKEY hKey = NULL;    
	if ( RegOpenKeyEx ( HKEY_CLASSES_ROOT,  lpszProtocolName,   0, KEY_ALL_ACCESS,  &hKey ) == ERROR_SUCCESS )  
	{       
		return 2;   
	}   
	else 
		hKey = NULL; 
		
	// 创建协议子键    
	if ( !CreateRegisterSubKey ( HKEY_CLASSES_ROOT, lpszProtocolName ) )        
		return 0;   
	
	// 设置协议描述字符串    
	CString csProtocolDesc; 
	csProtocolDesc.Format ( _T("%sProtocol"), lpszProtocolName );    
	dwBufSize = csProtocolDesc.GetLength();    
	if (!WriteRegister ( HKEY_CLASSES_ROOT, lpszProtocolName, _T(""), REG_EXPAND_SZ, (PUCHAR)csProtocolDesc.GetBuffer(0),&dwBufSize) )        
		return 0;    
	CString csAppFile; 
	csAppFile.Format ( _T("%s"), lpszAssociatedApp );    
	dwBufSize = csAppFile.GetLength();    
	if ( !WriteRegister ( HKEY_CLASSES_ROOT, lpszProtocolName,  _T("URL Protocol"), REG_EXPAND_SZ, (PUCHAR)csAppFile.GetBuffer(0),&dwBufSize) )        
		return 0; 
		
	// DefaultIcon 子键    
	csSubKey.Format ( _T("%s\\DefaultIcon"), lpszProtocolName );    
	if ( !CreateRegisterSubKey ( HKEY_CLASSES_ROOT, csSubKey ) )        
		return 0;    
	CString csIconParameter; 
	csIconParameter.Format ( _T("%s,%d"), lpszAssociatedApp, nIconIndex );    
	dwBufSize = csIconParameter.GetLength();    
	if ( !WriteRegister ( HKEY_CLASSES_ROOT, csSubKey,  _T(""), REG_EXPAND_SZ, (PUCHAR)csIconParameter.GetBuffer(0),&dwBufSize) )        
		return 0; 
		
	// shell\open\command 子键    
	csSubKey.Format ( _T("%s\\shell\\open\\command"), lpszProtocolName );    
	if ( !CreateRegisterSubKey ( HKEY_CLASSES_ROOT, csSubKey ) )       
		return 0;    
	CString csCommand; csCommand.Format ( _T("\"%s\" \"%%1\""), lpszAssociatedApp );    
	dwBufSize = csCommand.GetLength();    
	if ( !WriteRegister ( HKEY_CLASSES_ROOT, csSubKey, _T(""), REG_EXPAND_SZ, (PUCHAR)csCommand.GetBuffer(0),&dwBufSize) )        
		return 0; 
		
	return 1;
}
	
 卸载自定义的Web协议//
BOOL UnRegWebProtocol ( LPCTSTR lpszProtocolName )
 {       
	if ( !lpszProtocolName || lstrlen(lpszProtocolName) < 1 )      
		return FALSE;    
	return RegDeleteAllSubKey ( HKEY_CLASSES_ROOT, lpszProtocolName );
}

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Chrome浏览器可以通过调用本地程序来实现一些特定的功能。通过Chrome的应用程序界面API(Application Programming Interface),开发者可以在Chrome中与本地程序进行交互。 首先,Chrome提供了一种称为Native Messaging的功能,允许Chrome与本地程序进行双向通信。通过Native Messaging,Chrome可以发送指令给本地程序,并接收来自本地程序的响应。 其次,Chrome还支持使用URL Scheme调用本地程序URL Scheme是一种定义在URL中的特殊协议,可以用于启动本地程序并传递参数。例如,通过在Chrome中输入"myapp://open?id=123"的URL,可以启动名为"myapp"的本地程序,并传递参数"id=123"给该程序。 除了Native Messaging和URL Scheme,Chrome还支持使用外部协议处理程序(External Protocol Handler)来调用本地程序。通过将某个协议(如"myprotocol")与本地程序关联,当Chrome中点击使用该协议的链接时,系统将自动启动对应的本地程序。 值得注意的是,为了保证用户的安和隐私,Chrome对调用本地程序的权限进行了限制。用户在使用Chrome时,需要授权给相应的网站或应用程序才能调用本地程序。 总而言之,Chrome可以通过调用本地程序来实现一些特定的功能,如与本地文件系统交互、实现浏览器与本地程序的协同等。通过合理使用Chrome的本地程序调用功能,我们可以获得更多的扩展和定制化的体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值