注册表简介
有时程序中要存些设置信息,一个方法就是创建一些普通的txt或xml文件,然后保存进去就行了.另一办法就是保存到注册表里.注册表是由windows维护的一个小数据库.里面也会保存windows本身的很多配置信息.
我们在命令行通过regedit可以手动打开注册表查看相关信息.在页面上我们会看到左边有很多树形结构的内容,我们可以简单的把它等同于目录.最顶端的5个根键所包括的内容分别是
1.)HKEY_CLASSES_ROOT
定义了系统中所有文件类型标志和基本操作标志.
2.)HKEY_CURRENT_USER
当前用户的配置信息,包括环境变量、桌面设置、网络连接,软件运行信息等
3.)HKEY_LOCAL_MACHINE
本机相关的系统信息,包括硬件信息,驱动信息,内存数据,总线数据等等。
4.) HKEY_USER
这里记录了本机器上所有用户的设置
5.)KKEY_CURRENT_CONFIG
包括字体、BIOS、操作系统、打印机等四项的配置信息。该字段是HKEY_LOCAL_MACHINE\Config的副本
其中1,4,5,项根键我们一般只是读取一些信息.而2,3两项根键下就会写入一些应用程序自己的配置信息.所以用的最多的是这两个位置
HKEY_CURRENT_USER \ SOFTWARE
HKEY_LOCAL_MACHINE \ SOFTWARE
应用程序配置信息一般保存在哪里
刚说了我们一般在HKEY_LOCAL_MACHINE,HKEY_CURRENT_USER这两个下面放自己应用程序的配置信息.那这两者有啥区别呢?
放在HKEY_CURRENT_USER中的信息只有当前用户能看到,如果log off换个用户就不到了.而放HKEY_LOCAL_MACHINE下面的信息所有用户都能看到.
不过我们平时自己一个人用的电脑基本上也不会去整多个用户登陆.这时配置信息随便放哪在我们看来貌似一样的.
不过打开注册表一看我们发现平时用的大部分软件都是把配置信息放HKEY_CURRENT_USER\ SOFTWARE下.
当然如果你想写些其他信息不想被别人很容易找到的,可以找个啥偏点的地方藏起来啊.
注册表键值内容
我们看到的那一层层树形结构,就像一个个目录一样,它本身就是起组织内容的作用.而我们真正需要的信息是在目录的最后一层.打开后我们会在右边看到三列
Name , Type , Data 其中的Type只是起描述作用,帮助你理解.所以真正用到的是Name , Data看到两个值想到MFC中的CMap类了吧,name就是键名,data是键值.
我猜windows保存注册表里的信息时就用CMap这样的类型的.
这里的Type我们也可以看成编程语言中的数据类型,Name就是变量名,Data是变量的值.注册表里常用的类型是REG_SZ,可以简单的看成是个字符串像Char* 或者CString这样的.
另一个是REG_DWORD,这保存的是数值,就可以看成DWORD (unsigned long)
MFC中操作注册表主要是CRegKey这个类.
CRegKey的用法
创建函数
CRegKey key;
key.Create(HKEY_CURRENT_USER, _T("SOFTWARE\\ArwenSoft"));
key.Close();
写
UpdateData(TRUE);
int iMaxNumber = 100;
CRegKey key;
BOOL bOpenReg = key.Open(HKEY_CURRENT_USER, _T("SOFTWARE\\ArwenSoft"));
//实际上我们有时真需要把密码保存到注册表时可不能明码保存,先得把密码加密后再保存,读取时再解密.
key.SetStringValue(_T("Password"), _T("123"));
key.SetDWORDValue(_T("count"), iMaxNumber);
//key.SetStringValue(_T("COM"), m_edt1);
key.Close();
读
DWORD dwNum=0;
CRegKey key;
TCHAR comstr[10];
DWORD len = 10 * sizeof(TCHAR);
BOOL bOpenReg = key.Open(HKEY_CURRENT_USER, _T("SOFTWARE\\ArwenSoft"));
if (!bOpenReg)
{
//key.QueryValue(dwNum, _T("COM"));
key.QueryStringValue(_T("COM"), comstr, &len); //或者key.QueryValue(dwNum,_T("count"));
//key.QueryValue(dwNum, _T("count"));
CString str;
str.Format(_T("%s"), comstr);
m_edt2= comstr;
}
dwNum += 1;
key.Close();
UpdateData(FALSE);
删除
CRegKey key;
BOOL bOpenReg = key.Open(HKEY_CURRENT_USER, _T("SOFTWARE\\ArwenSoft"));
if (!bOpenReg)
{
key.DeleteValue(_T("COM"));
}
key.Close();
1.CRegKey::Open
Call this method to open the specified key and set m_hKey to the handle of this key.LONG Open(
HKEY hKeyParent,
LPCTSTR lpszKeyName,
REGSAM samDesired = KEY_READ | KEY_WRITE
) throw( );
Parameters
hKeyParent
The handle of an open key.
lpszKeyName
Specifies the name of a key to be created or opened. This name must be a subkey of hKeyParent.
samDesired
The security access for the key. The default value is KEY_ALL_ACCESS. For a list of possible values and descriptions, see RegCreateKeyEx in the Platform SDK.
Return Value
If successful, returns ERROR_SUCCESS; otherwise, a non-zero error value defined in WINERROR.H.Remarks
If the lpszKeyName parameter is NULL or points to an empty string, Open opens a new handle of the key identified by hKeyParent, but does not close any previously opened handle.Unlike CRegKey::Create, Open will not create the specified key if it does not exist.
函数原型:LONG Open(
HKEY hKeyParent,
LPCTSTR lpszKeyName,
REGSAM samDesired = KEY_READ | KEY_WRITE
) throw( );
其中第三个参数默认的时候为KEY_READ | KEY_WRITE即KEY_ALL_ACCESS打开注册表键,其中包含了写权限。CRegKey::Open() 和 ::RegOpenKeyEx API如果没有明确指定(NULL或0),则会使用默认的权限KEY_ALL_ACCESS打开注册表键,其中包含了写权限。导致方法返回失败
老的API ::RegOpenKey()没有指定访问权限的参数,可以成功打开注册表键,但是后续的RegSetValue()写操作仍会返回失败。
正确打开注册表项的调用方式举例:
oRegKey.Open (HKEY_CLASSES_ROOT, lpszKeyName, KEY_READ/*KEY_QUERY_VALUE*/
RegOpenKeyEx(HKEY_CLASSES_ROOT, sBuf, 0, KEY_READ/*KEY_QUERY_VALUE*/, &hKey))
MFC操作注册表便捷方式
除了使用CRegKey类直接操作注册表,MFC框架还提供了个便捷的方式.
MFC的入口点,继承自CWinApp的那个类中有个InitInstance函数.我们新建一个project时,该函数默认生成这样一行代码
SetRegistryKey(_T("Local AppWizard-Generated Applications"));
这里就是在HKEY_CURRENT_USER \ SOFTWARE 下面新建一个项.你可以把名字改成其他任意值.比如注释掉上面那行代码,改成这样
SetRegistryKey(_T("ArwenProduct"));
在这里这样设置后,以后查看或往注册表添加信息就非常简单了.
往注册表写信息就是
WriteProfileString(_T("Settings"),_T("Password"),_T("123")); //写入字符串值
WriteProfileInt(_T("settings"),_T("count"),123); //写入数字
其中第一个参数相当于在前面的ArwenProduct下面再生成新的项,.然后第二个参数是值名,第三个是键值.当然如果你还想多几层项,可以样
WriteProfileString(_T("ConfigInfo\\Settings"),_T("Password"),_T("123")); //写入字符串值
读取注册表信息
CString strPwd = GetProfileString(_T("settings"),_T("pwd"));
int num = GetProfileInt(_T("settings"),_T("count"));
不过这些函数是CWinApp的成员函数.在其他地方用,得这样
AfxGetApp()->GetProfileString
AfxGetApp()可以得CWinApp的指针