Windows的注冊表中包含了Windows的系統(tǒng)配置、PC機(jī)的硬件配置、Win32應(yīng)用程序和用戶的其他設(shè)置信息。注冊表和INI文件不同,它是多層次的樹狀數(shù)據(jù)結(jié)構(gòu),具有六個分支(根鍵),每個分支又由許多的鍵和鍵值組成,而每個鍵則代表一個特定的配置項(xiàng)目。在注冊表中鍵可以包括子鍵和值。我們可以對他做個比喻,鍵就是目錄,而子鍵和值可以看成文件,這樣比喻可能不科學(xué)但是很實(shí)際。在Windows 98下注冊表包括在兩個文件內(nèi),他們是user.dat和system.dat兩個文件。System.dat包括標(biāo)準(zhǔn)的系統(tǒng)信息,他們被保存在 HKEY_LOCAL_MACHINE的根鍵內(nèi)。User.dat文件包括用戶指定的信息,如用戶策略,桌面設(shè)定等等。
為了平時查看方便,Windows為我們準(zhǔn)備了一個小程序regedit.exe。執(zhí)行他就可以看到注冊表的樹狀結(jié)構(gòu)。在實(shí)際編程工作中,我們經(jīng)常會遇到如何在Visual C++中對Windows注冊表整個樹狀結(jié)構(gòu)信息進(jìn)行訪問和修改的問題,如查詢和修改注冊表中用戶姓名和公司名稱的有關(guān)信息等。為此,本實(shí)例將相關(guān)的注冊表操作封裝到函數(shù)中,并通過一個簡單的例程給出了上述函數(shù)的調(diào)用方法,該例程可以在注冊表中創(chuàng)建、刪除、顯示一個鍵值,同時還可以清空最近閱讀過的文檔歷史記錄。
一、實(shí)現(xiàn)方法
對注冊表的編程要用到句柄,我們需要通過一個句柄訪問注冊表鍵值,當(dāng)打開或創(chuàng)建一個鍵值的時候,會返回一個該鍵的句柄,并且調(diào)用和分析鍵和創(chuàng)建鍵值,在分析和創(chuàng)建的同時需要傳遞句柄到函數(shù)。WINDOWS提供預(yù)定義的用語---根一級鍵的保留句柄,如 HKEY_CLASS_ROOT,HKEY_CURRENT_USER,HKEY_LOCAL_MACHINE,HKEY_USER等,這些都是與注冊表的根鍵相對應(yīng)并且同名的句柄。當(dāng)訪問一個根鍵的時候,傳遞這些通用句柄。這就不用打開根鍵啦,因?yàn)樗麄兛偸窃诖蜷_狀態(tài)下,可使用默認(rèn)鍵的句柄訪問。
Win32 API提供了大約25個有關(guān)注冊表的函數(shù),他提供了對注冊表的讀取,寫入,刪除,以及打開注冊表的所有函數(shù),并且可以實(shí)現(xiàn)對注冊表備份,連接和對遠(yuǎn)端注冊表進(jìn)行查看等功能。但是在編程的時候首先需要考慮你是在什么操作系統(tǒng)編輯此類程序,雖然微軟的操作系統(tǒng),如NT和Windows98都是32位操作系統(tǒng),但是有些API函數(shù)中并不支持98,這點(diǎn)是要注意的。API經(jīng)歷和發(fā)展了很多年,有些函數(shù)已經(jīng)重復(fù),比如RegSetValue()及 RegSetValueEx()都是用來設(shè)置注冊表鍵值的,兩者的區(qū)別在于前者是設(shè)置注冊表鍵的默認(rèn)值,僅支持作為數(shù)據(jù)類型的字符串,而后者不僅繼承了前者的所有功能而且還能對多值或類型進(jìn)行操作。一般API對比較新的函數(shù)都會在后綴追加"Ex"的同樣名稱函數(shù),建議在編程中均應(yīng)盡可能的使用高級函數(shù)。下面介紹一些比較常用的操作注冊表的API函數(shù):
1、RegCloseKey()
原型:RegCloseKey(HKEY hKey)
解釋:關(guān)閉指定的主冊表鍵,釋放句柄。當(dāng)對一個或多個鍵或值操作完成以后,需要關(guān)閉其鍵來進(jìn)行保存操作結(jié)果,關(guān)閉一個鍵后,句柄變?yōu)榉欠,此時應(yīng)釋放句柄。
2、RegCreateKeyEx()
原型:LONG RegCreateKeyEx( HKEY hKey, LPCTSTR lpSubKey, DWORD Reserved,
LPTSTR lpClass, DWORD dwOptions, REGSAM samDesired, LPSECURITY_ATTRIBUTES lpSecurityAttributes,
PHKEY phkResult, LPDWORD lpdwDisposition );
解釋:打開指定的鍵或子鍵。如果要打開的鍵不存在的話,本函數(shù)會試圖建立它。提供該函數(shù)是為了向后兼容。所有的WIN32應(yīng)用程序應(yīng)使用函數(shù)RegCreateKeyEx()。各參數(shù)及返回值的含義如下:
各參數(shù)及返回值的含義如下:
·hKey為主鍵值,可以取下面的一些數(shù)值:HKEY_CLASSES_ROOT、HKEY_CURRENT_CONFIG、 HKEY_CURRENT_USER、HKEY_LOCAL_MACHINE、HKEY_USER、 HKEY_PERFORMANCE_DATA(WINNT操作系統(tǒng))、HKEY_DYN_DATA(WIN9X操作系統(tǒng));
·參數(shù)lpSubKey為一個指向以零結(jié)尾的字符串的指針,其中包含將要創(chuàng)建或打開的子鍵的名稱。子鍵不可以用反斜線(\)開始。該參數(shù)可以為NULL;
·參數(shù)Reserved為保留值,必須設(shè)置為0;
·參數(shù)lpClass為一個指向包含鍵類型的字符串。如果該鍵已經(jīng)存在,則忽略該參數(shù);
·參數(shù)dwOptions為新創(chuàng)建的鍵設(shè)置一定的屬性。可以取下面的一些數(shù)值: REG_OPTION_NON_VOLATILE ,表示新創(chuàng)建的鍵為一個非短暫性的鍵(數(shù)據(jù)信息保存在文件中,當(dāng)系統(tǒng)重新啟動時,數(shù)據(jù)信息恢復(fù));REG_OPTION_VOLATILE,表示新創(chuàng)建的鍵為一個短暫性的鍵(數(shù)據(jù)信息保存在內(nèi)存中),Windows95忽略該數(shù)值;REG_OPTION_BACKUP_RESTORE 僅在WINNT中支持,可以提供優(yōu)先級支持;
·參數(shù)samDesired用來設(shè)置對鍵訪問的權(quán)限,可以取下面的一些數(shù)值:KEY_CREATE_LINK,表示準(zhǔn)許生成符號鍵;KEY_CREATE_SUB_KEY 表示準(zhǔn)許生成子鍵;KEY_ENUMERATE_SUB_KEYS 表示準(zhǔn)許生成枚舉子鍵;KEY_EXECUTE 表示準(zhǔn)許進(jìn)行讀操作;KEY_NOTIFY表示準(zhǔn)許更換通告; KEY_QUERY_VALUE 表示準(zhǔn)許查詢子鍵;KEY_ALL_ACCESS 提供完全訪問,是上面數(shù)值的組合;
KEY_READ 是下面數(shù)值的組合:KEY_QUERY_VALUE、KEY_ENUMERATE_SUB_KEYS、KEY_NOTIFY; KEY_SET_VALUE 表示準(zhǔn)許設(shè)置子鍵的數(shù)值;KEY_WRITE 是下面數(shù)值的組合:KEY_SET_VALUE、KEY_CREATE_SUB_KEY;
·參數(shù)lpSecurityAttributes為一個指向SECURITY_ATTRIBUTES結(jié)構(gòu)的指針,確定返回的句柄是否被子處理過程繼承。如果該參數(shù)為NULL,則句柄不可以被繼承。在WINNT中,該參數(shù)可以為新創(chuàng)建的鍵增加安全的描述;
·參數(shù)phkResult為一個指向新創(chuàng)建或打開的鍵的句柄的指針;
·參數(shù)lpdwDispition指明鍵是被創(chuàng)建還是被打開的,可以是下面的一些數(shù)值: REG_CREATE_NEW_KEY 表示鍵先前不存在,現(xiàn)在被創(chuàng)建;REG_OPENED_EXISTING_KEY 表示鍵先前已存在,現(xiàn)在被打開。
如果該函數(shù)調(diào)用成功,則返回ERROR_SUCCESS。否則,返回值為文件WINERROR.h中定義的一個非零的錯誤代碼,可以通過設(shè)置 FORMAT_MESSAGE_FROM_SYSTEM標(biāo)識調(diào)用FormatMessage()函數(shù)來獲取一個對錯誤的總體描述。
相關(guān)推薦:2010年全國計算機(jī)等級考試考試報考指南北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |