这篇文章主要介绍了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就没问题了,这样读写等权限都可以。