CString GetSoftWarePath()
{
CString strPath = _T("");
HKEY hkey;
DWORD dwSize = 512;
char string[512];
LPTSTR pValue;
pValue="Path";//
LPCTSTR Rgspath="key" ;
RegOpenKeyEx(HKEY_LOCAL_MACHINE,"SOFTWARE//Microsoft//Windows//CurrentVersion//App Paths//",0,KEY_READ,&hkey);
LONG lRet = RegQueryValueEx(hkey , Rgspath , NULL , REG_NONE , (LPBYTE) string , &dwSize);
if(lRet == ERROR_SUCCESS)
strPath = string;
return strPath;
}
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
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與之類似),且運行結果正確。
1111111111111111111111111111111111111111222222222222222222222222222222222222222222222222
bool CMyClass::ReadAnyValueFromRegistry(LPCTSTR psDirectory,LPCTSTR psName,LPBYTE lpData,LPDWORD lpType,LPDWORD lpcbData)
{
HKEY hKey;
LONG lReturnCode=0;
lReturnCode=::RegOpenKeyEx(HKEY_LOCAL_MACHINE,psDirectory,0,KEY_READ,&hKey);
if(lReturnCode==ERROR_SUCCESS)
{
lReturnCode=::RegQueryValueEx(hKey,psName,NULL,lpType,lpData,lpcbData);
if(lReturnCode==ERROR_SUCCESS)
{
TRACE("Registry's Read!");
::RegCloseKey(hKey);
return true;
}
else
TRACE("Read Registry Failed!");
::RegCloseKey(hKey);
}
return false;
}
CString CMyClass::ReadMtNameFromRegistry()
{
CString* pMtName=" ";
LPCTSTR psDirectory = "HKEY_LOCAL_MACHINE//System//test";
LPCTSTR psName = "Value1";
BYTE sMtName[30];
DWORD Type;
DWORD cbData=sizeof(sMtName);
if(ReadAnyValueFromRegistry(psDirectory,psName,(LPBYTE)sMtName,(LPDWORD)&Type,(LPDWORD)&cbData))
{
*pMtName = sMtName;
return *pMtName ;
}
else
return *pMtName ;
}
本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/wuchen1004/archive/2008/09/11/2914609.aspx