![]() |
Модераторы: feodorv, GremlinProg, xvr, Fixin |
![]() ![]() ![]() |
|
pseudor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 21 Регистрация: 22.5.2007 Репутация: нет Всего: нет |
Пишу утилитку, которая висит в виде сервиса и проверяет, кто, когда и какие приложения устанавливал/удалял. Я использовал Msi.lib, а теперь добавил проверку чтением списка из подключа SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall - если событие было, а список, полученный от MSI, не изменился - самое время читать реестр. Теперь одна проблема у меня, наверное, самая крупная - это как определить, какой пользователь производит установку/удаление, основываясь на том факте, что в результате его действий были внесены изменения в реестр?
|
|||
|
||||
SenkraD |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 933 Регистрация: 3.2.2006 Где: Украина::Киев Репутация: 4 Всего: 23 |
Вот несколько скорых вариантов:
1. Читать системный журнал событий 2. Ловить обращения к реестру, а также определять текущего юзверя и писать это дело в свой лог |
|||
|
||||
pseudor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 21 Регистрация: 22.5.2007 Репутация: нет Всего: нет |
С этого места, пожалуйста, подробнее про первый вариант.
Во втором мне помогут хуки. А как определить текущего пользователя? Не того, от имени которого запущена моя утилитка. А если этот пользователь работает с помощью удалённого терминала? ![]() |
|||
|
||||
SenkraD |
|
||||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 933 Регистрация: 3.2.2006 Где: Украина::Киев Репутация: 4 Всего: 23 |
в любом случае это будет текущий юзер, кажись. А на счёт прочитки сислога? Вот пример с MSDN:
|
||||
|
|||||
pseudor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 21 Регистрация: 22.5.2007 Репутация: нет Всего: нет |
Извините, а виндовая утилита Программы-Администрирование-Просмотр_событий читает весь журнал? Если да - то тогда такое решение не подходит - записи об установке без использования MSI туда не попали.
|
|||
|
||||
SenkraD |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 933 Регистрация: 3.2.2006 Где: Украина::Киев Репутация: 4 Всего: 23 |
||||
|
||||
Smarts |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 67 Регистрация: 23.4.2007 Репутация: 2 Всего: 2 |
Есть подобная утилита под названием RegMon, и более новая - Process Monitor: http://www.microsoft.com/technet/sysintern...essmonitor.mspx
посмотри как они работают, тебе надо просто перехватить все функции реестра и добавлять в лог при каждом вызове |
|||
|
||||
pseudor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 21 Регистрация: 22.5.2007 Репутация: нет Всего: нет |
Так события изменения уже отлавливаются, проблема в определении имени пользователя, который производил установку/удаление.
|
|||
|
||||
pseudor |
|
|||
Новичок Профиль Группа: Участник Сообщений: 21 Регистрация: 22.5.2007 Репутация: нет Всего: нет |
Пойду таким путём - буду использовать хук на RegCreateKey и RegDeleteKey, в котором буду определять вызвавшего пользователя, если эти функции будут относиться к SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall.
Если есть какие-то напутствия - очень буду рад услышать. |
|||
|
||||
![]() ![]() ![]() |
Правила форума "C/C++: Системное программирование и WinAPI" | |
|
На данный раздел распространяются Правила форума и Правила раздела С++:Общие вопросы . Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Chipset, Step, Fixin, GremlinProg, xvr. feodorv. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Системное программирование и WinAPI | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |