Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Как поиметь память другого процесса ?

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Alexis101
Гость





СообщениеДобавлено: Вт Мар 26 2002 14:00    Заголовок сообщения: Как поиметь память другого процесса ? Ответить с цитатой

Задача заключается в обращении (чтении, записи) к памяти любого запущенного в системе (Win) процесса. Если знаете где можно об этом прочетать, оставьте ссылку. Заранее спасибо.
Вернуться к началу
яяя
Гость





СообщениеДобавлено: Вт Мар 26 2002 16:31    Заголовок сообщения: codeguru.com, rsdn.com, msdn, ... (-) Ответить с цитатой

-
Вернуться к началу
Alexis101
Гость





СообщениеДобавлено: Вт Мар 26 2002 20:21    Заголовок сообщения: Re: codeguru.com, rsdn.com, msdn, ... (-) Ответить с цитатой

Спасибо за ответ. Буду искать. Но надеюсь, что Вы, обращаясь к врачу, юристу (например) со своей проблемой, получите более внятный результат Smile
Вернуться к началу
Alexy



Зарегистрирован: 22.10.2003
Сообщения: 48

СообщениеДобавлено: Ср Мар 27 2002 10:58    Заголовок сообщения: Re: Как поиметь память другого процесса ? Ответить с цитатой

Если речь идёт о каком-то известном процессе,
то потребуется его HANDLE и пара API функций:
ReadProcessMemory, WriteProcessMemory.
Ограничения: нужно иметь права чтения/записи
в процесс, код исполняющийся в user-mode не может
писать в область памяти зарезервированную для OS.
(user-mode - обычный код обычной аппликации.
или user-mode: CS & 0x3 == 0x3,kernel-mode: CS & 0x3 == 0)

На сайте www.microsoft.com есть MSDN On Line,
там можно найти описания всех нужных ф-й,
в том числе как получить права чтения/записи


Если речь идёт о том, что нужно найти и изменить/посмотреть
неизвестный процесс, то это посложнее.
Есть полудокументированная библиотека psapi.dll
Вот имена ф-ций, так как они описаны в
таблице экспорта библиотеки:

const char* psAPI_Names[] = {
"EmptyWorkingSet", "EnumDeviceDrivers", "EnumPageFilesA",
"E.. "GetDeviceDriverBaseNameW", "GetDeviceDriverFileNameA",
"GetDeviceD.. ф-й и многие используемые структуры
неописаны в header-ах.


Удачи.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Посетить сайт автора
Alexy



Зарегистрирован: 22.10.2003
Сообщения: 48

СообщениеДобавлено: Ср Мар 27 2002 11:02    Заголовок сообщения: Oops Ответить с цитатой

/*
Names from exports table of psapi.dll

"EmptyWorkingSet",
"EnumDeviceDrivers",
"EnumPageFilesA..
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Посетить сайт автора
Alexy



Зарегистрирован: 22.10.2003
Сообщения: 48

СообщениеДобавлено: Ср Мар 27 2002 11:09    Заголовок сообщения: Re: Oops Ответить с цитатой

Ok, имена ф-й можно посмотреть в самой библиотеке. Если будут затруднения - сообщите
куда их сбросить.
GetProcAddress нужно давать точное имя из
таблицы экспортов, поскольку прототипы ф-й
этой библиотеки не описаны в header-ах
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Посетить сайт автора
яяя
Гость





СообщениеДобавлено: Чт Мар 28 2002 08:29    Заголовок сообщения: более внятный результат этот форум проглатывает, могу намылить исходники, если надо, мыло только оставьте (-) Ответить с цитатой

-
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...