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