这篇文章主要介绍了Windows api关于注册表的操作经验和总结,本文讲解了读取注册表常用的函数以及一个注册表操作实例,需要的朋友可以参考下
读取注册表常用的函数
RegOpenKeyEx 用于打开一个键
RegSetValueEx 用于设置一个键的键值
RegQueryValueEx 用于读取一个键的值
RegCloseKey 用于关闭RegOpen打开的键
RegQueryValueEx通常连用两次来读取键值,第一次只读取键的大小,然后分配内存,然后再用一次RegQueryValueEx来读取键值到buffer。
下面是一个读取windows下的path键值的例子
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
HKEY hk;
int result = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
_T("SYSTEMControlSet001ControlSession ManagerEnvironment"),
NULL,
KEY_READ, &hk );
if(result != ERROR_SUCCESS)
{
if(result == ERROR_FILE_NOT_FOUND)
{
MessageBox(g.hwnd,_T("no such key in RegOpenKeyEx"),_T("title"),MB_ICONWARNING);
}
else
return;
}
DWORD lsize;
result = RegQueryValueEx(hk, _T("Path"),NULL,NULL,
NULL, &lsize);
if(result != ERROR_SUCCESS)
{
if(result == ERROR_FILE_NOT_FOUND)
{
MessageBox(g.hwnd,_T("no such key in RegQueryValue"),_T("title"),MB_ICONWARNING);
}
else if(result == ERROR_MORE_DATA)
{
MessageBox(g.hwnd,_T("need more buffer"),_T("title"),MB_ICONWARNING);
}
else
return;
}
TCHAR *value = (TCHAR * )malloc(lsize * sizeof(TCHAR));
result = RegQueryValueEx(hk, _T("Path"),NULL,NULL,
(LPBYTE)value, &lsize);
if(result != ERROR_SUCCESS)
{
if(result == ERROR_FILE_NOT_FOUND)
{
MessageBox(g.hwnd,_T("no such key in RegQueryValue"),_T("title"),MB_ICONWARNING);
}
else if(result == ERROR_MORE_DATA)
{
MessageBox(g.hwnd,_T("need more buffer"),_T("title"),MB_ICONWARNING);
}
else
return;
}
SetWindowText(g.hwndEdit,value);
free(value);
RegCloseKey(hk);
|
新手常见问题
RegSetValueEx运行时失败,返回代码为5,
解决方法:这种情况是由于对注册表访问权限不够,拒绝访问的意思,因此,注意看看权限是否不够,如果改为
KEY_ALL_ACCESS就没问题了,这样读写等权限都可以。