На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
! user posted image
Пожалуйста, выделяйте текст программы тегом [сode=pas] ... [/сode]. Для этого используйте кнопку [code=pas] в форме ответа или комбобокс, если нужно вставить код на языке, отличном от Дельфи/Паскаля.

Соблюдайте общие правила форума

Следующие вопросы задаются очень часто, подробно разобраны в FAQ и, поэтому, будут безжалостно удаляться:
1. Преобразовать переменную типа String в тип PChar (PAnsiChar)
2. Как "свернуть" программу в трей.
3. Как "скрыться" от Ctrl + Alt + Del (заблокировать их и т.п.)
4. Как запустить программу/файл? (и дождаться ее завершения)
5. Как перехватить API-функции, поставить hook? (перехват сообщений от мыши, клавиатуры - внедрение в удаленное адресное прстранство)
... (продолжение следует) ...

Внимание:
Попытки открытия обсуждений реализации вредоносного ПО, включая различные интерпретации спам-ботов, наказывается предупреждением на 30 дней.
Повторная попытка - 60 дней. Последующие попытки - бан.
Мат в разделе - бан на три месяца...

Полезные ссылки:
user posted image MSDN Library user posted image FAQ раздела user posted image Поиск по разделу user posted image Как правильно задавать вопросы


Выразить свое отношение к модераторам раздела можно здесь: user posted image Rouse_, user posted image Krid

Модераторы: Rouse_, Krid
  
> доступ в память
    Драсте! 8) Пиплы, подскажите, плз, как можно просканить память, которую занимает другая прога? Как определить ентот диапазон памяти?
    З.Ы. этакая артмания...
    Сенк...
      0..$7FFFFFFF + $80000000..$FFFFFFFF
        И что ентот хекс значит?
          Мой тебе совет. Если не принципиально не лезь ты в эту память. Будеш перезагружаться после каждого запуска своей проги. Ну а если ты хочеш ломалку для игр писать то зачем велосипед изобретать. Этих ломалок и так навалом. И последние игры уже делаються с защитой от них.
            Мне принципиально.... я пишу не просто ВООБЩЕ, а под конкретную прогу...
            З.Ы. я даже смещение знаю.... мне бы адрес сегмента.......
              Цитата
              Гость VUD, 28.11.03, 18:19
              И что ентот хекс значит?


              Это диапазон, который занимает прога в контексте своего пространства. А адресное пространство на уровне системы не плоское, а страничное, если я ничего не путаю. Короче, виртуальная память.
                Товарищ, ты мне близок smile.gif Я бесюсь, если вместо ответа мне говорят "на тебе это надо, вот есть прога, используй ее!" Мне интересен процесс, а не результат. Итак, решение:
                ReadProcessMemory, WriteProcessMemory.

                BOOL ReadProcessMemory(

                HANDLE hProcess, // хэндл процесса, открывается OpenProcess
                LPCVOID lpBaseAddress, // Адрес начала куска памяти, смещение
                LPVOID lpBuffer, // адрес буфера под ентот кусок
                DWORD nSize, // количество байтов, которые надо прочитать
                LPDWORD lpNumberOfBytesRead // Переменная, в которую скинется количество прочитанных байтов
                );

                Прототип WriteProcessMemory такой же, только он пишет в память. С помощью этих функций написать свою Артманю - дело пары часов ненапряжного труда...
                  Сенк, товарищ 8@)
                  0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
                  0 пользователей:


                  Рейтинг@Mail.ru
                  [ Script execution time: 0,0244 ]   [ 16 queries used ]   [ Generated: 27.04.24, 12:58 GMT ]