Откуда берутся шелл-коды

Степан Ильин (step@gameland.ru)

Хакер, номер #085, стр. 085-050-1

Учимся писать шелл-коды самостоятельно

Найти уязвимый сервис и правильно подобрать эксплоит нелегко. И все же значительно сложнее написать этот эксплойт самому, превратить тусклую новость из багтрака в реально работающую отмычку. Сегодня я не расскажу тебе о том, как нужно писать эксплойты, и даже не буду разбирать популярные уязвимости в софте. Но зато с удовольствием научу составлять шелл-код, неотъемлемую часть практически любого сплоита.

[как работает эксплойт]

Проведем небольшой эксперимент. Открой в текстовом редакторе исходник любого эксплойта, обещающего много всяких вкусностей, вроде root-шелла на удаленной машине, и найди в нем самый непонятный участок кода. Такой там будет практически наверняка: смотри внимательнее и ты его найдешь. Скорее всего, тебе на глаза попадется несколько строчек непонятных и ничем не связанных между собой символов. Своеобразная последовательность байт в шестнадцатеричном формате, такая как эта:

char shellcode[] =

"\x33\xc9\x83\xe9\xeb\xd9\xee\xd9\x74\x24\xf4\x5b\x81\x73\x13\x8a"

"\xd4\xf2\xe7\x83\xeb\xfc\xe2\xf4\xbb\x0f\xa1\xa4\xd9\xbe\xf0\x8d"

"\xec\x8c\x6b\x6e\x6b\x19\x72\x71\xc9\x86\x94\x8f\x9b\x88\x94\xb4"

"\x03\x35\x98\x81\xd2\x84\xa3\xb1\x03\x35\x3f\x67\x3a\xb2\x23\x04"

"\x47\x54\xa0\xb5\xdc\x97\x7b\x06\x3a\xb2\x3f\x67\x19\xbe\xf0\xbe"

"\x3a\xeb\x3f\x67\xc3\xad\x0b\x57\x81\x86\x9a\xc8\xa5\xa7\x9a\x8f"

"\xa5\xb6\x9b\x89\x03\x37\xa0\xb4\x03\x35\x3f\x67";

Это и есть тот самый шеллкод, о котором пойдет речь. Иногда его называют байт-кодом, так как он состоит из последовательности байтов, но суть от этого не меняется. Содержимое шелл-кода - отнюдь не хитрое заклинание и не символы, взятые от балды. Это набор самых обыкновенных машинных команд, точно таких же, как и в обычном исполняемом файле. Например, приведенный выше шелл-код (определенная последовательность машинных команд) открывает 4444 порт на локальной Linux-машине и привязывает к нему шелл. Эксплойт, которому удастся выполнить этот шеллкод, предоставит хакеру полный доступ в систему.

С помощью шелл-кода можно также перезагрузить систему, отключить IDS-сервисы и honeypot, отправить заданный файл на мыло и т.д. и т.п. Все зависит от того, что именно прописано в шелл-коде. Заставить компьютер выполнить шелл-код - задача эксплойта. Возьмем для примера распространенную ошибку Buffer Overflow. Разработчики очень часто допускают оплошность и не проверяют данные, которые передаются функциям в качестве параметров. Банальный пример: программист создает динамический массив и выделяет память для 100 элементов, при этом реальное количество элементов нигде не контролирует. Такое положение дел играет на руку взломщику, потому как все данные, которые оказались за пределами этого массива, попадают в стек, происходит так называемое переполнение буфера. Задача эксплойта заключается в том, чтобы переполнить буфер и таким образом подменить адрес возврата на тот, где находится шелл-код. Если шелл-код получит управление, то он будет выполнен. Все довольно просто.

[место действия]

Не стоит рассматривать этот материал как руководство к написанию эксплойтов. Цель этой статьи - на практике показать процесс создания шелл-кода, а также его оптимизации для использования в реальных сплоитах. Конечно, существует немало репозитариев (например, www.metasploit.com) с отличной подборкой шелл-кодов, однако их не всегда бывает достаточно. Ты с самого начала должен понимать, что шелл-код - это последовательность машинных команд (самый низкий и сложный уровень программирования), которые сильно привязаны к конкретной архитектуре процессора и операционной системы. Шелл-код, работающий в одном случае, будет совершенно неприменим в другом. Вот почему так важно понимать, что к чему, чтобы в случае необходимости суметь составить работающий шелл-код самому или модифицировать уже существующий.

Содержание  Вперед на стр. 085-050-2
загрузка...
Журнал Хакер #151Журнал Хакер #150Журнал Хакер #149Журнал Хакер #148Журнал Хакер #147Журнал Хакер #146Журнал Хакер #145Журнал Хакер #144Журнал Хакер #143Журнал Хакер #142Журнал Хакер #141Журнал Хакер #140Журнал Хакер #139Журнал Хакер #138Журнал Хакер #137Журнал Хакер #136Журнал Хакер #135Журнал Хакер #134Журнал Хакер #133Журнал Хакер #132Журнал Хакер #131Журнал Хакер #130Журнал Хакер #129Журнал Хакер #128Журнал Хакер #127Журнал Хакер #126Журнал Хакер #125Журнал Хакер #124Журнал Хакер #123Журнал Хакер #122Журнал Хакер #121Журнал Хакер #120Журнал Хакер #119Журнал Хакер #118Журнал Хакер #117Журнал Хакер #116Журнал Хакер #115Журнал Хакер #114Журнал Хакер #113Журнал Хакер #112Журнал Хакер #111Журнал Хакер #110Журнал Хакер #109Журнал Хакер #108Журнал Хакер #107Журнал Хакер #106Журнал Хакер #105Журнал Хакер #104Журнал Хакер #103Журнал Хакер #102Журнал Хакер #101Журнал Хакер #100Журнал Хакер #099Журнал Хакер #098Журнал Хакер #097Журнал Хакер #096Журнал Хакер #095Журнал Хакер #094Журнал Хакер #093Журнал Хакер #092Журнал Хакер #091Журнал Хакер #090Журнал Хакер #089Журнал Хакер #088Журнал Хакер #087Журнал Хакер #086Журнал Хакер #085Журнал Хакер #084Журнал Хакер #083Журнал Хакер #082Журнал Хакер #081Журнал Хакер #080Журнал Хакер #079Журнал Хакер #078Журнал Хакер #077Журнал Хакер #076Журнал Хакер #075Журнал Хакер #074Журнал Хакер #073Журнал Хакер #072Журнал Хакер #071Журнал Хакер #070Журнал Хакер #069Журнал Хакер #068Журнал Хакер #067Журнал Хакер #066Журнал Хакер #065Журнал Хакер #064Журнал Хакер #063Журнал Хакер #062Журнал Хакер #061Журнал Хакер #060Журнал Хакер #059Журнал Хакер #058Журнал Хакер #057Журнал Хакер #056Журнал Хакер #055Журнал Хакер #054Журнал Хакер #053Журнал Хакер #052Журнал Хакер #051Журнал Хакер #050Журнал Хакер #049Журнал Хакер #048Журнал Хакер #047Журнал Хакер #046Журнал Хакер #045Журнал Хакер #044Журнал Хакер #043Журнал Хакер #042Журнал Хакер #041Журнал Хакер #040Журнал Хакер #039Журнал Хакер #038Журнал Хакер #037Журнал Хакер #036Журнал Хакер #035Журнал Хакер #034Журнал Хакер #033Журнал Хакер #032Журнал Хакер #031Журнал Хакер #030Журнал Хакер #029Журнал Хакер #028Журнал Хакер #027Журнал Хакер #026Журнал Хакер #025Журнал Хакер #024Журнал Хакер #023Журнал Хакер #022Журнал Хакер #021Журнал Хакер #020Журнал Хакер #019Журнал Хакер #018Журнал Хакер #017Журнал Хакер #016Журнал Хакер #015Журнал Хакер #014Журнал Хакер #013Журнал Хакер #012Журнал Хакер #011Журнал Хакер #010Журнал Хакер #009Журнал Хакер #008Журнал Хакер #007Журнал Хакер #006Журнал Хакер #005Журнал Хакер #004Журнал Хакер #003Журнал Хакер #002Журнал Хакер #001