- 浏览: 864010 次
- 性别:
- 来自: 济南
文章分类
- 全部博客 (280)
- java相关 (29)
- linux系统 (55)
- ipsec (0)
- ssl (3)
- 信息安全 (13)
- web相关 (35)
- windows (9)
- c,c++ (14)
- log4j (3)
- hibernate (8)
- sqlite (1)
- 程序人生 (2)
- js (2)
- 生活点滴 (3)
- 网络相关 (14)
- 问题积累 (15)
- 数据库相关 (27)
- 软件测试 (2)
- PKI相关 (2)
- 程序设计 (7)
- 犄角旮旯 (0)
- 杂七杂八 (0)
- 硬件相关 (14)
- 防火墙 (2)
- 电子商务 (2)
- 多媒体相关 (1)
- 内存管理 (4)
- 面向对象 (1)
- csp (1)
- 驱动开发 (3)
- 移动开发 (2)
- openssl多线程实例 (1)
最新评论
-
xiaoyao3857:
博主很有探索精神嘛,学习了
Linux主机名Hostname详解 -
hiskyrisa:
言简意赅,好文章。
Flex是什么 -
layznet:
犯了类似错误。使用的是derby数据库。driverClass ...
java.sql.SQLException: No suitable driver -
idision:
你好,文章有一句createSubjectKeyId(keyT ...
bouncycastle 产生证书 -
zheng12tian:
代码有全的不?只贴一部分,,,,
在LOG4J中把日志写入远程数据库
本文只是对注册表实现简单的打开、创建、读、写、关闭操作,故只是基本知识的介绍,适合不能熟练使用注册表操作的初级读者。
(我把本文放在这里,其实最主要的目的是怕自己以后忘了,毕竟我也不常用这方面的知识,好不容易弄懂了点点,就赶快存起来,呵呵^_^)
一、说明:
注册表是Windows重要组成部分,注册表记录了大量有关电脑软硬件的信息。注册表中的值通过其名称标识。值名称由与键名相同的字符组成。值本身可以是字符串、二进制数据或者是32位无符号值。在这里我们主要运用以下技巧:
(一)、预定义的注册表键。注册表包含了几个预定义键:
1. HKEY_LOCAL_MACHINE 包含描述计算机及其配置的条目。其中包括关于处理器、系统主板、内存和已安装的软件和硬件的信息。
2. HKEY_CLASSES_ROOT 是与文档类型和 OLE\COM 相关的信息的支持键。这个键是 HKEY_LOCAL_MACHINE的从属键。
3. HKEY_USERS 用作默认用户首选设置,也作为单个用户的首选设置。
4. HKEY_CLASSES_USER 是用于当前(登录)用户的相关信息。
5. HKEY_CURRENT_CONFIG 包含了当前系统配置的信息。
6. 还有一个,一般不会出现,只有配置的局域网后才会有。
(二)、VC中两种注册表操作方法
在VC中,主要有两种方法可以实现注册表的操作,一是使用MFC封装的类CRegKey,该类包含了14个成员函数,它们可以实现注册表的简单操作(基本的如本文提到的“打开、创建、读、写、关闭”等);二是使用Windows API函数。当然,对我来说,能使用底层的,那为什么不用呢,毕竟我现在是程序员,使用底层函数,可以移植到更多的开发平台中嘛。
1.
所需要头文件:atlbase.h
该种方法可以使用类CRegKey中的成员函数来完成。先包含头文件,再申明一个类对象CRegKey RKey;然后就可以调用成员函数来操作了。
基本功能的成员函数:
LONG Open(HKEY hKeyParent, LPCTSTR lpszKeyName,REGSAM samDesired = KEY_ALL_ACCESS);
LONG Close();
LONG Create(HKEY hKeyParent, LPCTSTR lpszKeyName,
LPTSTR lpszClass = REG_NONE, DWORD dwOptions = REG_OPTION_NON_VOLATILE,
REGSAM samDesired = KEY_ALL_ACCESS,
LPSECURITY_ATTRIBUTES lpSecAttr = NULL,
LPDWORD lpdwDisposition = NULL);
LONG SetValue(DWORD dwValue, LPCTSTR lpszValueName);
LONG SetValue(LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
LONG QueryValue(DWORD& dwValue, LPCTSTR lpszValueName);
LONG QueryValue(LPTSTR szValue, LPCTSTR lpszValueName, DWORD* pdwCount);
其他几个:
LONG SetKeyValue(LPCTSTR lpszKeyName, LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
static LONG WINAPI SetValue(HKEY hKeyParent, LPCTSTR lpszKeyName,LPCTSTR lpszValue, LPCTSTR lpszValueName = NULL);
HKEY Detach();
void Attach(HKEY hKey);
LONG DeleteSubKey(LPCTSTR lpszSubKey);
LONG RecurseDeleteKey(LPCTSTR lpszKey);
LONG DeleteValue(LPCTSTR lpszValue);
但是本文主要介绍使用Windows API函数来操作注册表,所以这里不详细的介绍这些成员函数的用法了。
2. Windows API函数个数比较多,一共有三、四十个,这里主要介绍几个常用的函数,来实现本文所说的基本功能即可。
常用API函数
☆ 打开一个键的函数:RegOpenKeyEx
函数定义:LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要打开的子键名字的地址
DWORD ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的打开的子键的句柄
);
说明:如果指定的要打开的子键不存在,则返回失败;反之返回成功ERROR_SUCCESS;
☆ 创建一个键的函数:RegCreateKeyEx
函数定义:LONG RegCreateKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
LPCTSTR lpSubKey,//要创建的子键名字的地址
DWORD ulOptions,//保留值,必须为0
REGSAM samDesired,//打开方式,如读还是写
PHKEY phkResult//返回的创建的子键的句柄
);
说明:如果指定的要创建的子键已经存在,则打开该子键;反之创建该子键。函数成功则返回ERROR_SUCCESS;
该子键可以一次创建多层子键,格式为“子键1层\\子键2层\\子键3层。。。”
☆ 查询某一个键值:RegQueryValueEx
函数定义:LONG RegQueryValueEx(HKEY hKey,//要查询的键的句柄
LPCTSTR lpValueName,//要查询的键值的名称
LPDWORD lpReserved,//保留值,必须为0
LPDWORD lpType,//要查询的数据的类型,如果不关心,可以为NULL
LPBYTE lpData,//要返回的查询的数据
LPDWORD lpcbData//预置的数据的长度,理论上可以为NULL,但实际我发现不行,最好设一个值
);
☆ 设置一个键值RegSetValueEx
函数定义:LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄
LPCTSTR lpValueName,//要访问的键值的名称
LPDWORD lpReserved,//保留值
DWORD dwType,//要设置的数据的类型
const BYTE *lpData,//要设置的健值
DWORD cbData//数据的长度
);
说明:如果要写入的数据已经存在,只是改变值而已;如果不存在,则新建子键并存值。
二、例子
我做了一些注册表的简单操作,主要是打开,如果打开失败,则创建;然后存值;
HKEY key;
CString strName = "hello";
CString strCompany = "world";
CString strSeries = "1111-1111";
bool G_bIsLicesed = true;
if (RegOpenKeyEx(HKEY_CURRENT_USER, _T("Software\\my Application\\Settings"), 0, KEY_ALL_ACCESS, &hkey)!= ERROR_SUCCESS)
{
VERIFY(!RegCreateKey(HKEY_CURRENT_USER, _T("Software\\my Application\\Settings"), &hkey));
}
VERIFY(!RegSetValueEx(hkey, _T("LicesedBool"), 0, REG_DWORD, (BYTE *)&G_bIsLicesed, 4));
VERIFY(!RegSetValueEx(hkey, _T("User Name"), 0, REG_SZ, (BYTE *)strName.GetBuffer(strName.GetLength()), 50));
VERIFY(!RegSetValueEx(hkey, _T("Company Name"), 0, REG_SZ, (BYTE *)strCompany.GetBuffer(strCompany.GetLength()),25));
VERIFY(!RegSetValueEx(hkey, _T("License Code"), 0, REG_SZ, (BYTE *)strSeries.GetBuffer(strSeries.GetLength()), 20));
RegCloseKey(hkey);
另外,我还做了注册表的读取操作
unsigned char chbuf[50];
CString strCompany = "";
CString strSeries = "";
HKEY hkey;
DWORD type(0);
DWORD len(50);
memset(chbuf, 0, sizeof(chbuf));
if (RegOpenKeyEx(HKEY_CURRENT_USER, _T("Software\\my Application\\Settings"), 0, KEY_ALL_ACCESS, &hkey) == ERROR_SUCCESS)
{
if (RegQueryValueEx(hkey, _T("User Name"), 0, &type, chbuf, &len) == ERROR_SUCCESS)
{
;
}
if (!RegQueryValueEx(hkey, _T("Company Name"), 0, &type, chbuf, &len))
{
strCompany.Format("%s", chbuf);
}
if (!RegQueryValueEx(hkey, _T("License Code"), 0, &type, chbuf, &len))
{
strSeries.Format("%s", chbuf);
}
if (!RegQueryValueEx(hkey, _T("LicesedBool"), 0, &type, chbuf, &len))
{
G_bIsLicesed = chbuf[0];
}
RegCloseKey(hkey);
}
先就到这里吧,如果要求不是很高的话,就“依葫芦画瓢”,基本可是实现本文所说的功能了。
如果有朋友来看了本文,而你又有更详尽更使用的东东,请贴上来,不尽感谢!
RegQueryValueEx(hkey, _T("LicesedBool"), 0, &type, chbuf, &len)
函数中的参数len,它的大小必须能够容纳要取的值的内存大小。
也就是说,比如要取一个字符串,长为100,那么,你在调用该函数前必须为len定义一个值,该值大于等于100,否则,它取值会失败!
len返回值是实际取值的长度,但是传入之前必须定义一个大于该长度的值,否则它虽然仍会返回实际长度的值,可是数据确取不 出来。
我上面的代码,实际就有点失误。用同一个len连续用在三个取值函数中,虽然开始是设定了值的,可是一旦在前面或中间某个取值函数中返回的len值小于后面一个取值函数中的len实际值,那么后面那个取痔函数就取不 出来值㐂而且,这种失误也是很难检测出来的,因为它的语法没有任何错误。必须时刻注意!!!
发表评论
-
关于从WEB服务器自动下载安装可执行性文件的方法
2010-09-20 15:17 3923首先,想要在客户端直接执行服务器端的程序,必须做一个Activ ... -
Activex控件在IE中也可以不显示安全提示
2010-09-17 17:08 2808转csdn网友shepherds() 在class ... -
U 盘加载,卸载,拔出,插入,WM_DEVICECHANGE,WndProc,DBT_DEVICEARRIVAL,DBT_DEVICEREMOVECOMPLE
2010-05-25 21:17 5675最近在做一个和U盘有关的项目,有一个需求是要求显示插入的U盘的 ... -
DeviceIoControl的使用说明
2010-05-25 17:39 1762应用程序和驱动程序的通信过程是:应用程序使用Cr ... -
Enable3dControls()和Enable3dControlsStatic()函数简介
2010-05-25 09:44 3318Enable3dControls()和Enable3dCont ... -
CString,string,char* 之间的转换
2010-05-24 11:49 1345这几天经常用到的,不如记下吧。 这三种类型各有各的优点, ... -
_cdecl 和_stdcall
2009-08-04 17:12 1396_cdecl 是C Declaration的缩 ... -
指针和数组之区别
2009-07-25 20:00 3175数组名可以当作一个指针来用,数组名可以用*取其中的值,指针也可 ... -
c++内存管理
2009-06-29 10:12 11031. void GetMemory(char *p) { ... -
C++ Primer中文版(第4版) 随书源码
2009-06-07 22:08 2161MS_files.zip for windows using ... -
#include "" 和#include <> 区别问题
2009-06-07 21:02 1094clude ""是先从本地目录开始寻找 ... -
std::cout 与\n
2009-06-07 19:53 1893#includ<iostream> int mai ... -
逗号运算符
2009-05-18 11:40 1349C 语言中,逗号(,)也可以是运算符,称为逗号运算符(Comm ...
相关推荐
请注意,操作注册表时需要小心,因为错误的修改可能会导致软件运行异常甚至系统不稳定。在实际应用中,应添加错误处理代码,并考虑使用适当的安全措施,如备份重要数据。 在“ReadWriteRegistry”这个压缩包文件中...
以下是一个简单的VC6注册表操作示例程序,演示了如何读取和写入注册表值: ```cpp #include #include int main() { HKEY hKey; DWORD dwDisposition; // 打开或创建HKEY_CURRENT_USER\Software\MyApp键 if ...
在VC++中,我们可以使用Windows API函数来操作注册表,如RegOpenKeyEx、RegCreateKeyEx、RegQueryValueEx、RegSetValueEx等。下面是一些关键步骤: 1. **打开键(Key)**:使用`RegOpenKeyEx`函数,传入HKEY之一...
1. 引入库:在VC++项目中,要操作注册表,首先需要包含`#include <winreg.h>`头文件,并链接`advapi32.lib`库。 2. 函数接口: - `RegOpenKeyEx()`:打开一个已存在的注册表键,或者创建一个新的键。 - `...
Visual C++ 6.0(简称VC6.0)是一款经典的C++集成开发环境,它允许开发者通过MFC(Microsoft Foundation Classes)库来操作注册表。本文将详细介绍如何使用VC6.0创建和删除注册表项,以及如何模拟安装和卸载程序的...
首先,让我们了解一下如何在`C++`中直接操作注册表。在Windows API中,`RegOpenKeyEx`函数用于打开已存在的注册表键,`RegCreateKeyEx`用于创建新的键,`RegQueryValueEx`用于读取键值,而`RegSetValueEx`则用于写入...
与大家分享一个VC 简单操作注册表的范例,主要完成注册表键值的读取和写入,向注册表中写入键值、并修改指定项的值,或删除数值,添加条目、删除条目、查询用户信息等,每一步操作都会弹出注册表操作成功与否的提示...
### VC操作注册表实例解析 在本篇内容中,我们将深入了解如何使用Visual C++(简称VC)进行注册表的操作,并具体分析一个简单的示例代码。该示例代码展示了如何使用VC来读取Windows注册表中的特定键值。此外,本文...
在C++编程中,使用Visual C++(简称VC)可以方便地进行注册表操作。通过调用Windows API函数,如RegOpenKeyEx、RegCreateKeyEx、RegSetValueEx等,可以实现对注册表键值的读取和写入。优点是访问速度快,系统级的...
在VC++编程环境中,对注册表进行操作是常见的...总的来说,VC++提供了丰富的API来操作注册表,包括加锁和解锁功能的模拟。开发者需要充分理解这些API的用法,同时关注权限管理和错误处理,以确保代码的安全和可靠性。
VC++,即Visual C++,是Microsoft开发的一款强大的C++编程工具,它提供了一系列API(应用程序接口)供程序员操作注册表。本教程将深入探讨如何使用VC++的注册表API进行键值的添加,并展示相关函数的使用方法。 首先...
例如,如果我们想要添加一个新的环境变量`MY_VAR`,其值为`my_value`,那么在注册表中应创建一个名为`MY_VAR`的字符串值,并将其数据设置为`my_value`。 在VC++中,我们可以使用`RegCreateKeyEx`函数创建新的注册表...
在Windows操作系统中,注册表是存储系统和应用程序配置信息的关键数据库。VC++(Visual C++)作为Microsoft开发的编程环境,可以用来编写程序来访问和读取注册表以获取各种信息,例如安装在系统上的程序的详细数据。...
下面是一个简单的使用MFC操作注册表的示例: ```cpp #include int main() { CWinApp theApp; if (!theApp.InitInstance()) return FALSE; CRegKey regKey; LONG result = regKey.Create(HKEY_CURRENT_USER,...
《获取启动项——VC编写与注册表操作指南》 在计算机系统中,启动项是程序在操作系统启动时自动运行的一种机制。了解并掌握启动项的管理对于系统优化、安全维护至关重要。本文将以VC++(Visual C++)为编程工具,...
VC 修改注册表相关键值实例源码,向注册表中添加一个新的键值项目,本范例源码相当简单,容易理解,是新手学习VC 注册表操作的入门实例。本程序还可查询注册表的指定信息,可学习下如何读娶检索、修改、插入注册表...
通过简单的注册表编辑,我们可以自定义右键菜单,添加个性化功能,使其更加符合个人需求。本文将详细介绍如何通过修改注册表来定制右键菜单。 #### 注册表基础知识 Windows注册表是一个存储操作系统设置和其他应用...
双击运行该文件,它会将预定义的字体设置导入到用户的系统注册表中,从而改变VC6的字体显示。通常,这个脚本会将代码编辑器的字体更改为更易读的等宽字体,如Consolas或Courier New,并可能调整字体大小以适应不同...
总之,“VC6注册信息清理器”是一款针对VC6重装问题的实用工具,通过清理注册表中残留的信息,帮助用户顺利重新安装VC6,继续享受这一经典开发环境带来的便利。在日常使用中,了解注册表的运作机制和如何正确处理...