Reg注册表读写

在Windows 95及其后继版本中,采用了一种叫做“注册表”的数据库来统一进行管理,将各种信息资源集中起来并存储各种配置信息。按照这一原则,Windows各版本中都采用了将应用程序和计算机系统全部配置信息容纳在一起的注册表,用来管理应用程序和文件的关联、硬件设备说明、状态属性以及各种状态信息和数据等。

我们可以通过win+R,输入regedit  查看注册表编辑器。

创建注册表 

RegCreateKeyW( )函数 

LSTATUS RegCreateKeyW(
  [in]           HKEY    hKey,
  [in, optional] LPCWSTR lpSubKey,
  [out]          PHKEY   phkResult
);
  • 参数hKey

打开的注册表句柄, 或是以下预定义键之一。

  • HKEY_CLASSES_ROOT
  • HKEY_CURRENT_CONFIG
  • HKEY_CURRENT_USER
  • HKEY_LOCAL_MACHINE
  • HKEY_USERS
  • 参数lpSubKey

要创建表项的名称,必须是hKey参数标识的子项(子目录下)。

  • 参数phkResult

接收或打开表项的句柄 

 例如:

HKEY hKey;
RegCreateKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Xioaming\\admin", &hKey);

SOFTWATEHKEY_LOCAL_MACHINE下的子项目

 

 

打开注册表 

RegOpenKey( )函数

LSTATUS RegOpenKeyW(
  [in]           HKEY    hKey,
  [in, optional] LPCWSTR lpSubKey,
  [out]          PHKEY   phkResult
);
  • 参数hKey 

打开的注册表项的句柄。此句柄由RegCreateKeyExRegOpenKeyExR函数返回,也可以是以下预定义键之一:

  • HKEY_CLASSES_ROOT
  • HKEY_CURRENT_CONFIG
  • HKEY_CURRENT_USER
  • HKEY_LOCAL_MACHINE
  • HKEY_USERS
  • 参数lpSubKey

 要打开的注册表项的名称。此键必须是hKey参数的子项(或者说子目录下)。参数值不区分大小写。如果此参数为NULL或指向空字符串的指针,则该函数返回传入的相同句柄。

  • 参数phkResult

该变量接收打开的注册文件句柄的句柄。 

例如:

HKEY hKey;
RegOpenKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Xioaming\\admin", &hKey);

SOFTWAREHKEY_LOCAL_MACHINE的子项目 

 

写注册表 

 RegSetValueEx( )函数

LSTATUS RegSetValueExW(
  [in]           HKEY       hKey,
  [in, optional] LPCWSTR    lpValueName,
                 DWORD      Reserved,
  [in]           DWORD      dwType,
  [in]           const BYTE *lpData,
  [in]           DWORD      cbData
);
  • 参数hKey

表示打开的注册表项的句柄。 或者是以下预定义键之一。

  • HKEY_CLASSES_ROOT
  • HKEY_CURRENT_CONFIG
  • HKEY_CURRENT_USER
  • HKEY_LOCAL_MACHINE
  • HKEY_USERS
  •  参数lpValueName

要设置的键的名称。如果设置为NULL或空字符串 “”,则该函数将设置键为未命名值或默认值的类型和数据。

  • 参数Reserved

此参数是保留的,必须为零。

  • 参数dwTyle

表示lpData指向的数据类型。有如下的值可选

取值含义
REG_BINARY任何形式的二进制数据。
REG_DWORD32 位数字。
REG_DWORD_LITTLE_ENDIAN小端格式的 32 位数字。Windows被设计为在小端计算机体系结构上运行。因此,此值在 Windows 头文件中定义为REG_DWORD。
REG_DWORD_BIG_ENDIAN大端格式的 32 位数字。一些 UNIX 系统支持大端架构。
REG_EXPAND_SZ一个以 null 结尾的字符串,其中包含对环境变量的未展开引用(例如,“%PATH%”)。它将是一个 Unicode 或 ANSI 字符串,具体取决于您使用的是 Unicode 还是 ANSI 函数。若要展开环境变量引用,请使用ExpandEnvironmentString函数。
REG_LINK一个以 null 结尾的 Unicode 字符串,其中包含通过使用 REG_OPTION_CREATE_LINK 调用RegCreateKeyEx函数创建的符号链接的目标路径。
REG_MULTI_SZ以空字符串 (\0) 结尾的以 null 结尾的字符串序列。下面是一个示例:字符串 1\0 字符串 2\0 字符串 3\0 最后一个字符串\0\0 第一个 \0 终止第一个字符串,第二个到最后一个 \0 终止最后一个字符串最后一个 \0 终止序列。请注意,最终终止符必须计入字符串的长度。
REG_NONE没有定义的值类型。
REG_QWORD64 位数字。
REG_QWORD_LITTLE_ENDIAN小端格式的 64 位数字。Windows被设计为在小端计算机体系结构上运行。因此,此值定义为 Windows 头文件中的REG_QWORD。
REG_SZ以 null 结尾的字符串。这将是 Unicode 或 ANSI 字符串,具体取决于您使用的是 Unicode 还是 ANSI 函数。
  • 参数lpData

表示要指向存储的数据的指针,当设置为空的时候,cbData必须为'0'

  • 参数cbData

表示lpData参数指向的信息的大小(字节为单位),如果lpData存储的是字符串类型的,则cbData的值必须是包含终止符的大小。

例如:

DWORD dwAge=20;
RegSetValueEx(hKey, L"age", 0, REG_DWORD, (CONST BYTE*)&dwAge, sizeof(DWORD);

hKey是上面创建注册表返回的句柄。

读注册表 

 RegQueryValueEx( )函数

LSTATUS RegQueryValueExW(
  [in]                HKEY    hKey,
  [in, optional]      LPCWSTR lpValueName,
                      LPDWORD lpReserved,
  [out, optional]     LPDWORD lpType,
  [out, optional]     LPBYTE  lpData,
  [in, out, optional] LPDWORD lpcbData
);
  • 参数hKey

表示打开注册表的句柄,或者是以下预定义键之一

  • HKEY_CLASSES_ROOT
  • HKEY_CURRENT_CONFIG
  • HKEY_CURRENT_USER
  • HKEY_LOCAL_MACHINE
  • HKEY_PERFORMANCE_DATA
  • HKEY_PERFORMANCE_NLSTEXT
  • HKEY_PERFORMANCE_TEXT
  • HKEY_USERS
  • 参数lpValueName

表示键的名称。如果设置为NULL或空字符串 “”,则该函数将检索键为未命名值或默认值(如果有)的类型和数据。如果指定的键不在注册表,则返回 ERROR_FILE_NOT_FOUND。

  • 参数lpReserved

此参数是保留的,必须为NULL。

  • 参数lpType

指向一个变量的指针,该变量接收要读取的数据类型的代码。若不需要可设为NULL

  • 参数lpData

指向接收数据的缓冲区的指针。如果不需要数据,则可设置为NULL

  • 参数lpcbData

表示指向缓冲区大小的指针(以字节为单位),如果数据是字符串类型的,需包含终止符。

DWORD dwType;
DWORD dwAge;
DWORD dwValue;

RegQueryValueEx(hKey, L"age", 0, &dwType, (LPBYTE) & dwAge, &dwValu);

关闭注册表

 RegCloseKey( )函数

LSTATUS RegCloseKey(
  [in] HKEY hKey
);
  • 参数hKey

 要关闭的注册表句柄

  •  返回值

如果函数成功,则返回值为 ERROR_SUCCESS

如果函数失败,则返回值是在 Winerror.h 中定义的非零错误代码。

Demo

 写注册表:
下面程序中会先创建一个注册表,之后再写入内容

void CMyFileCFileView::OnWriteReg() {
	HKEY hKey;
	DWORD dwAge = 22;
	//创建注册表项
	int ret = ::RegCreateKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Xioaming\\admin", &hKey);
	if (ret != 0) {
		TRACE("#RegCreateKeyW Failed,ErrorCode = %d,ret = %d", GetLastError(), ret);
		MessageBox(L"创建注册表失败");
		return;
	}
	
	//写注册表
	ret = ::RegSetValueEx(hKey, L"age", 0, REG_DWORD, (CONST BYTE*)&dwAge, sizeof(DWORD));
	if (ret != 0) {
		TRACE("#RegSetValueEx Failed,ErrorCode = %d,ret = %d", GetLastError(), ret);
		MessageBox(L"写注册表失败");
		return;
	}
	
	//关闭注册表
	::RegCloseKey(hKey);
}

读注册表:

下面程序中会打开写入时创建的注册表,并读取写入的内容

void CMyFileCFileView::OnReadReg() {
	//RegQueryValue()	//读注册表
	HKEY hKey;
	
	//创建注册表项
	int ret = ::RegOpenKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Xioaming\\admin", &hKey);
	if (ret != 0) {
		TRACE("#RegOpenKeyW Failed,ErrorCode = %d,ret = %d", GetLastError(), ret);
		MessageBox(L"打开注册表失败");
		return;
	}

	//查询注册表
	DWORD dwType;
	DWORD dwValue;
	DWORD dwAge;
	ret = ::RegQueryValueEx(hKey, L"age", 0, &dwType, (LPBYTE) & dwAge, &dwValue);
	if (ret != 0) {
		TRACE("#RegQueryValueEx Failed,ErrorCode = %d,ret = %d", GetLastError(), ret);
		MessageBox(L"读注册表失败");
		return;
	}
	TRACE("#dwType = %d,dwValue = %d,dwAge = %d", dwType, dwValue, dwAge);
	//关闭注册表
	::RegCloseKey(hKey);
}

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用微软提供的CReg类可以方便地读写注册表,具体用法如下: ```cpp #include <creg.hxx> // 读取注册表 CRegKey reg; if (reg.Open(HKEY_LOCAL_MACHINE, _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion"), KEY_READ) == ERROR_SUCCESS) { DWORD dwType = REG_SZ; TCHAR szValue[1024] = { 0 }; ULONG ulCount = 1024; if (reg.QueryStringValue(_T("ProgramFilesDir"), szValue, &ulCount) == ERROR_SUCCESS) { // 读取成功 // szValue中存储了ProgramFilesDir的值 } reg.Close(); } // 注册表 CRegKey reg; if (reg.Create(HKEY_LOCAL_MACHINE, _T("SOFTWARE\\MyCompany\\MyApp")) == ERROR_SUCCESS) { if (reg.SetStringValue(_T("MyValue"), _T("Hello, World!")) == ERROR_SUCCESS) { // 入成功 } reg.Close(); } ``` 另外,在VB中,可以使用自身的SaveSetting、GetSetting函数读写注册表,也可以使用API函数来实现注册表任意读写。具体用法可以参考以下代码: ```vb ' 读取注册表 Dim hKey As Long Dim dwType As Long Dim dwSize As Long Dim sValue As String hKey = OpenKey(HKEY_LOCAL_MACHINE, "SOFTWARE\Microsoft\Windows\CurrentVersion", KEY_READ) If hKey <> 0 Then dwType = REG_SZ sValue = String$(1024, 0) dwSize = Len(sValue) If QueryValueEx(hKey, "ProgramFilesDir", 0, dwType, ByVal sValue, dwSize) = ERROR_SUCCESS Then ' 读取成功 ' sValue中存储了ProgramFilesDir的值 End If RegCloseKey hKey End If ' 注册表 hKey = CreateKey(HKEY_LOCAL_MACHINE, "SOFTWARE\MyCompany\MyApp") If hKey <> 0 Then If SetValueEx(hKey, "MyValue", 0, REG_SZ, "Hello, World!", Len("Hello, World!")) = ERROR_SUCCESS Then ' 入成功 End If RegCloseKey hKey End If ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值