Вирус, который не увидит AVP!

Xakep Online -> Журнал, номер #012, стр. 012-034-1

Roman Hady

Здарова, дружище! Что такой грустный? Последний троян, которого ты забросил, обнаружили еще в посылке? И весь задуманный план мести полетел к черту? Пиши свой! Что, неужели так трудно? Скачай ViriiLab, которых пруд пруди в Сети, и клепай своих. Все равно ловят? И правильно - не так-то просто написать хороший вирь. Да еще и обычные антивирусные сканеры превратились во что-то вообще непотребное - эвристики. Ох уж эти антивирусисты - вечно-то они что-нибудь придумают, чтобы испортить жизнь таким, как мы. Ну да ничего, мы тоже не на васике писаны :). Давай разбираться, как устроены эти их супер-пупер навороченные программы, "использующие методы эвристического анализа".

Немного теории

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

Именно с этой мыслью и головной болью (от не слишком удачного вчерашнего вечера) я принялся за анализ горячо любимого всеми вирмейкерами AVP и не менее любимого DrWeb. А для пущей убедительности взял код "стороннего" производителя - вирь из пакета, сродни VirriLab. Некто Nowhere Man (популярная личность, кстати) накодил его на ассемблере много-много лет назад (штамм 1992(c)) и назвал он свое детище нерукотворное - CodeZero. Довольно примитивный вирь, надо сказать. И хотя использует шифрование собственного тела, от AVP и DrWeb это его не спасает.

Итак, скомпилировал я его, прошелся по нему AVP - тот заорал так, как будто ему за это премии дают. Прошелся DrWeb`ом - оба оказались навороченными шкафами и выжить несчастному CodeZero не дали.

Написание собственного вируса что называется с нуля тоже принесло мало толка - возомнив себя бодибилдерами с правами ОМОНа, AVP и DrWeb растерзали моего несчастного паразита в один момент. Невинно убиенный стал последней каплей, переполнившей чашу моего терпения.

Основная инфа

Итак, начнем-с. Многие антивирусы, реализующие функции эвристического анализа (вроде AVP и DrWeb) в лучшем случае являются декодерами части команд процессора. То есть выдирают по одной команде из exe-шника и смотрят в заранее подготовленный (еще на стадии создания самого антивируса) "черный список". Если в списке такая команда (а обычно не одна, а несколько - участок кода, например, вызов какого-то прерывания c определенными значениями) присутствует, то программе добавляют "балл". Как только баллов больше чем обычно - орут благим матом о подозрительном коде. Конечно, у каждого эвристика (то есть его автора) свое мнение о "подозрительных" командах, которые могут принадлежать паразитам. Но, в основном, это обращения к прерываниям (особенно 21h - чтение и запись в файл), всякого рода махинации с таблицей векторов, блоками памяти "ручным способом" (то есть с помощью корявых рук вирмейкера). Иногда сюда добавляются команды, которые могут использоваться для расшифровки самомодифицирующихся вирусов и вирусов, кодирующих себя. Как это, видимо, и произошло в случае CodeZero и моего несчастного дитяти.

Содержание  Вперед на стр. 012-034-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