Главная · Поиск книг · Поступления книг · Top 40 · Форумы · Ссылки · Читатели

Настройка текста
Перенос строк


    Прохождения игр    
Roman legionnaire vs Knight Artorias
Ghost-Skeleton in DSR
Expedition SCP-432-4
Expedition SCP-432-3 DATA EXPUNGED

Другие игры...


liveinternet.ru: показано число просмотров за 24 часа, посетителей за 24 часа и за сегодня
Rambler's Top100
Образование - Коваль И. Весь текст 308.41 Kb

Как написать компьютерный вирус

Следующая страница
 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ... 27
             КАК НАПИСАТЬ КОМПЬЮТЕРНЫЙ ВИРУС
          -------------------------------------


                       СОДЕРЖАНИЕ
                    ----------------

                                                  стр.

    ВВЕДЕНИЕ ..................................... 5


    ЧАСТЬ 1 . COM - ВИРУСЫ ....................... 6

       ГЛАВА 1 . РАЗРАБОТКА НЕРЕЗИДЕНТНОЙ
                 ВИРУСНОЙ ПРОГРАММЫ .............. 6
        1.1  Загрузка и выполнение
             COM - программы ..................... 6
        1.2  Как вирус может заразить
             COM - файл .......................... 7
        1.3  Работа вируса в
             зараженной программе ................ 8
        1.4  Как начинается
             распространение вируса .............. 9
        1.5  Начало работы ....................... 10
        1.6  Вирус получает управление ........... 10
        1.7  Восстанавливаем зараженную
             программу ........................... 12
        1.8  Запоминаем содержимое DTA ........... 12
        1.9  Ищем подходящий файл ................ 13
        1.10 Читаем исходные три байта ........... 15
        1.11 Выполняем необходимые расчеты ....... 16
        1.12 Проверяем файл на зараженность ...... 18
        1.13 Заражаем COM - программу ............ 19
        1.14 Восстанавливаем DTA ................. 20
        1.15 Передаем управление
             зараженной программе ................ 20
        1.16 Область данных вирусной программы ... 21
        1.17 Завершаем запускающую программу ..... 21
        1.18 Текст нерезидентного COM - вируса ... 23
        1.19 Комментарии ......................... 29
        1.20 Испытание вируса .................... 29

       ГЛАВА 2 . РАЗРАБОТКА РЕЗИДЕНТНОЙ
                 ВИРУСНОЙ ПРОГРАММЫ .............. 30
        2.1  Понятие резидентного
             ( TSR ) вируса ...................... 30
        2.2  Несколько слов о
             резидентных программах .............. 30
        2.3  Алгоритм работы
             резидентного COM - вируса ........... 31
        2.4  Заголовок вируса .................... 34
        2.5  Вирус начинает работу ............... 34
        2.6  Сохраняем регистры процессора ....... 38
        2.7  Создаем секцию
             инициализации ....................... 39
        2.8  Запрашиваем блок памяти ............. 41
        2.9  Делаем вирус " незаметным " ......... 44
        2.10 Получаем вектора прерываний ......... 46
        2.11 Копируем вирусный код в память ...... 48
        2.12 Устанавливаем вектора прерываний
             на вирусные обработчики ............. 48
        2.13 Пишем резидентную часть ............. 50
        2.14 Заражаем COM - файл ................. 51
        2.15 Восстанавливаем регистры ............ 56
        2.16 Пишем обработчики прерываний ........ 57
        2.17 Обработчик Int 13h .................. 58
        2.18 Обработчик Int 21h .................. 60
        2.19 Обработчик Int 24h .................. 62
        2.20 Обработчик Int 2Fh .................. 62
        2.21 Обработчик Int 28h .................. 64
        2.22 Область данных вируса ............... 64
        2.23 Процедура идентификации COMMAND.COM.. 65
        2.24 Завершаем программу ................. 66
        2.25 Текст резидентного COM - вируса ..... 67
        2.26 Комментарии ......................... 81
        2.27 Испытание вируса .................... 82


    ЧАСТЬ 2 . EXE - ВИРУСЫ ....................... 82

       ГЛАВА 1 . РАЗРАБОТКА НЕРЕЗИДЕНТНОГО
                 EXE - ВИРУСА .................... 82
        1.1  Формат EXE - файла на диске ......... 82
        1.2  Загрузка и выполнение
             EXE - программы ..................... 84
        1.3  Как вирус может заразить
             EXE - файл .......................... 86
        1.4  Работа вируса в
             зараженной программе ................ 86
        1.5  Начало работы ....................... 88
        1.6  Вирус получает управление ........... 88
        1.7  Ищем подходящий файл ................ 89
        1.8  Читаем заголовок файла .............. 92
        1.9  Производим необходимые
             вычисления .......................... 93
        1.10 Заражаем EXE - программу ............ 98
        1.11 Восстанавливаем DTA ................. 99
        1.12 Восстанавливаем точку входа ......... 100
        1.13 Область данных вируса ............... 101
        1.14 Используемые процедуры .............. 103
        1.15 Работа завершена .................... 104
        1.16 Полный текст
             нерезидентного EXE - вируса ......... 104
        1.17 Несколько слов об
             испытании вируса .................... 112

       ГЛАВА 2 . РАЗРАБОТКА РЕЗИДЕНТНОГО
                 EXE - ВИРУСА .................... 113
        2.1  Алгоритм работы резидентного
             EXE - вируса ........................ 113
        2.2  Защита от
             программ - антивирусов .............. 115
        2.3  Как реализовать защиту от
             эвристического анализа .............. 116
        2.4  Реализуем предложенный алгоритм ..... 119
        2.5  Пишем промежуточный обработчик ...... 121
        2.6  Защита от обнаружения вируса в файле. 122
        2.7  Несколько слов о вредных
             действиях вирусной программы......... 122
        2.8  Полный текст резидентного
             EXE - вируса ........................ 123


    ЧАСТЬ 3 . ЗАГРУЗОЧНЫЕ ВИРУСЫ ................. 143

       ГЛАВА 1 . РАЗРАБОТКА ЗАГРУЗОЧНОЙ
                 ВИРУСНОЙ ПРОГРАММЫ .............. 143
        1.1  Краткие сведения о начальной
             загрузке персонального компьютера ... 143
        1.2  Понятие о загрузочных вирусах ....... 144
        1.3  Алгоритм работы загрузочного
             вируса .............................. 145
        1.4  Как начинается распространение
             вируса .............................. 147
        1.5  Начало работы ....................... 147
        1.6  Вирус получает управление ........... 148
        1.7  Защита от антивирусных программ ..... 150
        1.8  Перехватываем Int 13h ............... 152
        1.9  Читаем исходную BOOT - запись ....... 153
        1.10 Заражаем MBR винчестера ............. 154
        1.11 Пишем обработчик прерывания Int 13h . 156
        1.12 Используемые процедуры .............. 161
        1.13 Область данных вируса ............... 162
        1.14 Пишем секцию инсталляции ............ 163
        1.15 Текст загрузочного вируса ........... 166
        1.16 Комментарии ......................... 176
        1.17 Испытание вируса .................... 177


    ЗАКЛЮЧЕНИЕ ................................... 177

    ПРИЛОЖЕНИЕ 1
    Краткий справочник по функциям
    MS DOS и BIOS ................................ 178

    ПРИЛОЖЕНИЕ 2
    Формат загрузочной записи для MS DOS
    различных версий ............................. 186

    ПРИЛОЖЕНИЕ 3
    КОДЫ ОШИБОК ПРИ ВЫПОЛНЕНИИ ФУНКЦИЙ
    MS DOS и BIOS ................................ 192

    ЛИТЕРАТУРА ................................... 194


                        ВВЕДЕНИЕ

    Компьютерные  вирусы  со времени  своего появления
    распространились  чрезвычайно широко . Сейчас  уже
    трудно найти человека,который бы ни разу не слышал
    об этих " существах " .И вместе с тем  подавляющее
    большинство пользователей почти ничего  не знают о
    том,  что это такое,  и склонны  приписывать виру-
    сам различные фантастические возможности,  а также
    сильно преувеличивать их опасность.Словом,эта тема
    окутывается  завесой таинственности .Такое положе-
    ние возникло,  главным образом, из - за почти пол-
    ного отсутствия специальной литературы  по данному
    вопросу ( причина этого вполне понятна ).А в имею-
    щейся литературе для широкого круга читателей ино-
    гда можно встретить  ошибочные и  неправдоподобные
    сведения .Например, в одной очень распространенной
    и читаемой  книге сказано,  что  некоторые  вирусы
    "выживают" в компьютере даже после выключения  пи-
    тания !Неизвестно,что имел ввиду автор,но эта фра-
    за полностью абсурдна . Дело в том,  что  при вык-
    лючении питания содержимое оперативной памяти  те-
    ряется, в ПЗУ записать что - либо невозможно, а  в
    CMOS - памяти свободного места для хранения вирус-
    ного  кода никогда не хватит .Вирус может "выжить"
    в компьютере разве  что на жестком диске, но  этой
    способностью обладают все вирусные программы .
    Книга, которая предлагается вашему вниманию, напи-
    сана с  использованием собственных разработок, на-
    блюдений и  экспериментов  автора .Изложение  рас-
    считано на пользователей, знакомых с языком ассем-
    блера микропроцессоров семейства 8086 фирмы INTEL.
    Автор  рассказывает  о  принципах  работы  компью-
    терных  вирусов и подробно описывает процесс  соз-
    дания нерезидентных, резидентных и загрузочных ви-
    русов. Разработка  программ  ведется от простого к
    сложному. Предыдущие  программы становятся основой
    для  разработки  последующих . Читатель  найдет  в
    книге большое количество  хорошо прокомментирован-
    ных  исходных текстов .Каждая фаза  создания виру-
    сов подробно объясняется .В общем,читайте и совер-
    шенствуйтесь !Разобравшись с программами,приведен-
    ными в книге,вы сможете создавать  собственные ви-
    русы,  а главное - повысите свой  профессиональный
    уровень .Кроме того, устойчивое  мнение,  что "Ви-
    русы пишут только гении,мудрецы  и " посвященные "
    покинет вас навсегда .
    УДАЧИ !
    18.08.1998
    Автор .


                  ЧАСТЬ 1 . COM - ВИРУСЫ


           ГЛАВА 1 . РАЗРАБОТКА НЕРЕЗИДЕНТНОЙ
                    ВИРУСНОЙ ПРОГРАММЫ

    * Эта глава написана "по мотивам" [ 3 ] и не  пре-
      тендует на оригинальность. Предложенная в  книге
      П.Л.Хижняка программа существенно  переработана,
      исправлены  замеченные  ошибки и  глюки. Так что
      Главу 1 можно рассматривать как "ре-мэйк" разра-
      ботки тов. Хижняка.


        1.1  Загрузка и выполнение COM - программы

    Для того,  чтобы дальнейшее изложение стало  более
    понятным, следует  немного рассказать  о действиях
    MS DOS при  запуске программы типа COM.
    Для запуска программ в системе MS DOS используется
    специальная функция  EXEC . Действия этой  функции
    при запуске COM - программы выглядят так :

    1. Запускаемой  программе  отводится  вся  свобод-
    ная в данный момент оперативная память .Сегментная
    часть начального адреса этой памяти обычно называ-
    ется начальным сегментом программы.

    2. По нулевому  смещению в  сегменте, определяемом
    начальным сегментом программы,  EXEC строит специ-
    альную  служебную структуру - так  называемый  PSP
    ( Program Segment Prefix ),  в котором  содержится
    информация,необходимая для правильной работы прог-
    раммы . Заполняет PSP операционная система ( ОС ),
    а его размер всегда равен 100h ( 256 ) байт .

    3. Сразу вслед за PSP загружается сама COM - прог-
    рамма .

    4. EXEC  выполняет настройку регистров процессора.
    При этом устанавливаются такие значения :CS = DS =
    = SS = ES указывают на начальный  сегмент  програ-
    ммы,  регистр IP инициализируется числом  100h,  а
    регистр SP - числом 0fffeh .

    5. Теперь загруженную COM - программу можно испол-
    нить . Для этого EXEC передает управление по адре-
    су CS : 100h.После завершения программы управление
    передается обратно в  EXEC,  а оттуда программе  -
    предку .

    Таким образом,по адресу CS : 100h обязательно дол-
    жна стоять первая исполняемая команда .Чаще  всего
    это команда перехода,  но допустимо использовать и
    другие .Следует также напомнить, что в MS DOS раз-
Следующая страница
 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ... 27
Ваша оценка:
Комментарий:
  Подпись:
(Чтобы комментарии всегда подписывались Вашим именем, можете зарегистрироваться в Клубе читателей)
  Сайт:
 
Комментарии (9)

Реклама