C/C++注册表【2】打开,创建,删除

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sunjikui1255326447/article/details/88802927

注册表打开,创建,删除

所需要头文件:windows.h  

常用函数

(1) 打开一个键的函数:

RegOpenKeyEx

函数定义:LONG RegOpenKeyEx(HKEY hKey,                  //已经打开的键的句柄,或者直接是上述几个根键

                              LPCTSTR lpSubKey,                             //要打开的子键名字的地址

                              DWORD ulOptions,                               //保留值,必须为0

                              REGSAM samDesired,                          //打开方式,如读还是写

                              PHKEY phkResult                                 //返回的打开的子键的句柄

                               );

RegOpenKey 这个函数与Windows 3.1兼容。基于Win32的应用程序应该使用RegOpenKeyEx函数。(建议使用RegOpenKeyEx函数)

LONG RegOpenKey(HKEY hKey,        // 要打开键的句柄
                     LPCTSTR lpSubKey, // 要打开子键的名字的地址
                     PHKEY phkResult   // 要打开键的句柄的地址
                     );

注意:RegOpenKey这个函数与Windows 3.1兼容。基于Win32的应用程序应该使用RegOpenKeyEx函数。

实例:

#include "pch.h"
#include <iostream>
# include <windows.h>
# include <tchar.h>

int main(void)
{
	HKEY hKey = NULL;
	const TCHAR * subKey = _T("SOFTWARE\\RunTest");
	DWORD dwOptions = REG_OPTION_NON_VOLATILE;
	DWORD dwDisposition;

	LONG lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,subKey, 0, KEY_ALL_ACCESS, &hKey);
	if (lRet == ERROR_SUCCESS) {
		MessageBox(NULL, _T("打开注册表成功"), _T("提示"), MB_OK);
		HKEY hSubKey = NULL;
	}
	else {
		MessageBox(NULL, _T("打开注册表失败"), _T("提示"), MB_OK);
	}
	RegCloseKey(hKey);
	return 0;
}

若不存在,则返回打开失败提示语,完成创建后,重新打开,提示会成功。

(2)新建指定键

RegCreateKey

                   函数定义:LONG RegCreateKey (HKEY  hkey,                           // 要打开键的句柄

                                     LPCTSTR lpsubkey,                                                    // 要打开子键的名字的地址

                                     PHKEY phkresult                                                         // 已打开句柄的缓存区的地址

                                     );

注意:如果这个键在注册表中已经存在,这个函数打开它。

RegCreateKeyEx函数:

                    函数定义:LONG RegCreateKeyEx(  
                                      HKEY hKey,                                    // 主键名称  
                                      LPCTSTR lpSubKey,                      // 子键名称或路径  
                                      DWORD Reserved,                        // 保留,为0  
                                      LPTSTR lpClass,                            // 一般设置为NULL
                                      DWORD dwOptions,      /* 对你建立的键的一些选项,可以是这些值:                                                                                                                                                     REG_OPTION_NON_VOLATILE,

                                                                                               REG_OPTION_VOLATILE,           

                                                                                               REG_OPTION_BACKUP_RESTORE

                                                                                第一个是默认的了。一般用第一个就可以了。*/  
                                     REGSAM samDesired,                        // 设置你对你建立的这个键的访问权限
                                     LPSECURITY_ATTRIBUTES lpSecurityAttributes,                   //一般设置为NULL
                                     PHKEY phkResult,                               // 返回新建注册表项的句柄  
                                     LPDWORD lpdwDisposition                 //用来查看是打开一个已经有的键,还是新建了键  
      );

返回值:不成功返回非0,成功返回ERROR_SUCCESS.  
           解释:打开指定的键或子键。如果要打开的键不存在的话,本函数会试图建立它。当在创建或打开注册表的键时,需要指定访问权限,而这些访问权限需要到一级。默认的权限是KEY_ALL_ACCESS权限。还有KEY_CREATE_LINK创建字符链权限,KEY_CREATE_SUB_KEY创建子键权限,KEY_EXECUTE读取键权限,KEY_NOTIFY获得修改键通知的权限,KEY_QUERY_VALUE查询键值的权限,KEY_SET_VALUE设置数据值的权限。注意不能在根一级建键,在注册表的根一级仅可有预定义的键。具体使用,请查看联机手册。

实例:

#include "pch.h"
#include <iostream>
# include <windows.h>
# include <tchar.h>

int main(void)
{
	HKEY hKey = NULL;
	const TCHAR * subKey = _T("SOFTWARE\\RunTest");
	DWORD dwOptions = REG_OPTION_NON_VOLATILE;
	DWORD dwDisposition;

	long resulte = RegCreateKeyEx(HKEY_LOCAL_MACHINE, subKey, 0, NULL,
		dwOptions, KEY_WRITE, NULL, &hKey, &dwDisposition);
	if (resulte != ERROR_SUCCESS)
	{
		MessageBox(NULL, _T("打开注册表失败"), _T("提示"), MB_OK);
	}
	else
	{
		if (dwDisposition == REG_OPENED_EXISTING_KEY)
		{
			MessageBox(NULL, _T("打开一个存在的注册表项"), _T("提示"), MB_OK);
		}
		else if (dwDisposition == REG_CREATED_NEW_KEY)
		{
			MessageBox(NULL, _T("新建一个注册表项"), _T("提示"), MB_OK);
		}
	}
	RegCloseKey(hKey);
	return 0;
}

若系统为X64,请到 HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node路径下查看创建的注册表。

(3)删除

3.1删除注册表指定键下的值 

                   函数定义: LONG RegDeleteValue(HKEY hKey,            //子键的句柄

                                      LPCTSTR lpValueName                              //删除键值的名称

                                     );

3.2删除注册表项 (注册表文件夹)就用

                   函数定义:LONG RegDeleteKey(HKEY hKey,        //已打开的键的句柄

                                    LPCTSTR lpSubKey                               //要删除的子键或路径

                                    );

         RegDeleteKey 也可用来删除一个键值。在 Win 95/98 平台下,也可用来删除整个子键和键值。但是在Windows NT/2000及以上平台,只能用来删除没有子键的键。

3.3删除一个带有很多子键值的键

                   函数定义:DWORD SHDeleteKey(HKEY    hkey,                      // 注册表打开的键值的句柄

                                     LPCTSTR  pszSubKey                                            //被删除的键值名称

                                  );

实例:

#include "pch.h"
#include <iostream>
# include <windows.h>
# include <tchar.h>

int main(void)
{

	const TCHAR *lpszSubKey = _T("SOFTWARE\\Runtest");
	LONG lRet = RegDeleteKey(HKEY_LOCAL_MACHINE, lpszSubKey);
	if (lRet == ERROR_SUCCESS) {
		MessageBox(NULL, _T("删除成功!"), _T("tips"), MB_OK);
	}
	else {
		MessageBox(NULL,_T("删除失败!"),_T("tips"),MB_OK);
	}

    //const TCHAR *lpszSubKey = _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run456");
//SHDeleteKey(HKEY_LOCAL_MACHINE, lpszSubKey);

	return 0;
}

删除完成后,重新打开注册表编译器,则创建的Runtest子键消失。

猜你喜欢

转载自blog.csdn.net/sunjikui1255326447/article/details/88802927