第一:通过winecec()函数,但是有取得注册表的键值
第二:通过shellexec()他很简单 就是一句话
ShellExecute(NULL,"open","f:\\11.htm",NULL,NULL,SW_SHOW);
把第一种的代码
// HKEY hKetRoot,hkeySub;
// charValueName[MAX_PATH];
// unsigned charDataValue[MAX_PATH];
// unsigned longcbValueName=MAX_PATH;
// unsigned longcbDataValue=MAX_PATH;
// char IE[MAX_PATH];
// DWORD dwType;
// if(RegOpenKey(HKEY_CLASSES_ROOT,NULL,&hKetRoot)==ERROR_SUCCESS)//hKetRoot接受打开键值得HANDLE
// {
// if(RegOpenKeyEx(hKetRoot,"htmlfile\\shell\\open\\command",0,KEY_ALL_ACCESS,&hkeySub)==ERROR_SUCCESS)
// { //列举了指定打开得注册表得值
// RegEnumValue(hkeySub,0,ValueName,&cbValueName,NULL,&dwType,DataValue,&cbDataValue);
// strcpy(IE,(char *)DataValue);
// strcat(IE,"F:\\11.htm");
// //q启动浏览器
// WinExec(IE,SW_SHOW);
//
// }
// else
// MessageBox("浏览器打开失败","信息提示",MB_OK);
//
// }
// else
// MessageBox("浏览器打开失败","信息提示",MB_OK);
// RegCloseKey(hKetRoot);
// RegCloseKey(hkeySub);
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
RegOpenKeyEx
RegOpenKeyEx()
函数功能描述:打开一个制定的注册表键 函数原型: LONG RegOpenKeyEx( ); 参数: |
RegEnumValue |
VB声明 | |
Declare Function RegEnumValue Lib"advapi32.dll" Alias "RegEnumValueA" (ByVal hKey As Long, ByValdwIndex As Long, ByVal lpValueName As String, lpcbValueName AsLong, lpReserved As Long, lpType As Long, lpData As Byte, lpcbDataAs Long) As Long | |
说明 | |
枚举指定项的值 | |
返回值 | |
Long,零(ERROR_SUCCESS)表示成功。其他任何值都代表一个错误代码 | |
参数表 | |
参数 | 类型及说明 |
hKey | Long,一个已打开项的句柄,或者指定一个标准项名 |
dwIndex | Long,欲获取值的索引。注意第一个值的索引编号为零 |
lpValueName | String,用于装载位于指定索引处值名的一个缓冲区 |
lpcbValueName | Long,用于装载lpValueName缓冲区长度的一个变量。一旦返回,它会设为实际载入缓冲区的字符数量 |
lpReserved | Long,未用;设为零 |
lpType | Long,用于装载值的类型代码的变量 |
lpData | Byte,用于装载值数据的一个缓冲区 |
lpcbData | Long,用于装载lpData缓冲区长度的一个变量。一旦返回,它会设为实际载入缓冲区的字符数量 |
|