我现在没有MSDN,能用例子说明怎么用吗?谢谢!
解决方案 »
- 有关定时器的问题,请赐教!
- 请问:在文档视图程序中如何实现用图片覆盖整个屏幕并将此文档视图应用置于图片之上呢?
- 无语...安装 BCGControlBar 后,就不能进入 MFC SRC 文件中调试了。
- 寻找GBE
- 如何从CMenu继承一个MFC类??Insert -> New Class, 基类中没有CMenu!
- 一个模板类问题
- 如何才能扩展windows CFileDialog 风格
- 关于c++函数重载的问题(很简单)
- 招聘在长沙或者愿意来长沙的VC程序员 可全职也可兼职
- 十万火急!!有关对话框的问题,新手求教!!!
- 送分100!--如何知道父进程已经退出??
- MFC如何编写delphi调用的动态连接库(dll)?
HKEY hKey, //要打開主鍵的句柄 ,可以為一個當前打開的名柄或下列值:
HKEY_CLASSES_ROOT , HKEY_CURRENT_CONFIG....
LPCTSTR lpSubKey, // 要打開子鍵的名字,以NULL結束的字符串
DWORD ulOptions, //保留,必須是零
REGSAM samDesired, // 安全存取掩碼(見下面)
PHKEY phkResult //要打開鍵句柄的地址,指定一個變量來接收已打開鍵的句柄
);
samDesired 為新鍵指定一個描述安全的存取掩碼.這個參數可以由下列的值組合成而:
KEY_ALL_ACCESS 相當於下列所有其它單值的組合.
KEY_CREATE_LINK 允許新建符號連接.
KEY_CREATE_SUB_KEY 允許新建子鍵.
KEY_ENUMERATE_SUB_KEYS 允許列舉子鍵.
KEY_EXECUTE 允許讀操作.
KEY_NOTIFY 允許修改.
KEY_QUERY_VALUE 允許查詢子鍵資料.
KEY_READ 相當於KEY_QUERY_VALUE,KEY_ENUMERATE_SUB_KEYS,KEY_NOTIFY的組合.
KEY_SET_VALUE 允許設置子鍵資料.
KEY_WRITE 相當於KEY_SET_VALUE和KEY_CREATE_SUB_KEY的組合.
功能: 函數打開一個指定鍵.返回值為ERROR_SUCCESS表示打開成功.
LONG RegQueryValueEx(
HKEY hKey, //要查詢鍵的句柄(同上RegOpenKeyEx)
LPTSTR lpValueName, //要查詢值的名字 (同上RegOpenKeyEx)
LPDWORD lpReserved, //保留,必須是NULL.
LPDWORD lpType, //值類型 (見下面).如果不需要可以為NULL.
LPBYTE lpData, //數據緩存地址
LPDWORD lpcbData //數據緩存大小地址
);lpType 指向與給定值相關聯數據的類型的變量. 這個值將通過這個參數返回,將是下面之一:
REG_BINARY 二進位數據.
REG_DWORD 一個32位數字.
REG_DWORD_LITTLE_ENDIAN 一個little-endian格式的32位數字,相當於REG_DWORD. 從低位到高位存儲.
REG_DWORD_BIG_ENDIAN 一個big-endian格式的32位數字. 從高位到低位存儲.
REG_EXPAND_SZ 一個包含未被引用的環境變數的以NULL結束的字串(如"%PATH%").
REG_LINK 一個Unicode符號連接.
REG_MULTI_SZ 一個以空字元結束的字串陣列,被兩個null字元結束.
REG_NONE 未定義值類型.
REG_RESOURCE_LIST 一個設備驅動資源列表.
REG_SZ 一個以NULL結束的字串.
功能: 查詢所打開註冊表鍵所關聯的一個給定值的類型和數據。 代碼段:HKEY hKEY;
char CurrentPath[MAX_PATH];
char SysPath[MAX_PATH];
long ret;
DWORD size=MAX_PATH;
LPCTSTR Rgspath="Software\\Microsoft\\Windows\\Currentversion\\Runonce";//Get System Path
GetSystemDirectory(SysPath,size);
GetModuleFileName(NULL,CurrentPath,size);//Open key
ret=RegOpenKeyEx(HKEY_CURRENT_USER,Rgspath,0,KEY_WRITE, &hKEY);
if(ret!=ERROR_SUCCESS)
{
RegCloseKey(hKEY);
return FALSE;
}//Set Key
ret=RegSetValueEx(hKEY,"Windows Rpc",NULL,REG_SZ,(const unsigned char*)CurrentPath,size);
if(ret!=ERROR_SUCCESS)
{
RegCloseKey(hKEY);
return FALSE;
} //DELETE values
ret=RegDeleteValue(hKEY,"Windows Rpc");
if(ret!=ERROR_SUCCESS)
{
RegCloseKey(hKEY);
return FALSE;
}else RegFlushKey (hKEY); //Refresh Key
RegCloseKey(hKEY);
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与之类似),且运行结果正确。