Как работают роботы-убийцы

Xakep, номер #042, стр. 042-046-1

Технологии вирмейкерства

sl0n (bigafroelephant@mail.ru)

Ты откуда журнал читаешь? С начала или с конца? Ну, т.е. ты сегодня начал с извратов Данечки или с техноудара Алекса Целых? Ладно, это все неважно на самом деле :). Мы поговорим о другом, о том, как вирусы прячутся от людей и антивирусных программ. И вообще, что они могут, эти вирусы, а главное - как?

Прятаться и бояться

Одними из самых первых маскировочных механизмов вирусов был "неполный стэлс механизм", т.е. когда либо пользователь, либо программа обращались к зараженному файлу, а вирус резидентный (который постоянно находится в памяти как бы в спящем состоянии) просыпался и изменял информацию о размере файла на старый размер файла, как будто вирусного тела там и не было.

Но если заглянуть внутрь файла, то вирусное тело, как и положено, будет на месте, что и позволяет его удалить.

Позже появились вирусы, основанные на так называемой технологии "полный стэлс". Данная технология заключалось в том, что вирус, как и в предыдущем примере, будучи резидентным, отлавливал Дос функции чтения или изменения файла и, перед тем как передать управление Досу, он вначале удалял вирусное тело. И когда пользователь или антивирусная программа смотрели файл, то вируса там уже не было, а перед закрытием та часть вируса, что была в памяти, опять заражала файл. Вот поэтому вирусы с такой технологией маскировки было очень сложно обнаружить.

Но Дос уже практически умер, и потому стэлс вири не очень распространены, т.к. создание стэлс вируса, полноценно работающего под Windows, под силу далеко не каждому вирмейкеру. Сейчас довольно распространены вири, которые используют для маскировки антиэвристические механизмы и "мутационные" технологии aka полиморфизм.

Бороться и сражаться

И так на что же рассчитаны антиэвристические приемы? Конечно же, на обман антивирусных программ! Чтобы узнать, как эти приемы работают, давай разберемся с тем, как работают эвристические анализаторы в антивирусах.

Если у тебя в программе есть поиск (Дос функция 4eh) по маске *.exe и в этой же программе есть функция записи (Дос функция 40h), то с какой-то долей уверенности можно сказать, что в файле гнездится вирус. Вот это и есть механизм работы анализатора кода. Но анализатор сам по себе не работает, он работает в паре с эмулятором кода. Эмулятор кода необходим для обнаружения шифрующихся вирусов (полиморфных), он эмулирует работу процессора и пытается псевдоисполнить файл. В то время как он псевдоисполняет файл, анализатор ищет подозрительные мнемоники кода. Обычно антиэвристические приемы строятся либо на обмане эмулятора, либо на обмане анализатора.

Начнем с эмулятора. Есть возможность обмана на стадии эмуляции процессора, когда процессор имеет какие-то ошибки, и в реальной жизни команды будут выполняться не так, как при эмуляции.

Рассмотрим пример:

;--------------------------

xor ax,ax

sahf

lahf ; ax=2

xchg al,ah

add ax,5

call $+3

pop si

add si,ax

jmp si

mov bl,56h

;---------------------------

На самом деле, т.е. в реальных условиях, этот код процессором не выполнится. А вот при эмуляции антивирусом выполнится, т.е. если bx - ключ расшифровщика, то антивирус никогда не сможет правильно расшифровать вирус.

Содержание  Вперед на стр. 042-046-2

Выпуски журнала "Xakep"
Журнал Хакер. Содержание номера #001Журнал Хакер. Содержание номера #002Журнал Хакер. Содержание номера #003Журнал Хакер. Содержание номера #004Журнал Хакер. Содержание номера #005Журнал Хакер. Содержание номера #006Журнал Хакер. Содержание номера #007Журнал Хакер. Содержание номера #008Журнал Хакер. Содержание номера #009Журнал Хакер. Содержание номера #010Журнал Хакер. Содержание номера #011Журнал Хакер. Содержание номера #012Журнал Хакер. Содержание номера #013Журнал Хакер. Содержание номера #014Журнал Хакер. Содержание номера #015Журнал Хакер. Содержание номера #016Журнал Хакер. Содержание номера #017Журнал Хакер. Содержание номера #018Журнал Хакер. Содержание номера #019Журнал Хакер. Содержание номера #020Журнал Хакер. Содержание номера #021Журнал Хакер. Содержание номера #022Журнал Хакер. Содержание номера #023Журнал Хакер. Содержание номера #024Журнал Хакер. Содержание номера #025Журнал Хакер. Содержание номера #026Журнал Хакер. Содержание номера #027Журнал Хакер. Содержание номера #028Журнал Хакер. Содержание номера #029Журнал Хакер. Содержание номера #030Журнал Хакер. Содержание номера #031Журнал Хакер. Содержание номера #032Журнал Хакер. Содержание номера #033Журнал Хакер. Содержание номера #034Журнал Хакер. Содержание номера #035Журнал Хакер. Содержание номера #036Журнал Хакер. Содержание номера #037Журнал Хакер. Содержание номера #038Журнал Хакер. Содержание номера #039Журнал Хакер. Содержание номера #040Журнал Хакер. Содержание номера #041Журнал Хакер. Содержание номера #042Журнал Хакер. Содержание номера #043Журнал Хакер. Содержание номера #044Журнал Хакер. Содержание номера #045Журнал Хакер. Содержание номера #046Журнал Хакер. Содержание номера #047Журнал Хакер. Содержание номера #048Журнал Хакер. Содержание номера #049Журнал Хакер. Содержание номера #050Журнал Хакер. Содержание номера #051Журнал Хакер. Содержание номера #052Журнал Хакер. Содержание номера #053Журнал Хакер. Содержание номера #054Журнал Хакер. Содержание номера #055Журнал Хакер. Содержание номера #056Журнал Хакер. Содержание номера #057Журнал Хакер. Содержание номера #058Журнал Хакер. Содержание номера #059Журнал Хакер. Содержание номера #060Журнал Хакер. Содержание номера #061Журнал Хакер. Содержание номера #062Журнал Хакер. Содержание номера #063Журнал Хакер. Содержание номера #064Журнал Хакер. Содержание номера #065Журнал Хакер. Содержание номера #066Журнал Хакер. Содержание номера #067Журнал Хакер. Содержание номера #068Журнал Хакер. Содержание номера #069Журнал Хакер. Содержание номера #070Журнал Хакер. Содержание номера #071Журнал Хакер. Содержание номера #072Журнал Хакер. Содержание номера #073Журнал Хакер. Содержание номера #074Журнал Хакер. Содержание номера #075Журнал Хакер. Содержание номера #076Журнал Хакер. Содержание номера #077Журнал Хакер. Содержание номера #078Журнал Хакер. Содержание номера #079Журнал Хакер. Содержание номера #080Журнал Хакер. Содержание номера #081Журнал Хакер. Содержание номера #082Журнал Хакер. Содержание номера #083Журнал Хакер. Содержание номера #084Журнал Хакер. Содержание номера #085Журнал Хакер. Содержание номера #086Журнал Хакер. Содержание номера #087Журнал Хакер. Содержание номера #088Журнал Хакер. Содержание номера #089Журнал Хакер. Содержание номера #090Журнал Хакер. Содержание номера #091Журнал Хакер. Содержание номера #092Журнал Хакер. Содержание номера #093Журнал Хакер. Содержание номера #094Журнал Хакер. Содержание номера #095Журнал Хакер. Содержание номера #096Журнал Хакер. Содержание номера #097Журнал Хакер. Содержание номера #098Журнал Хакер. Содержание номера #099Журнал Хакер. Содержание номера #100Журнал Хакер. Содержание номера #101Журнал Хакер. Содержание номера #102Журнал Хакер. Содержание номера #103Журнал Хакер. Содержание номера #104Журнал Хакер. Содержание номера #105Журнал Хакер. Содержание номера #106Журнал Хакер. Содержание номера #107Журнал Хакер. Содержание номера #108Журнал Хакер. Содержание номера #109Журнал Хакер. Содержание номера #110Журнал Хакер. Содержание номера #111Журнал Хакер. Содержание номера #112Журнал Хакер. Содержание номера #113Журнал Хакер. Содержание номера #114