用于操作注册表的编程,参考:
//下面这个是个小错误,请注意:
//第二次用有指针参数的函数时,要注意,此时该指针指向的内存块大小和内容均是上一次的
vc注册表操作相关函数说明
注册表的操作,API为我们提供了大约25个函数。他提供了对注册表的读取,写入,删除,以及打开注
册表及键值时所有函数,并且可以达到对注册表的备份,连接和对远端注册表进行查看等等。注册表对
整个系统十分重要,你在进行操作时,一定要先考虑清楚。这些函数有:
RegCloseKey RegConnectRegistry RegCreateKey RegCreateKeyEx RegDeleteKey RegDeleteVale
RegEnumKey RegFlushKey RegGetKeySecurity(此函数,98不适用) RegLoadKey RegNotifyChangeKeyValue(98不适用) RegOpenKey RegOpenKeyEx RegQueryInfoKey
RegQueryValue
RegQueryValueEx RegReplaceKey RegRestoreKey(98不适用) RegSaveKey RegSetKeySecurity
(98不适用) RegSetValue RegSetValueEx RegUnLoadKey
我们对经常使用的几个函数进行介绍。
1·RegClose()
原形:LONG RegCloseKey(
HKEY hKey // 释放已经打开的注册表句柄
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:关闭指定的主册表键,释放句柄。当对一个或多个键或值操作完成以后,需要关闭其键来进行
保存操作结果。关闭一个键后,句柄变为非法,以使其不可再次被使用。为系统重新使用而释放句柄。
例子
BOOL bRet = TRUE;
if( m_hKey == NULL )
return( FALSE );
bRet = ( ::RegCloseKey( m_hKey ) == ERROR_SUCCESS );
m_hKey = NULL;
return( bRet );
2·RegCreateKeyEx()和RegCreateKey()
原形:LONG RegCreateKeyEx(
HKEY hKey, // 主键名称
LPCTSTR lpSubKey, // 子键名称或路径
DWORD Reserved, // 保留,为0
LPTSTR lpClass, // 没弄懂,我设为空也差不多
DWORD dwOptions,
REGSAM samDesired, // 设置你对你建立的这个键的访问权限 LPSECURITY_ATTRIBUTES lpSecurityAttributes,
//不太明白
PHKEY phkResult, // 指向你建的句柄
LPDWORD lpdwDisposition //用来查看是打开一个已经有的键,还是新建了键
);
RegCreateKey()函数简单了不少,请自己看了。
返回值:不成功返回非0,成功返回ERROR_SUCCESS.
解释:打开指定的键或子键。如果要打开的键不存在的话,本函数会试图建立它。当在创建或打开注
册表的键时,需要指定访问权限,而这些访问权限需要到一级。默认的权限是KEY_ALL_ACCESS权限。还
有KEY_CREATE_LINK创建字符链权限,KEY_CREATE_SUB_KEY创建子键权限,KEY_EXECUTE读取键权限,
KEY_NOTIFY获得修改键通知的权限,KEY_QUERY_VALUE查询键值的权限,KEY_SET_VALUE设置数据值的权
限。注意不能在根一级建键,在注册表的根一级仅可有预定义的键。具体使用,请查看联机手册。
例子:
HKEY m_hkey;
DWORD dwDisposition;
long ret0=(::RegCreateKeyEx
(HKEY_CURRENT_USER,"REGD",0,NULL,
REG_OPTION_NON_VOLATILE,KEY_ALL_ACCESS,NULL,&m_hkey,&dwDisposition)); if(ret0!=ERROR_SUCCESS) //如果无法打开hKEY,则终止程序的执行
{
MessageBox("错误: 无法打开有关的hKEY!");
return;
}
if(dwDisposition==REG_OPENED_EXISTING_KEY)
MessageBox("打开了一个已经存在的键");
else
{
if(dwDisposition==REG_CREATED_NEW_KEY)
MessageBox("建立一个新键");
}
RegClosekey(m_hkey);
3·RegOpenKey()和RegOpenKeyEx()
原形:LONG RegOpenKeyEx(
HKEY hKey, // 要打开主键名
LPCTSTR lpSubKey, // 子键或路径
DWORD ulOptions, // 保留,为0
REGSAM samDesired, // 操作权限标志
PHKEY phkResult // 指向你打开键的句柄
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS.
解释:该函数负责打开指定的键或子键,如果不存在他不建立。其他和RegCreateKeyEx()和
RegCreateKey()基本相同。
4·RegDeleteKey()
原形:LONG RegDeleteKey(
HKEY hKey, // 已打开的键的句柄
LPCTSTR lpSubKey // 要删除的子键或路径,传如""将删除key本身 );
返回值:不成功返回非0,成功返回ERROR_SUCCESS
该函数用来删除注册表中的一个键值的。在用此函数时需要注意98与NT的差异。在NT中在删除一个键
之前,要求必须删除所有子键,需要从下向上递归删除所有子键,而WINDOWS98没有他那么复杂,只要
删除键及其所有子键就可以啦。
5·RegQueryValue()和RegQueryValueEx()
原形:LONG RegQueryValueEx(
HKEY hKey, // 已打开的键的句柄
LPTSTR lpValueName, // 要查询值的名称,传如""为查询键下的默认值 LPDWORD lpReserved, // 保留,为0
LPDWORD lpType, // 查询的类型
LPBYTE lpData, // 数据存放的地址
LPDWORD lpcbData // 数据长度+1
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:读取某子键下特定名称的值。
例子
CString m_strQ;//用来存放查询来的字符串值
DWORD m_dwCount;//记录字符串的长度+1(包括NULL字符)
::RegQueryValueEx(m_hkey,"",0,NULL,NULL,&m_dwCount);//先查询出字节空间 ret1=(::RegQueryValueEx
(m_hkey,"",0,NULL,(unsigned char *)m_strQ.GetBuffer(m_dwCount),&m_kk)); m_strQ.ReleaseBuffer();
MessageBox(m_strQ);
6·RegSetValue()和RegSetValueEX()
原形:LONG RegSetValueEx(
HKEY hKey, // 已打开的键的句柄
LPCTSTR lpValueName, // 要查询值的名称,传如""为查询键下的默认值 DWORD Reserved, // 保留
DWORD dwType, // 变量的类型
CONST BYTE *lpData, // 变量数据的地址
DWORD cbData // 变量的长度
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:设置某子键下特定名称的值。
7·RegEnumValue()
原形:LONG RegEnumValue(
HKEY hKey, // 要查询的已打开的键的句柄
DWORD dwIndex, // 读取名称的索引号
LPTSTR lpValueName, // 返回所读取的名称
LPDWORD lpcbValueName, // 返回读取名称的长度,不含chr(0) LPDWORD lpReserved, // 保留,为0
LPDWORD lpType, // 返回所读取的数据类型
LPBYTE lpData, // 返回所读取的数据
LPDWORD lpcbData // 返回所读取的数据长度
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:列出某Key的所有名称的值,变化索引即可遍历整个键下的名称和数据。 8·RegDeleteValue()
原形:LONG RegDeleteValue(
HKEY hKey, // 要删除的键的句柄
LPCTSTR lpValueName // 要删除的名称
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:删除某Key的某一名称
9·RegEnumKey()和RegEnumKeyEx()
原形:LONG RegEnumKeyEx(
HKEY hKey, // 要列举的键的句柄
DWORD dwIndex, // 索引
LPTSTR lpName, // 子键的名称
LPDWORD lpcbName, // 子键名称的长度
LPDWORD lpReserved, // 保留
LPTSTR lpClass, // address of buffer for class string
LPDWORD lpcbClass, // address for size of class buffer
PFILETIME lpftLastWriteTime
// address for time key last written to
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
返回注册表键及其子键的详细信息。
10·RegQueryInfoKey()
原形:LONG RegQueryInfoKey(
HKEY hKey, // 已打开的键的句柄
LPTSTR lpClass, // 类型名称,仅使用于NT。若不使用则传入Null LPDWORD lpcbClass, // 类型名称的长度
LPDWORD lpReserved, // 保留
LPDWORD lpcSubKeys, // 返回子键的数目
LPDWORD lpcbMaxSubKeyLen, // 返回最长的子键长度 LPDWORD lpcbMaxClassLen, // 返回最长的类长度
LPDWORD lpcValues, // 返回值的数目
LPDWORD lpcbMaxValueNameLen, // 返回最长的值项名称的长度
LPDWORD lpcbMaxValueLen, // 返回最长的值的长度
LPDWORD lpcbSecurityDescriptor, //返回安全描述,仅适用于 NT
PFILETIME lpftLastWriteTime // 返回键最后被写入的时间,仅适用于 NT );
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:返回注册表键的信息,包括类名、子键数量、最长子键名、值的数量、最长值数据、安全描述
符的长度以及上一次写入的时间等。
11·RegLoadKey()
原形:LONG RegLoadKey(
HKEY hKey, // 打开的句柄
LPCTSTR lpSubKey, //子键的路径
LPCTSTR lpFile // 要写入注册表信息的文件
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:从指定的文件恢复注册表键的子键信息到注册表。
12·RegReplaceKey()
原形:LONG RegReplaceKey(
HKEY hKey, // handle to open key
LPCTSTR lpSubKey, // address of name of subkey
LPCTSTR lpNewFile, // 在替换前生成新的备份文件
LPCTSTR lpOldFile // 需要覆盖上注册表的文件
);
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:从指定的文件恢复注册表键的子键信息到注册表并替换原有的值,并生成新的备份文件
13· RegSaveKey()
LONG RegSaveKey(
HKEY hKey, // 要保存的句柄
LPCTSTR lpFile, // 保存子键的文件
LPSECURITY_ATTRIBUTES lpSecurityAttributes //不太懂 );
返回值:不成功返回非0,成功返回ERROR_SUCCESS
解释:保存键及其子键信息到指定的文件。
14· RegConnectRegistry()
原形:LONG RegConnectRegistry(
LPTSTR lpMachineName, //远程计算机的名称 HKEY hKey, // 预先注册的句柄
PHKEY phkResult // 远程计算机上的句柄 );
返回值:不成功返回非0,成功返回ERROR_SUCCESS 解释:连接到远程系统的注册表。
15·RegNotifyChangeKeyValue()
当修改指定的注册表对象时提供通知。
16· RegUnloadKey()
LONG RegUnLoadKey(
HKEY hKey, // handle to open key
LPCTSTR lpSubKey // address of name of subkey to unload );
返回值:不成功返回非0,成功返回ERROR_SUCCESS 删除注册表键及其所有的子键。
VC++:访问和修改系统注册表 Windows95/98的注册表包含了Windows95/98的系统配置、PC机的硬件配置 、Win32应用程序和用户的其他设置信息。注册表和INI文件不同,它是多层次的 树状数据结构,具有六个分支(根键),每个分支又由许多的键和键值组成,而 每个键则代表一个特定的配置项目。 在实际的编程工作中,我们遇到了如何在Visual C++中对Windows95/98注 册表整个树状结构信息进行访问和修改的问题,如查询和修改注册表中用户姓名 和公司名称的有关信息。通过编程实践,我们实现了在Visual C++中查询和修 改系统注册表的有关信息。下面以一个实例说明具体的编程方法。 在Visual C++ 6.0或5.0环境中新建一基于对话框的工程,设置了两个命令 按钮,名为“查询用户信息”和“修改用户信息”,用来查询和修改注册表中用 户姓名和公司名称。这里须要指出的是,用户的信息位于系统注册表中 HKEY_LOCAL_MACHINE Software Microsoft Windows CurrentVersion 的位置,键 值名RegisteredOwner和RegisteredOrganization分别表示用户的姓名和用户公司 的名称。 1.查询用户信息的代码 HKEY hKEY; //定义有关的 hKEY, 在查询结束时要关闭。 LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion\″; //打开与路径 data_Set 相关的 hKEY,第一个参数为根键名称,第二个参数表。 //表示要访问的键的位置,第三个参数必须为0,KEY_READ表示以查询的方式。 //访问注册表,hKEY则保存此函数所打开的键的句柄。 long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set, 0, KEY_READ, &hKEY)); if(ret0!=ERROR_SUCCESS) //如果无法打开hKEY,则终止程序的执行 {MessageBox(″错误: 无法打开有关的hKEY!″); return;} //查询有关的数据 (用户姓名 owner_Get)。 LPBYTE owner_Get=new BYTE[80]; DWORD type_1=REG_SZ ; DWORD cbData_1=80; //hKEY为刚才RegOpenKeyEx()函数所打开的键的句柄,″RegisteredOwner″。 //表示要查 询的键值名,type_1表示查询数据的类型,owner_Get保存所。 //查询的数据,cbData_1表示预设置的数据长度。 long ret1=::RegQueryValueEx(hKEY, ″RegisteredOwner″, NULL, &type_1, owner_Get, &cbData_1); if(ret1!=ERROR_SUCCESS) { MessageBox(″错误: 无法查询有关注册表信息!″); return; } // 查询有关的数据 (公司名 company_Get) LPBYTE company_Get=new BYTE [80]; DWORD
type_2=REG_SZ; DWORD cbData_2=80; long ret2=::RegQueryValueEx(hKEY, ″RegisteredOrganization″, NULL,&type_2,company_Get, &cbData_2); if(ret2!=ERROR_SUCCESS) { MessageBox(″错误: 无法查询有关注册表信息!″); return; } // 将 owner_Get 和 company_Get 转换为 CString 字符串, 以便显示输出。 CString str_owner=CString(owner_Get); CString str_company=CString(company_Get); delete[] owner_Get; delete[] company_Get; // 程序结束前要关闭已经打开的 hKEY。 ::RegCloseKey(hKEY); …… 这样,上述程序执行完毕,字符串str_owner和str_company则表示查询到的 用户的姓名和公司的名称,在VC++中便可用对话框的方式将其显示出来。 2. 修改用户信息的代码(注意和上述的查询代码属于不同的函数体) 在程序中我们先显示一个对话框,要求用户输入新的用户姓名和公司名称并 按确认键,将取得CString类型的有关字符串。要先将其转换为LPBYTE(即 unsigned char*)型的数据类型,以便后面的函数调用。下面是程序中用到的将 CString型转换为LPBYTE的转换函数: LPBYTE CString_To_LPBYTE(CString str) { LPBYTE lpb=new BYTE[str.GetLength()+1]; <str.GetLength(); i++)lpb[i]=str[i];> for(int i=0; ibr> lpb[str.GetLength()]=0; return lpb; } 以下则是具体的修改注册表用户信息的代码: CString str_owner, str_company; …… //通过对话框输入新的用户信息,保存到str_owner和str_company //定义有关的 hKEY, 在程序的最后要关闭。 HKEY hKEY; LPCTSTR data_Set=″Software\Microsoft\Windows\CurrentVersion″; //打开与路径 data_Set 相关的hKEY,KEY_WRITE表示以写的方式打开。 long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE, data_Set, 0, KEY_WRITE, &hKEY)); if(ret0!=ERROR_SUCCESS) { MessageBox(″错误: 无法打开有关的hKEY!″); return; } //修改有关数据(用户姓名 owner_Set),要先将CString型转换为LPBYTE。 LPBYTE owner_Set=CString_To_LPBYTE(str_owner); DWORD type_1=REG_SZ; DWORD cbData_1=str_owner.GetLength()+1; //与RegQureyValueEx()类似,hKEY表示已打开的键的句柄,″RegisteredOwner″ //表示要访问的键值名,owner_Set表示新的键值,type_1和cbData_1表示新值。 //的数据类型和数据长度 long ret1=::RegSetValueEx(hKEY, ″RegisteredOwner″, NULL,
type_1, owner_Set, cbData_1); if(ret1!=ERROR_SUCCESS) { MessageBox(″错误: 无法修改有关注册表信息!″); return; } //修改有关的数据 (公司名 company_Set) LPBYTE company_Set=CString_To_LPBYTE(str_company); DWORD type_2=REG_SZ; DWORD cbData_2=str_company.GetLength()+1; long ret2=::RegSetValueEx(hKEY, ″RegisteredOrganization″, NULL, type_2, company_Set, cbData_2); if(ret2!=ERROR_SUCCESS) { MessageBox(″错误: 无法修改有关注册表信息!″); return; } 执行上面的修改注册表的操作后,可打开注册表查看具体的数值,可以看到 已经成功地修改了有关的数据了。 以上实例讲述了如何在VC++中访问Windows98/95的系统注册表,我们可以 很方便地查询及修改注册表的任何位置的有关信息。以上的程序在Visual C++ 6.0中调试通过(Visual C++ 5.0与之类似),且运行结果正确。 以下是我仿照VCL写的一个能对注册表数据进行基本操作的类,希望对您有用。 class CRegistry { public: CRegistry(void); ~CRegistry(void); bool OpenKey(HKEY hRootKey, LPCTSTR lpSubKey, bool bCreate); LPBYTE ReadData(LPCTSTR lpValueName); LPTSTR ReadString(LPCTSTR lpValueName); DWORD ReadDWORD(LPCTSTR lpValueName, DWORD dwDefault); bool WriteData(LPCTSTR lpValueName, const BYTE *lpData, DWORD cbData, DWORD dwType); bool WriteString(LPCTSTR lpValueName, LPCTSTR lpString); bool WriteDWORD(LPCTSTR lpValueName, DWORD dwData); bool DeleteKey(LPCTSTR lpSubKey); bool DeleteValue(LPCTSTR lpValueName); private: HKEY m_hRootKey; HKEY m_hCurrentKey; LPBYTE m_lpData; }; CRegistry::CRegistry(void) { m_lpData = NULL; m_hRootKey = HKEY_LOCAL_MACHINE; m_hCurrentKey = NULL; } CRegistry::~CRegistry(void) { delete[] m_lpData; m_lpData = NULL; } bool CRegistry::OpenKey(HKEY hRootKey, LPCTSTR lpSubKey, bool bCreate) { bool bResult; m_hRootKey = hRootKey; if (bCreate) { DWORD dwResult; bResult = (RegCreateKeyEx(hRootKey, lpSubKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &m_hCurrentKey, &dwResult) == ERROR_SUCCESS); } else bResult = (RegOpenKeyEx(hRootKey, lpSubKey, 0, KEY_ALL_ACCESS, &m_hCurrentKey) == ERROR_SUCCESS); return bResult; } LPBYTE CRegistry::ReadData(LPCTSTR lpValueName) { DWORD dwRequired; DWORD dwType; RegQueryValueEx(m_hCurrentKey, lpValueName, 0, &dwType, NULL, &dwRequired); delete[] m_lpData; m_lpData = new BYTE[dwRequired]; RegQueryValueEx(m_hCurrentKey, lpValueName, 0, &dwType, m_lpDat
a, &dwRequired); return m_lpData; } LPTSTR CRegistry::ReadString(LPCTSTR lpValueName) { return (LPTSTR)ReadData(lpValueName); } DWORD CRegistry::ReadDWORD(LPCTSTR lpValueName, DWORD dwDefault) { LPBYTE lpResult = ReadData(lpValueName); if (NULL == lpResult) return dwDefault; else return (DWORD)*lpResult; } bool CRegistry::WriteData(LPCTSTR lpValueName, const BYTE *lpData, DWORD cbData, DWORD dwType) { return (RegSetValueEx(m_hCurrentKey, lpValueName, 0, dwType, lpData, cbData) == ERROR_SUCCESS); } bool CRegistry::WriteString(LPCTSTR lpValueName, LPCTSTR lpString) { return (WriteData(lpValueName, (const BYTE*)lpString, lstrlen(lpString), REG_SZ)); } bool CRegistry::WriteDWORD(LPCTSTR lpValueName, DWORD dwData) { return (WriteData(lpValueName, (const BYTE*)&dwData, sizeof(DWORD), REG_DWORD)); } bool CRegistry::DeleteKey(LPCTSTR lpSubKey) { return (RegDeleteKey(m_hCurrentKey, lpSubKey) == ERROR_SUCCESS); } bool CRegistry::DeleteValue(LPCTSTR lpValueName) { return (RegDeleteValue(m_hCurrentKey, lpValueName) == ERROR_SUCCESS); }一、说明: 注册表是Windows重要组成部分,注册表记录了大量有关电脑软硬件的信息。注册表中的值通过其名称标识。值名称由与键名相同的字符组成。值本身可以是字符串、二进制数据或者是32位无符号值。在这里我们主要运用以下技巧:(一)、预定义的注册表键。注册表包含了几个预定义键: HKEY_LOCAL_MACHINE 包含描述计算机及其配置的条目。其中包括关于处理器、系统主板、内存和已安装的软件和硬件的信息。 HKEY_CLASSES_ROOT 是与文档类型和 OLE\COM 相关的信息的支持键。这个键是 HKEY_LOCAL_MACHINE的从属键。 HKEY_USERS 用作默认用户首选设置,也作为单个用户的首选设置。 HKEY_CLASSES_USER 是用于当前(登录)用户的相关信息。 HKEY_CURRENT_CONFIG 包含了当前系统配置的信息。 还有一个,一般不会出现,只有配置的局域网后才会有。 (二)、CRegKey 类及主要使用和函数说明 所需要头文件:atlbase.h 常用函数 ☆ 打开一个键的函数:RegOpenKeyEx函数定义:LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键LPCTSTR lpSubKey,//要打开的子键名字的地址DWORD ulOptions,//保留值,必须为0REGSAM samDesired,//打开方式,如读还是写PHKEY phkResult//返回的打开的子键的句柄);☆ 查询某一个键值:RegQueryValueEx函数定义:LONG RegQueryValueEx(HKEY hKey,//要
查询的键的句柄LPCTSTR lpValueName,//要查询的键值的名称LPDWORD lpReserved,//保留值LPDWORD lpType,//要查询的数据的类型LPBYTE lpData,//要返回的查询的数据LPDWORD lpcbData//预置的数据的长度);☆ 设置一个键值RegSetValueEx函数定义:LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄LPCTSTR lpValueName,//要访问的键值的名称LPDWORD lpReserved,//保留值DWORD dwType,//要设置的数据的类型const BYTE *lpData,//要设置的健值DWORD cbData//数据的长度); 二、实例: 通过AppWizard创建基于对话框的程序 Regedit 设置两个命令按钮,名为“查询”(ID_QUERY)和“修改”(ID_CHANGE),用来查询和修改注册表中用户姓名和公司名称。 注:信息位置9x系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrntVersion NT系列:\HKEY_LOCAL_MACHINE\Software\Microsoft\Windows NT\CurrntVersion 键值:RegisteredOwnertkg和RegisteredOrganization分别表示用户名和公司名 设置两个编辑框,用于显示和修改信息。定义两个CString变量m_strOwner,m_Company。 “查询”按钮代码如下:void CRegeditDlg::OnQuery(){UpdateData(true);HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭//打开与路径 data_Set相关的hKEYLPCTSTR data_Set="Software\\Microsoft\\Windows NT\\CurrentVersion\\";//访问注册表,hKEY则保存此函数所打开的键的句柄long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行{AfxMessageBox("错误:无法打开有关的hKEY");return;}//查询有关的数据LPBYTE owner_Get=new BYTE[80];//定义用户姓名 owner_GetDWORD type_1=REG_SZ;//定义数据类型DWORD cbData_1=80;//定义数据长度long ret1=::RegQueryValueEx(hKEY,"RegisteredOwner",NULL,&type_1,owner_Get,&cbData_1);if(ret1!=ERROR_SUCCESS){AfxMessageBox("错误:无法查询有关的注册表信息");return;}//查询公司名LPBYTE company_Get=new BYTE[80];//定义公司名称 company_GetDWORD type_2=REG_SZ;//定义数据类型DWORD cbData_2=80;//定义数据长度long ret2=::RegQueryValueEx(hKEY,"RegisteredOrganization",NULL,&type_2,company_Get,&cbData_2);if(ret2!=ERROR_SUCCESS){AfxMessageBox("错误:无法查询有关的注册表信息");return;}//显示信息m_strOwner=CString(owner_Get);m_strCompany=CString(company_Get);delete[] owner_Get;delete[] c
ompany_Get;//程序结束,关闭打开的hKEY::RegCloseKey(hKEY);UpdateData(false);}“设置”按钮代码如下:void CRegeditDlg::OnModify(){UpdateData(true);HKEY hKEY;//定义有关的hKEY,在查询结束时要关闭//打开与路径 data_Set相关的hKEYLPCTSTR data_Set="Software\\Microsoft\\Windows NT\\CurrentVersion\\";//访问注册表,hKEY则保存此函数所打开的键的句柄long ret0=(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,data_Set,0,KEY_READ,&hKEY));if(ret0!=ERROR_SUCCESS)//如果无法打开hKEY,则中止程序的执行{AfxMessageBox("错误:无法打开有关的hKEY");return;}//设置有关的数据//CString_To_LPBYTE,请参考下面的函数LPBYTE owner_Set=CString_To_LPBYTE(m_strOwner);//定义用户姓名 owner_SetDWORD type_1=REG_SZ;//定义数据类型DWORD cbData_1=m_strOwner.GetLength()+1;//定义数据长度long ret1=::RegSetValueEx(hKEY,"RegisteredOwner",NULL,type_1,owner_Set,cbData_1);if(ret1!=ERROR_SUCCESS){AfxMessageBox("错误:无法设置有关的注册表信息");return;}//查询公司名LPBYTE company_Set=CString_To_LPBYTE(m_strCompany);//定义公司名称 company_SetDWORD type_2=REG_SZ;//定义数据类型DWORD cbData_2=m_strCompany.GetLength()+1;//定义数据长度long ret2=::RegSetValueEx(hKEY,"RegisteredOrganization",NULL,type_2,company_Set,cbData_2);if(ret2!=ERROR_SUCCESS){AfxMessageBox("错误:无法设置有关的注册表信息");return;}else{AfxMessageBox("注册表修改完成");}//程序结束,关闭打开的hKEY::RegCloseKey(hKEY);UpdateData(false);}参考函数 LPBYTE CString_To_LPBYTE(CString str){LPBYTE lpb=new BYTE[str.GetLength()+1];for(int i=0;i<str.GetLength();i++)lpb[i]=str[i];lpb[str.GetLength()]=0;return lpb;} 三、注意:以上代码仅能在Windows NT/2000/XP中通过,Windows 9X/Me中请将注册表路径中的Windows NT改为Windows即可实现。 本程序源代码在Windows 2000+VC6.0中通过测试。 本程序源代码示例文件仅能在 Windows NT/2000/XP 下使用,Windows 9X/Me 中请修改后使用。 主要是添加了开机自启动项函数详解a)打开注册表,定位到某个KEYlong RegOpenKeyEx(HKEY hKey, // 待打开的预定义键LPCTSTR lpSubKey, // 待打开的子键的地址DWORD ulOptions, // 保留REGSAM samDesired, // 安全访问掩码PHKEY phkResult // 打开的键的地址);b) 关闭注册表RegCloseKey(HKEY hKey, // 待打开的预定义键)c)向注册表写入值long RegSetValueEx(HKEY hKey, //待打开的预定义键LPCTSTR lpValueName, //一个指向包含值名的字符串指针DWORD Reserved, //保留,通常必须设置为DWORD dwType, //设置的值的类型CONST BYTE *lpData, //指向包含插入注册表的键值的缓冲区的指针DWORD cbData //指向保
存返回值长度的变量的指针);d)从注册表删除值long RegDeleteValue(HKEY hKey, //待打开的预定义键LPCTSTR lpSubKEY //欲删除的键名);实例//写入注册表,开机自启动HKEY hKey; //找到系统的启动项LPCTSTR lpRun = _T("Software\\Microsoft\\Windows\\CurrentVersion\\Run"); //打开启动项Key long lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE, lpRun, 0, KEY_WRITE, &hKey); if(lRet == ERROR_SUCCESS) { unsigned char pFileName[MAX_PATH] = {0}; //得到程序自身的全路径DWORD dwRet = GetModuleFileName(NULL, (LPWCH)pFileName, MAX_PATH); //添加一个子Key,并设置值lRet = RegSetValueEx(hKey, _T("Mutextest"), 0, REG_SZ, (BYTE *)pFileName, dwRet); //关闭注册表RegCloseKey(hKey); if(lRet != ERROR_SUCCESS) { AfxMessageBox(_T("系统参数错误,不能随系统启动")); CHECK1.SetCheck(0);} } VC的获取系统时间使用VC的一个结构体SYSTEMTIME,其中包括年、月、日、时、分、秒等信息。可以使用结构体的访问方式访问其中值。使用GetSystemTime(&SYSTEMTIME)传入一个SYSTEMTIME类型的引用/指针即可取得当前系统时间。注意,取得的时间是格林尼治时间,比如我们在正8时区就要手动给当前时间进行修正。SYSTEMTIME tm;GetSystemTime(&tm);//输出时间outfile << setw(2) << tm.wMonth << "/" << setw(2) << tm.wDay << "/" << tm.wYear << " " << setw(2) << (tm.wHour + 8)%24 << ":" << setw(2) << tm.wMinute << ":" << setw(2) << tm.wSecond << " "; VC的获取当前用户名使用函数GetUserName(),用法如下char buf[64]; GetUserName(buf, sizeof(buf));
vc字符串函数大全bcmp比较内存内容相关函数bcmpstrcasecmpstrcmpstrcollstrncmpstrncase…
第一节MessageBoxNULLTEXTquot世界你好quotTEXTquot问quotMBOKMBICONQUESTION第…
vc数据类型转换大全转载inti100longl20xxfloatf3002doubled12345119charusername…
vc中各种字符串含义和转换大全20xx年03月31日整理第一章各种字符串类型的定义区别和含义CStringBSTRLPCTSTR之…
vc字符串函数大全bcmp比较内存内容相关函数bcmpstrcasecmpstrcmpstrcollstrncmpstrncase…