Реестр в ОС Windows

 

СОДЕЖАНИЕ


ВВЕДЕНИЕ

. АНАЛИЗ СОСТОЯНИЯ ВОПРОСА

1.1 Что такое реестр

.2 Роль реестра

.3 Реестр Windows 3.1

.4 Реестр Windows NT 3.1

1.5 Современный реестр Windows7

.6 Архитектура реестра

.7 Структура реестра

2. ПОСТАНОВКА ЗАДАЧИ

. ПРОЕКТИРОВАНИЕ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ

3.1 Интерфейс программы

.2 Структурная схема вызовов окон приложений

4. РЕАЛИЗАЦИЯ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ

4.1 Физическая структура приложения

.2 Описание стандартных методов использованных в при реализации приложения

.3 Описание основных процедур и функции

5. ТЕСТИРОВАНИЕ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ

5.1 Cоздание нового раздела

.2 Добавление новых ключей со значениями новых ключей

.3 Изменение ключа

.4 Удаление раздела со всеми ключами

.5 Результаты тестирования

ВЫВОДЫ

СПИСОК ИСПОЛЬЗОВАННЫХ ИСТОЧНИКОВ

ПРИЛОЖЕНИЕ А


ВВЕДЕНИЕ


Во всех версиях Windows, начиная с Windows 95, системный реестр является центральным хранилищем всей конфигурационной информации, касающейся настройки Windows, пользовательских предпочтений, а также установленного программного и аппаратного обеспечения. Поэтому есть необходимость в создании системной утилиты работающей с системным реестром Windows. Данная утилита должна поддерживать вывод ключей реестра, создание и удаление ключей, а также иметь возможность изменения их.

В первом разделе рассказывается о системном реестре в целом. Описывается его структура, роль и выполняемые им функции.

Во втором разделе была сформулирована задача, которую необходимо реализовать в данном курсовом проекте.

В третьем и четвертом разделах рассмотрены основные моменты на этапах проектирования и реализации программного обеспечения.

В пятом разделе производится тестирование программного продукта и его сравнение со стандартной утилитой редактирования реестра Regedit.

К записке также прилагается листинг исполняемых модулей и графическая часть.

Курсовой проект выполнен с учётом требований к содержанию и оформлению курсового проекта [1], а также гостов на построение блок схем [2], [3].


1. АНАЛИЗ СОСТОЯНИЯ ВОПРОСА


1.1 Что такое реестр


Словарь Microsoft Computer Dictionary дает такое определение Реестра: Иерархически построенная, централизованная база данных в составе операционных систем Microsoft Windows 9x/NT/2000/XP/2003/Vista/7, содержащая сведения, которые используются операционной системой для работы с пользователями, программными продуктами и устройствами.

В реестре хранятся данные, которые необходимы для правильного функционирования Windows. К ним относятся профили всех пользователей, сведения об установленном программном обеспечении и типах файлов, которые могут быть созданы каждой программой, информация о свойствах папок и значках приложений, а также установленном оборудовании и используемых портах.

Системный реестр заменяет собой большинство текстовых ini-файлов, которые использовались в Windows 3.x, а также файлы конфигурации MS-DOS (например, Autoexec.bat и Config.sys).

Версии реестра для разных версий операционных систем семейства Windows имеют определенные различия.

Во время запуска операционной системы происходит до тысячи обращений к Реестру, а во время работы на ПК в течение одного сеанса работы - до 10 тысяч. Отдельные компоненты Реестра хранятся в оперативной памяти ПК в течение всего сеанса работы.

Запись (считывание) информации в Реестр (из Реестра) происходит постоянно: например, если мы устанавливаем какую-нибудь программу, вся информация, необходимая для запуска и работы этой программы, записывается в Реестр. Если мы устанавливаем новое устройство, в Реестре будет отмечено, где находится его драйвер и т.д. Если же мы запускаем какую-либо программу или устройство, то из Реестра считывается вся необходимая для запуска программы (устройства) информация.


1.2 Роль реестра


Реестр можно рассматривать как записную книжку Windows - как только системе нужна какая-то информация, то она ищет ее в реестре. Реестр очень обширен и дать однозначное его определение невозможно. Приблизительно, Реестр - компонент операционной системы компьютера, который в иерархической базе данных хранит важнейшие установки и информацию о приложениях, системных операциях и пользовательской конфигурации.

Реестр выполняет следующие основные функции:

)отслеживает все системные устройства и их установки, включая такие ресурсы, как запросы на прерывания (IRQ) и номера каналов прямого доступа памяти (DMA);

2)работает как база данных, которая унифицирует функционирование приложений;

)проверяет наличие необходимых драйверов для инсталлируемого оборудования. При добавлении нового периферийного устройства Диспетчер конфигурации (Configuration manager) операционной системы помещает конфигурационные данные устройства в реестр;

4)предоставляет системные сервисы, которые необходимы для работы многих приложений;

5)обеспечивает запуск необходимого приложения при щелчке мышью;

6)сохраняет информацию, относящуюся к системным правилам, профилям пользователей и средствам администрирования.

Реестр - это не статическая база данных, он постоянно работает и постоянно обновляется. При запуске любой программы происходит множество обращений к реестру, еще больше обращений происходит при запуске компьютера.


1.3 Реестр Windows 3.1


Сам реестр, как древовидная иерархическая база данных (registration database - регистрационная база) впервые появился в Windows 3.1 (апрель 1992). Это был всего один двоичный файл, который назывался REG.DAT и хранился в каталоге C:\Windows\. Реестр Windows 3.1 имел только одну ветку HKEY_CLASSES_ROOT. Он служил для связи DDE, а позднее и OLE объектов.

Одновременно c появлением реестра в Windows 3.1 появилась программа REGEDIT.EXE для просмотра и редактирования реестра.

Первый реестр уже имел возможность импорта данных из *.REG файлов. В базовой поставке шел файл SETUP.REG, содержащий данные по основным расширениям и типам файлов.

Реестр Windows 3.1 имел ограничение на максимальный размер файла REG.DAT - 64 Кбайт. Если вдруг реестр превышал этот размер - то файл реестра (REG.DAT) приходилось удалять и собирать заново либо из *.REG файлов, либо вводить данные вручную.


1.4 Реестр Windows NT 3.1


Следующий шаг сделан в Windows NT 3.1 (июль 1993). Произошёл отказ от устаревших файлов MS-DOS: AUTOEXEC.BAT и CONFIG.SYS, а также от INI-файлов, как от основных файлов конфигурации. На регистрационную базу (реестр) была переведена вся конфигурация системы. Основой конфигурации системы стал реестр. Он имел 4 корневых раздела: HKEY_LOCAL_MACHINE, HKEY_CURRENT_USER, HKEY_CLASS-ES_ROOT и HKEY_USERS.

Реестр стал «сборным»: на диске он хранился в файлах: DEFAULT, SOFTWARE, SYSTEM, а при запуске системы из этих файлов собиралась единая БД.

В комплекте поставки оставался файл REGEDIT.EXE, который по прежнему позволял просматривать и редактировать только ветку HKEY_CLASSES_ROOT, и появился файл REGEDT32.EXE, который позволял редактировать все ветки реестра.

Далее технология и идеология (назначение) реестра уже не менялись. Все последующие версии Windows (NT 3.5, 95, NT 4.0, 98, 2000, XP, Vista, 7) использовали реестр как основную БД, содержащую все основные данные по конфигурации как самой ОС, так и прикладных программ. Далее менялось только расположение и название файлов реестра, и название и назначение ключей.


1.5 Современный реестр Windows


Реестр в том виде, как его использует Windows и как видит его пользователь в процессе использования программ работы с реестром, некоторым образом «нигде не хранится», а формируется из различных данных. Чтобы получилось то, что видит пользователь, редактируя реестр, происходит следующее.

Вначале, в процессе установки и настройки Windows, на диске формируются файлы, в которых хранится часть данных относительно конфигурации системы.

Затем, в процессе каждой загрузки системы, а также в процессе каждого входа и выхода каждого из пользователей, формируется некая виртуальная сущность, называемая «реестром» - объект REGISTRY\. Данные для формирования «реестра» частично берутся из тех самых файлов (Software, System …), частично из информации, собранной ntdetect при загрузке (HKLM\Hardware\Description).

То есть часть данных реестра хранится в файлах, а часть данных формируется в процессе загрузки Windows.

Для редактирования, просмотра и изучения реестра стандартными средствами Windows (программы regedit.exe и regedt32.exe) доступны именно ветки реестра. После редактирования реестра и/или внесения в него изменений эти изменения сразу записываются в файлы.

Однако есть программы сторонних разработчиков, которые позволяют работать непосредственно с файлами.

Программы оптимизации реестра, твикеры, а также инсталляторы и деинсталляторы программ работают через специальные функции работы с реестром.


1.6 Архитектура реестра


Информация, хранящаяся в иерархической базе данных реестра, собрана в разделы (key), которые содержат один или более подразделов (subkey).

Возможность создавать вложенные подразделы позволяет группировать параметры. В результате получается древовидная структура, которую можно просмотреть в Редакторе реестра (Registry editor). Каждый раздел (ветвь) соответствует определенному типу информации о пользователе, аппаратном обеспечении, приложении и т.д.


1.7 Структура реестра


Реестр состоит из следующих разделов (ветвей):

1)HKEY_CURRENT_USER - данный раздел является корневым для данных конфигурации пользователя, вошедшего в систему в настоящий момент. Здесь хранятся папки пользователя, цвета экрана и параметры панели управления. Эти сведения сопоставлены с профилем пользователя. Вместо полного имени раздела иногда используется аббревиатура HKCU;

2)HKEY_USERS - данный раздел содержит все активные загруженные профили пользователей компьютера. Раздел HKEY_CURRENT_USER является подразделом раздела HKEY_USERS. Вместо полного имени раздела иногда используется аббревиатура HKU;

3)HKEY_LOCAL_MACHINE - содержит параметры конфигурации, относящиеся к данному компьютеру (для всех пользователей). Вместо полного имени раздела иногда используется аббревиатура HKLM;

4)HKEY_CLASSES_ROOT - является подразделом HKEY_LOCAL_MACHINE \Software. Хранящиеся здесь сведения обеспечивают выполнение необходимой программы при открытии файла с использованием проводника. Вместо полного имени раздела иногда используется аббревиатура HKCR. Начиная с Windows 2000, эти сведения хранятся как в HKEY_LOCAL_MACHINE, так и в HKEY_CURRENT_USER. Раздел HKEY_LOCAL_ MACHINE\Software\Classes содержит параметры по умолчанию, которые относятся ко всем пользователям локального компьютера. Параметры, содержащиеся в разделе HKEY_CURRENT_USER\Software\Classes, переопределяют принятые по умолчанию и относятся только к текущему пользователю. Раздел HKEY_CLASSES_ROOT включает в себя данные из обоих источников.

Кроме того, раздел HKEY_CLASSES_ROOT предоставляет эти объединенные данные программам, разработанным для более ранних версий Windows. Изменения настроек текущего пользователя выполняются в разделе HKEY_CURRENT_USER\Software\Classes. Модификация параметров по умолчанию должна производиться в разделе HKEY_LOCAL_MACHINE\Software\Classes. Данные из разделов, добавленных в HKEY_CLASSES_ROOT, будут сохранены системой в разделе HKEY_LOCAL_MACHINE\Software\Classes. Если изменяется параметр в одном из подразделов раздела HKEY_CLASSES_ROOT и такой подраздел уже существует в HKEY_CURRENT_USER\Software\Classes, то для хранения информации будет использован раздел HKEY_CURRENT_USER\Software\Classes, а не HKEY_LOCAL_MACHINE\Software \Classes;

5)HKEY_CURRENT_CONFIG - данный раздел содержит сведения о профиле оборудования, используемом локальным компьютером при запуске системы.


2. ПОСТАНОВКА ЗАДАЧИ


В соответствии с заданием курсового проекта, должна быть исследована структура системного реестра и разработано программное обеспечение для просмотра и изменения системного реестра.

Приложение должно обладать следующим функционалом:

)вывод всех веток реестра;

2)просмотр списка ключей для определенной директории реестра;

)добавление новых ключей со значениями разного типа;

)редактирование ключей;

)добавление новой папки (директории) в реестр;

)удаление определенной папки (директории) и ключа;

)вывод сведений о программе.

Приложение должно быть разработано для операционной системы Window 7 с помощью инструментального средства Microsoft Visual Studio 2010, на основе интерфейса Windows Forms.



3. ПРОЕКТИРОВАНИЕ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ


3.1 Интерфейс программы


Как известно, разрабатываемое приложение должно быть интуитивно понятным для пользователей. Для этого, интерфейс программы должен быть спроектирован наиболее простым и понятным способом. Для этого необходимо реализовать главное меню, в котором будут реализованы операции добавления раздела и ключа, изменение ключа, а также удаление раздела и ключа. Далее приведу примерное изображение меню (см. рисунок 3.1.1):


Рисунок 3.1.1 - Примерное изображение основного меню


Операция создания нового ключа может создавать ключи как строчного типа, так и DWORD типа. Для возможности выбора определенного типа ключа было создано выпадающее меню для операции создания ключа (см. рисунок 3.1.2):


Рисунок 3.1.2 - Примерное изображение выпадающего меню


Поскольку нам необходимо выводить все ветки реестра на форму, добавляем элемент управления TreeView, в котором будут отображаться все директории реестра. Для отображения имен и значений ключей поместим на форму элемент DataGrid. В нем данные будут отображаться в виде таблицы (см. рисунок 3.1.3):

Рисунок 3.1.3 - Примерное изображение таблицы


В итоге главное окно программы будет иметь следующий вид (см. рисунок 3.1.4):


Рисунок 3.1.4 - Главное окно программы


Для удобства использования программы все основные операции реализованы в виде диалогов, ввиду их простоты и удобства, как создания, так и модифицирования.

Диалог добавления ключа должен иметь 2 элемента управления TextBox, в которые пользователь будет вводить имя и значение ключа. Примерное изображение диалога добавления нового ключа приведено на рисунке 3.1.5:


Рисунок 3.1.5 - Диалоговое окно добавления нового ключа

Также пользователь должен иметь возможность изменения имени и значения определенного ключа. Для этого нужно будет выбрать необходимый ключ из таблицы ключей и нажать пункт меню Изменить. В результате появится диалоговое окно изменения ключа (см. рисунок 3.1.6):


Рисунок 3.1.6 - Примерное изображения диалога изменения ключа


После редактирования ключа, имя и значение в таблице должны обновиться автоматически.


3.2 Структурная схема вызовов окон приложений


Данное приложение многооконное. Оно состоит из главного окна и 4 диалоговых. Каждый пункт меню главного окна вызывает свое собственное диалоговое окно. Для конкретизации вызовов окон в приложении, приведу структурную схему, изображённую на рисунке 3.2.1:


Рисунок 3.2.1 - Структурная схема вызовов окон



4. РЕАЛИЗАЦИЯ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ


4.1 Физическая структура приложения


Физическая структура данного приложения состоит из нескольких программных модулей (см. рисунок 4.1.1):


Рисунок 4.1.1 - Изображение Обозревателя решения


Список основных модулей приложения и их описание:

1)Main.cs - главное окно приложения, содержит код реализующий все обработчики событий и основные функции, а именно, добавление ключей разного типа, создание и удаление разделов, изменение и удаление ключей;

2)CreateDirForm.cs - диалоговое окно добавления нового раздела, в коде которого хранится название нового раздела, которое будет передано модулю Main.cs для создания и отображения нового раздела;

)СreateStrRegForm.cs - диалоговое окно создания нового строчного ключа, информация из которого будет передано в модуль Main.cs, где и будет произведено добавления нового ключа;

4)DwordRegForm.cs - окно создания нового ключа со значением типа DWORD. Принцип работы аналогичен с модулем добавления ключа со строчным значением;

5)EditRegForm.cs - диалог редактирования имен и значений ключей. Исправленная информация будет передана в модуль главного окна, где будут произведены изменения ключа.


4.2 Описание стандартных методов использованных при реализации приложения


Для реализации курсового проекта используется среда Microsoft Visio Studio 2010. Она имеет пользовательский интерфейс, предоставляет удобные средства для написания программы. Необходимо отметить, что данный программный продукт представляет собой довольно мощный инструмент для разработки программ подобного типа.

Для того чтобы разобраться в реализации данного проекта приведу описание используемых методов класса RegistyKey, предоставляемого программной платформой .NET Framework версии 4.0.

Для возвращения вложенного раздел с доступом только для чтения используем метод OpenSubKey класса RegistryKey. Для использования этого класса необходимо подключить пространство имен Microsoft.Win32.

Для создание нового вложенного раздела или открытия существующего вложенного раздела, с доступом на чтение и запись вызываем метод CreateSubKey класса Registry.

Метод GetSubKeyNames класса RegistryKey возвращает массив строк, который содержит все имена раздела.

Для установления значения пары имя-значения в разделе реестра используется метод SetValue класса RegistryKey.

Для удаления заданного значения из раздела используется метод DeleteValue.

4.3 Описание основных процедур и функции


Основу грамотного функционирования приложения составляют процедуры и функции, реализующие работу с реестром и отображающие результаты этой работы.

Основные функции, используемые при создании данного программного обеспечения:

-private void FillNodes(RegistryKey reg, string[] s, TreeNode tn) - процедура, выводящая на экран все директории реестра. Блок-схема алгоритма работы данной процедуры приведен на листе 1 графической части приложения Б;

-private RegistryKey FindReg(TreeNode tnC, RegistryKey rg, TreeNode tnS) - метод выполняющий поиск ключа. Данная функция возвращает экземпляр класса RegistryKey. Блок-схема алгоритма работы данной функции приведен на листе 2 графической части приложения Б;

-private RegistryKey Findreg_by_path(TreeNode te) - функция, выполняющая поиск ключа по пути;

private void FillGrid(string[] str, RegistryKey rg) - процедура, которая заполняет таблицу именами и значениями ключей. Блок-схема алгоритма работы данной процедуры приведен на листе 3 графической части приложения Б.



5. ТЕСТИРОВАНИЕ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ


Произведем тестирование разработанного программного обеспечения с целью выявления ошибок и неполадок. Тестирование программы будет выполняется на ноутбуке со следующей конфигурацией: Intel Core i7 2,2GHz, 4Gb DDR3, Windows Seven Ultimate.

Данное приложение разработано для операционных систем Windows XP/Vista/Seven. Для полного функционирования данного программного обеспечения необходимо определенное программное окружение, а именно, установленная программная платформа .NET Framework версии 4.0.

Для подтверждения работоспособности программы необходимо протестировать использование все функции программы.

План тестирования:

1)создание нового раздела;

2)добавление новых ключей со значениями разного типа;

)изменение ключа;

)удаление раздела со всеми ключами.

На каждом этапе тестирования результаты программного обеспечения будут сравниваться с результатами стандартной утилиты редактирования реестра Regedit, поставляемой с операционной системой Windows Seven Ultimate.


5.1 Cоздание нового раздела


Создадим новый раздел Тестирование в ветке HKEY_CURRENT_USER и сравним с результатом работы стандартной утилиты Regedit (см. рисунок 5.1.1 и рисунок 5.1.2):




Рисунок 5.1.1 - Добавление нового раздела


Рисунок 5.1.2 - Вывод ветки HKEY_CURRENT_USER с помощью Regedit


Из рисунка 5.1.1 и рисунка 5.1.2 видно, что раздел создан успешно.


5.2 Добавление новых ключей со значениями новых ключей


Далее создадим для раздела Тестирование ключ со строчным значением и со значение DWORD типа (см. рисунок 5.2.1 и рисунок 5.2.2). Сверим с результатом утилиты Regedit (см. рисунок 5.2.3).


Рисунок 5.2.1 - Диалоговое окно создания нового ключа

Рисунок 5.2.2 - Создание новых ключей


Рисунок 5.2.3 - Результаты утилиты Regedit


Строчный ключ Cтрока и ключ DWORD со значением типа DWORD созданы успешно.


5.3 Изменение ключа


Изменим имя строчного ключа на Строка(измененная) для тестирования операции изменения ключей (см. рисунок 5.3.1 и рисунок 5.3.2). И снова сравним с результатом стандартной утилиты Regedit (см. рисунок 5.3.3).



Рисунок 5.3.1 - Диалоговое окго изменения ключа


Рисунок 5.3.2 - Значения ключей после изменения


Рисунок 5.3.3 - Результат работы стандартной утилиты Regedit


Название ключа изменилось с Строка на Строка (измененная) успешно.


5.4 Удаление раздела со всеми ключами


Удалим наш созданный раздел вместе со всеми ключами (см. рисунок 5.4.1 и рисунок 5.4.2).


Рисунок 5.4.1 - Диалог подтверждения удаления


Рисунок 5.4.2 - Главное окно после удаления раздела Тестирование


Раздел Тестирование удален безвозвратно. Все ключи, входящие в этот раздел также удалены.


5.5 Результаты тестирования


Результаты тестирования показали, что все функции программы работают исправно. Сама программа работает стабильно, ошибки и сбой выявлены не были. Данное программное обеспечение ничем не уступает стандартной утилите редактирования реестра Regedit.

утилита реестр windows интерфейс


ВЫВОДЫ


В ходе выполнения данной курсовой работы было разработано приложение, демонстрирующее работу с системным реестром операционной системы Windows. Согласно результатам тестирования, представленный программный продукт оказался устойчивым к возникновению исключительных ситуаций.

Безусловно, спроектированное приложение демонстрирует не весь функционал и потенциал системного реестра. Однако вполне способно найти себе применение при конкретной модернизации. Например, может быть использовано пользователями для удаления ненужной информации из системного реестра или для редактирования её.

Также еще раз прекрасно себя показала программная платформа .NET Framework, используемая при создании данного курсового проекта. На ней очень удобно создавать системные приложения, так как она предоставляет большой инструментарий и легко понятную документацию для работы с ним.


ПРИЛОЖЕНИЕ А


ЛИСТИНГ ПРОГРАММЫ


Main.cs


using System;System.Collections.Generic;System.ComponentModel;System.Data;System.Drawing;System.Linq;System.Text;System.Windows.Forms;System.IO;Microsoft.Win32;System.Security.AccessControl;

Курсач

{partial class Main : Form

{treen;[] reg = new RegistryKey[5];tempreg = null;isTreeClick = false;rSec;dt;p, m;


public Main()

{[0] = Registry.CurrentUser;[1] = Registry.ClassesRoot;[2] = Registry.LocalMachine;[3] = Registry.Users;[4] = Registry.CurrentConfig;();.Nodes.Add(reg[0].Name);.Nodes.Add(reg[1].Name);.Nodes.Add(reg[2].Name);.Nodes.Add(reg[3].Name);.Nodes.Add(reg[4].Name);i = 0;(TreeNode tn in treeView1.Nodes)

{[] str = reg[i].GetSubKeyNames();[] s;(int j = 0; j < str.Length; j++).Nodes.Add(str[j]);

(TreeNode tnn in tn.Nodes)

{

{r = reg[i].OpenSubKey(tnn.Text);= r.GetSubKeyNames();

}(Exception) { continue; }

}++;

}.CollapseAll();= new DataTable("regtable");.Columns.Add("Имя");.Columns.Add("Значение");.DataSource = dt;.Columns[0].Width = 210;.Columns[1].Width = 350;

}


void FillNodes(RegistryKey reg, string[] s, TreeNode tn)

{[] ss;(s.Length != 0)

{(int k = 0; k < s.Length; k++).Nodes.Add(s[k]);(TreeNode tt in tn.Nodes)

{

{rg = reg.OpenSubKey(tt.Text);= rg.GetSubKeyNames();

}(Exception) { continue; }

}

}

}RegistryKey Findreg_by_path(TreeNode te)

{s = te.FullPath;strtemp = null;rg = null;(s != "HKEY_CLASSES_ROOT" && s != "HKEY_CURRENT_USER"

&&!= "HKEY_LOCAL_MACHINE" && s != "HKEY_USERS" &&!= "HKEY_CURRENT_CONFIG")

{i = 0;(s[i] != '\\')

{+= s[i];++;

}(strtemp)

{"HKEY_CLASSES_ROOT":= FindReg(treeView1.Nodes[1], reg[1], te); break;"HKEY_CURRENT_USER":= FindReg(treeView1.Nodes[0], reg[0], te); break;"HKEY_LOCAL_MACHINE":= FindReg(treeView1.Nodes[2], reg[2], te); break;"HKEY_USERS":= FindReg(treeView1.Nodes[3], reg[3], te); break;"HKEY_CURRENT_CONFIG":= FindReg(treeView1.Nodes[4], reg[4], te); break;

}

}

{= s;(strtemp)

{"HKEY_CLASSES_ROOT": return Registry.ClassesRoot;"HKEY_CURRENT_USER": return Registry.CurrentUser;"HKEY_LOCAL_MACHINE": return Registry.LocalMachine;"HKEY_USERS": return Registry.Users;"HKEY_CURRENT_CONFIG": { dt.Rows.Clear(); return .CurrentConfig; }

}


}rg; }

RegistryKey FindReg(TreeNode tnC, RegistryKey rg, TreeNode tnS)

{(tempreg != null) return tempreg;(TreeNode tn in tnC.Nodes)

{reg;{ reg = rg.OpenSubKey(tn.Text, true); }(Exception) { continue; }(tn.FullPath == tnS.FullPath)

{ tempreg = reg; return tempreg; }if (tn.Nodes.Count != 0) FindReg(tn, rg, tnS);

}tempreg;

}void treeView1_AfterExpand(object sender, TreeViewEventArgs e)

{tempnd = e.Node; string[] str;regs;= Findreg_by_path(tempnd);(regs!=null)

{(TreeNode tnn in tempnd.Nodes)

{

{.Nodes.Clear();treg = regs.OpenSubKey(tnn.Text);= treg.GetSubKeyNames();(string ss in str)

{.Nodes.Add(ss);

}

}(Exception) { continue; }

}

} tempreg=null;


}

void treeView1_AfterSelect(object sender, TreeViewEventArgs e)

{(e.Action == TreeViewAction.ByMouse)

{rg; treen = e.Node; string[] ses;.Rows.Clear();= Findreg_by_path(treen);(rg != null)

{= rg.GetValueNames(); FillGrid(ses, rg);

}

} tempreg = null;

}

void FillGrid(string[] str, RegistryKey rg)

{dr = null;(int i = 0; i < str.Length; i++)

{= dt.NewRow(); dr[0] = str[i]; dr[1] = rg.GetValue(str[i]);.Rows.Add(dr);

}.DataSource = dt;

}

void создатьРазделключToolStripMenuItem_Click(object sender, e)

{AddNewDir = new CreateDirForm();.ShowDialog();(!AddNewDir.Cancel)

{rpath = Findreg_by_path(treen);newKey = AddNewDir.Name;.BeginUpdate();rg = rpath.CreateSubKey(newKey, .ReadWriteSubTree);.Nodes.Add(newKey);.Refresh();.EndUpdate();

}

}

void удалитьToolStripMenuItem_Click_1(object sender, EventArgs )

{(MessageBox.Show("Вы действительно хотите удалить этот (раздел)

ключ и все дополнительные ключи (разделы)",

"Внимание", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning)

== DialogResult.OK)

{k_del = Findreg_by_path(treen);(isTreeClick)

{((k_del.Name != "HKEY_CURRENT_USER") || (k_del.Name !=

"HKEY_CLASSES_ROOT")

|| (k_del.Name != "HKEY_LOCAL_MACHINE") || (k_del.Name !=

"HKEY_USERS") || (k_del.Name != "HKEY_CURRENT_CONFIG"))

{k_del2 = Findreg_by_path(treen.Parent);(k_del2.SubKeyCount != 0)_del2.DeleteSubKeyTree(treen.Text);_del.DeleteSubKeyTree(treen.Text);

}.SelectedNode.Remove();

}

{_del.DeleteValue((string)dataGridView1.CurrentRow.Cells[0].Value);.dataGridView1.CurrentRow.Cells[0].Value = "";.dataGridView1.CurrentRow.Cells[1].Value = "";


}

}return;

}

void treeView1_Click(object sender, EventArgs e)

{= true;

}

void dataGridView1_Click(object sender, EventArgs e)

{= false;

}

void строковыйToolStripMenuItem_Click(object sender, EventArgs )

{frm = new CreateStrRegForm();.ShowDialog();(!frm.Cancel)

{nm = frm.Name; string zn = frm.Znach;k_addStr = Findreg_by_path(treen);_addStr.SetValue(nm, zn, RegistryValueKind.String);dr = dt.NewRow(); dr[0] = nm; dr[1] = zn; dt.Rows.Add(dr);

}

}

void dWORDToolStripMenuItem_Click(object sender, EventArgs e)

{frm = new DwordRegForm();.ShowDialog();zn;(!frm.Cancel)

{= Convert.ToInt32(frm.Znach);nm = frm.Name;k_addQword = Findreg_by_path(treen);_addQword.SetValue(nm, zn, RegistryValueKind.DWord);dr = dt.NewRow(); dr[0] = nm; dr[1] = zn; dt.Rows.Add(dr);

}

}

void изменитьToolStripMenuItem_Click(object sender, EventArgs )

{k_upd = Findreg_by_path(treen);frm = new EditRegForm();upd = null;nname = null;.textBox1.Text = (string)dataGridView1.CurrentRow.Cells[0].Value;.textBox2.Text = (string)dataGridView1.CurrentRow.Cells[1].Value;.textBox2.Focus(); frm.textBox2.SelectAll();.ShowDialog();(!frm.Cancel)

{_upd.DeleteValue((string)dataGridView1.CurrentRow.Cells[0].Value);= frm.Znach;= frm.Name;_upd.SetValue(nname, upd);.CurrentRow.Cells[0].Value = nname;.CurrentRow.Cells[1].Value = upd;

}

}

void оПрограммеToolStripMenuItem1_Click(object sender, e)

{aboutForm = new About();.ShowDialog();

}

void выходToolStripMenuItem_Click(object sender, EventArgs e)

{.Close();

}


}

}


СОДЕЖАНИЕ ВВЕДЕНИЕ . АНАЛИЗ СОСТОЯНИЯ ВОПРОСА 1.1 Что такое реестр .2 Роль реестра .3 Реестр Windows 3.1 .4 Реестр Windows NT 3.1 1.5 С

Больше работ по теме:

КОНТАКТНЫЙ EMAIL: [email protected]

Скачать реферат © 2017 | Пользовательское соглашение

Скачать      Реферат

ПРОФЕССИОНАЛЬНАЯ ПОМОЩЬ СТУДЕНТАМ