| FreeMan |
4.01.2005 10:23
Сообщение
#1
|
|
- ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 480 Пол: Мужской Репутация: 4 |
Почти каждый, кто изучает язык ассемблера, рано или поздно пишет вирус, некоторые люди пишут вирус, когда заканчивают изучать какой-нибудь язык программирования... Прежде чем читать то, что я буду писать ниже и понимать хоть что-нибудь, вы должны:
а) знать основные команды ассемблера б) уметь пользоватся АПИ-функциями в) взять где-нибудь (можно и у меня) TASM32 (можно и другой, но каждый компилятор имеет свои особенности). г) отладчик (если собираетесь собственноручно создать зверька, то без отладки довольно трудно найти ошибки) д) прогу, которая прикреплена (на неё вопит касперский, но это не вирус!!!! ) е) иметь здоровую голову (если вы хотите испортить все компы на Земле, то ваше место в больнице, а не здесь) ё) ПОМНИТЬ, ЧТО ЭТОТ МАТЕРИАЛ ПРЕДСТАВЛЕН ТОЛЬКО В ЦЕЛЯХ ОБУЧЕНИЯ, И ЗА ПОСЛЕДСТВИЯ Я НИКАКОЙ ОТВЕТСТВЕННОСТИ НЕ НЕСУ Вроде всё. Теперь план обучения: 1) формат заголовка файла РЕ 2) разбор основных полей заголовка РЕ 3) методика заражения 4) дельта-смещение. 5) поиск АПИ 6) разбор используемых АПИ 7) пишем код 8) Reserved Прикрепленные файлы -------------------- бб
|
![]() ![]() |
| FreeMan |
4.01.2005 10:33
Сообщение
#2
|
|
- ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 480 Пол: Мужской Репутация: 4 |
3. Методика заражения
Пишу в виде алгоритма, хотя я не умею их делать. Пишу с того момента, когда мы отловили адреса апишек, после всех приготовлений (об этом ниже). 1) ищем файл 2) открываем, проверяем на зараженность, если всё ОК, то идём дальше, если нет то на шаг 8 3) ищем последнюю секцию 4) пишем код ей в зад 5) фиксим некоторые поля заголовка и соответствующего элемента Object Table 6) устанавливаем метку заражения 7) закрываем 8) заразили достаточно, на шаг 10, нет - дальше 9) ищем следующий, валим на шаг 2 10) если первое поколение то просто выходим, если нет, то передаём управление носителю Что-то типа этого. На практике разберётесь (на самом деле всё сложнее немного). Продолжу, если это будет хоть кому-нибудь интересно. Кому интересно или если вы заметили какие-то ошибки или недочёты, то пишите в PM или стучите в асю 88880172, выражайте свои мысли. -------------------- бб
|
FreeMan Пишем вирус... 4.01.2005 10:23
FreeMan 1. Формат заголовка РЕ
Заголовок - это структура,... 4.01.2005 10:25
FreeMan 2. Разбор основных полей РЕ заголовка.
Итак, вы п... 4.01.2005 10:31
FreeMan 4. Дельта смещение.
При линковке программы происхо... 5.01.2005 10:17
FreeMan 3.1 В поисках дельты.
Может вам показалось, что по... 5.01.2005 10:17
FreeMan 5) Поиск АПИ.
Когда Винда загружает файл, она в ад... 5.01.2005 10:20
FreeMan [b]5.1. Поиск адреса кернела
Кернел висит в памяти... 5.01.2005 11:38
FreeMan [b]5.2 Поиск АПИ...
Теперь адрес кернела мы знаем... 5.01.2005 13:07
FreeMan [b]6. Pазбор используемых АПИ
Разбор сводится к ко... 7.01.2005 12:51
FreeMan FindFirstFileA - ищет файл в текущей директории
... 7.01.2005 13:13
FreeMan FindNextFileA - ищет следующий файл
hFindFile -... 7.01.2005 13:30
FreeMan MapViewOfFile - помещает промэппированный файл в п... 7.01.2005 13:45
FreeMan UnmapViewOfFile - полная противоположность MapView... 12.01.2005 17:37
FreeMan [b]7. Пишем код
В исполняемый файл добавляем код ... 12.01.2005 17:38
FreeMan То есть, для успешного заражения надо пофиксить ещ... 12.01.2005 17:41
FreeMan [b]7.1 Пишем код
Для разминки напишем прогу, котор... 12.01.2005 17:42
FreeMan Кстати, вышел номер 29А... http://www.vx.netlux.or... 12.01.2005 18:03
FreeMan Теперь пришло время писать код.
includelib import... 14.01.2005 16:51
FreeMan ls_found:
; сюда попадём после того, как найдена ... 14.01.2005 16:52
Тоха ЭТО КРУТО!
Спасибо большое. 26.02.2009 13:09![]() ![]() |
|
Текстовая версия | 3.11.2025 23:23 |