在VC++中訪問和修改系統登錄檔 (轉)
在VC++中訪問和修改系統登錄檔 (轉)[@more@](廣東 粟利民 孫強)
95/98的登錄檔包含了Windows95/98的、PC機的配置、應用和的其他設定資訊。登錄檔和INI不同,它是多層次的樹狀資料結構,具有六個分支(根鍵),每個分支又由許多的鍵和鍵值組成,而每個鍵則代表一個特定的配置專案。
在實際的工作中,我們遇到了如何在Visual C++中對Windows95/98登錄檔整個樹狀結構資訊進行訪問和修改的問題,如查詢和修改登錄檔中使用者姓名和公司名稱的有關資訊。透過程式設計實踐,我們實現了在Visual C++中查詢和修改系統登錄檔的有關資訊。下面以一個例項說明具體的程式設計方法。
在Visual C++ 6.0或5.0環境中新建一基於對話方塊的工程,設定了兩個命令按鈕,名為“查詢使用者資訊”和“修改使用者資訊”,用來查詢和修改登錄檔中使用者姓名和公司名稱。這裡須要指出的是,使用者的資訊位於系統登錄檔中 HKEY_LOCAL_MACHINESoftwareWindowsCurrentVersion 的位置,鍵值名RegisteredOwner和RegisteredOrganization分別表示使用者的姓名和使用者公司的名稱。
1.查詢使用者資訊的程式碼
HKEY hKEY; //定義有關的 hKEY, 在查詢結束時要關閉。
LPCTSTR data_Set=″SoftwareMicrosoftWindowsCurrentVersion″;
//開啟與路徑 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];
D 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];
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=″SoftwareMicrosoftWindowsCurrentVersion″;
//開啟與路徑 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與之類似),且執行結果正確。
摘自《報》
95/98的登錄檔包含了Windows95/98的、PC機的配置、應用和的其他設定資訊。登錄檔和INI不同,它是多層次的樹狀資料結構,具有六個分支(根鍵),每個分支又由許多的鍵和鍵值組成,而每個鍵則代表一個特定的配置專案。
在實際的工作中,我們遇到了如何在Visual C++中對Windows95/98登錄檔整個樹狀結構資訊進行訪問和修改的問題,如查詢和修改登錄檔中使用者姓名和公司名稱的有關資訊。透過程式設計實踐,我們實現了在Visual C++中查詢和修改系統登錄檔的有關資訊。下面以一個例項說明具體的程式設計方法。
在Visual C++ 6.0或5.0環境中新建一基於對話方塊的工程,設定了兩個命令按鈕,名為“查詢使用者資訊”和“修改使用者資訊”,用來查詢和修改登錄檔中使用者姓名和公司名稱。這裡須要指出的是,使用者的資訊位於系統登錄檔中 HKEY_LOCAL_MACHINESoftwareWindowsCurrentVersion 的位置,鍵值名RegisteredOwner和RegisteredOrganization分別表示使用者的姓名和使用者公司的名稱。
1.查詢使用者資訊的程式碼
HKEY hKEY; //定義有關的 hKEY, 在查詢結束時要關閉。
LPCTSTR data_Set=″SoftwareMicrosoftWindowsCurrentVersion″;
//開啟與路徑 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];
D 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];
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=″SoftwareMicrosoftWindowsCurrentVersion″;
//開啟與路徑 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與之類似),且執行結果正確。
摘自《報》
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-987232/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 怎樣在VC++中訪問和修改登錄檔 (轉)C++
- 遠端登錄檔訪問 (轉)
- Windows XP 登錄檔修改精粹(轉)Windows
- VB中使用系統登錄檔 (轉)
- Windows 98 登錄檔大修改(轉)Windows
- Win10系統怎麼修改登錄檔ProfileName值Win10
- Windows XP系統登錄檔的恢復(轉)Windows
- M$的系統啟動在登錄檔的位置
- win10系統中登錄檔如何開啟 win10系統開啟登錄檔的步驟Win10
- 在AIX,LINUX系統中訪問含特殊符號的檔案AILinux符號
- win10系統修改登錄檔後儲存不了提示寫入登錄檔時出錯如何解決Win10
- 駭客經常更改的系統配置檔案及登錄檔(轉)
- win10修改登錄檔沒有許可權怎麼辦 win10系統下修改登錄檔許可權的方法Win10
- 修改登錄檔 全方位最佳化 Windows XP(轉)Windows
- Javascript如何訪問和處理系統檔案JavaScript
- 檔案和目錄的訪問控制(2)新增訪問控制
- 使用Java操作Windows系統登錄檔JavaWindows
- win10系統利用登錄檔修改資料夾命名方式的方法Win10
- Windows10系統通過登錄檔修改版本號的技巧Windows
- Windows10系統透過登錄檔修改版本號的技巧Windows
- win10系統修改錄音檔案中的檔名的方法Win10
- 在DOS下使用登錄檔掃描程式 (轉)
- Ubuntu系統中修改hosts檔案Ubuntu
- Windows小技巧|登錄檔修改主頁Windows
- “網遊大盜”透過修改登錄檔盜密碼(轉)密碼
- EJB 訪問檔案系統的疑惑
- Windows10系統登錄檔出現問題怎麼修復Windows
- Windows 98 登錄檔妙用(轉)Windows
- win10系統修改檔案提示檔案操作失敗拒絕訪問如何解決Win10
- GhRegEdit64.exe 是 GHOST 軟體中的一個元件,主要用於管理和編輯系統登錄檔。它通常用於在執行系統克隆和恢復操作時,自動調整目標系統的登錄檔設定,以確保系統的正常執行。元件
- win10系統中檔案拒絕訪問怎麼回事 win10系統檔案拒絕訪問的解決步驟Win10
- powershell無法修改字符集,非修改登錄檔修改powershell的方法
- win10系統怎麼修復登錄檔_win10登錄檔怎麼修復Win10
- win10系統登錄檔怎麼修復 win10一鍵修復登錄檔Win10
- win10 修改登錄檔開機啟動方法 win10怎麼修改登錄檔設定啟動項Win10
- 登錄檔檔案修改開啟程式的簡單示例
- 匯出系統登錄檔抓Hash的思路整理
- 透過登錄檔來修改IE安全設定