首先,

我们来查看注册表在运行里面输入:regedit打开注册表

c++获取注册表中程序的安装路径_ios

然后,我们就看到有几个主键

c++获取注册表中程序的安装路径_主键_02

接着,找到。我们今天要测试的注册的键,glireader,这是我自己的程序注册的键,你们可能没有,

c++获取注册表中程序的安装路径_ios_03

看到旁边的URL Protocol了吗,它里面的值就是这个程序的安装路径

c++获取注册表中程序的安装路径_主键_04

下面:我们就用代码来实现获取它的路径

// 读取注册表.cpp : 定义控制台应用程序的入口点。
//


#include "stdafx.h"
#include"windows.h"
#define SIZE 256
int _tmain(int argc, _TCHAR* argv[])
{


HKEY hKEY;
LPCTSTR data_Set = _T("glireader");//主键值
long ret0, ret1;//返回值
DWORD dataType;//数据类型
DWORD dataSize;//数据长度
char data[SIZE] = { 0 };


char biosVendor[SIZE];
memset(biosVendor, 0x41, SIZE); // 这里故意设置成A的,只是为了给大家提个醒。


ret0 = RegOpenKeyEx(HKEY_CLASSES_ROOT, data_Set, NULL, KEY_READ, &hKEY);//打开主键
if (ret0 != ERROR_SUCCESS) //如果无法打开hKEY,则中止程序的执行
{
printf("不能打开注册表 !!\n");
return 1;
}


ret1 = RegQueryValueEx(hKEY, _T("URL Protocol"), NULL, &dataType, (LPBYTE)data, &dataSize);//获取数据
if (ret1 != ERROR_SUCCESS) //如果无法打开hKEY,则中止程序的执行
{
printf("无法打开x !!\n");
return 1;
}


printf("Data 字节:%d\n", dataType);
printf("Data 长度:%d\n", dataSize);
printf("数据: "); // 为毛这里分每个字节来打印,而不是直接puts什么的。


// 因为键值数据每个字符中间都是0x00 = “/0”,so puts只能输出一个字符。我也是调试才看到的,还以为是API参数错误呢。
for (unsigned i = 0, j = 0; i < dataSize; i += 2, j++)
{
printf("%c", data[i]);
memcpy(biosVendor + j, data + i, 1);
}
printf("\n");


printf("路径信息: %s\n", biosVendor); // 你看明白我是怎么看主机BIOS固件厂商的了吧


RegCloseKey(hKEY); // 程序结束前要关闭已经打开的 hKEY。
system("pause");




return 0;
}




最后运行的结果:

c++获取注册表中程序的安装路径_主键_05